Прочитать WM_POWERBROADCAST

Программирование на Visual Basic, главный форум. Обсуждение тем программирования на VB 1—6.
Даже если вы плохо разбираетесь в VB и программировании вообще — тут вам помогут. В разумных пределах, конечно.
Правила форума
Темы, в которых будет сначала написано «что нужно сделать», а затем просьба «помогите», будут закрыты.
Читайте требования к создаваемым темам.
NIC
Продвинутый пользователь
Продвинутый пользователь
 
Сообщения: 175
Зарегистрирован: 26.04.2005 (Вт) 4:50

Прочитать WM_POWERBROADCAST

Сообщение NIC » 13.12.2007 (Чт) 4:50

Никак ни получаеться это сделать:
Код: Выделить всё
Private Declare Function WaitMessage Lib "user32" () As Long
Private Declare Function PeekMessage Lib "user32" Alias "PeekMessageA" (lpMsg As Msg, ByVal hWnd As Long, ByVal wMsgFilterMin As Long, ByVal wMsgFilterMax As Long, ByVal wRemoveMsg As Long) As Long
Private Type POINTAPI
    x As Long
    y As Long
End Type
Private Type Msg
    hWnd As Long
    Message As Long
    wParam As Long
    lParam As Long
    time As Long
    pt As POINTAPI
End Type
Private Const PM_NOREMOVE As Long = &H0
Private Const WM_POWER As Long = &H48
Private Const WM_POWERBROADCAST As Long = &H218

Private Sub Form_Activate()
Pm
End Sub

Sub Pm()
Dim Message As Msg
Do
WaitMessage
If PeekMessage(Message, Me.hWnd, WM_POWERBROADCAST, WM_POWERBROADCAST, PM_NOREMOVE) Then
Debug.Print "123"
End If
DoEvents
Loop
End Sub

Пробовал подставлять WM_POWER-тоже никак.
В чём ошибка?,другие мессаги читаються.
Может надо подписываться на получение этих сообщений? Или это надо только в Висте? :roll:

Nic.

Вернуться в Visual Basic 1–6

Кто сейчас на конференции

Сейчас этот форум просматривают: Yandex-бот и гости: 66

    TopList