/ Forside / Teknologi / Udvikling / VB/Basic / Nyhedsindlæg
Login
Glemt dit kodeord?
Brugernavn

Kodeord


Reklame
Top 10 brugere
VB/Basic
#NavnPoint
berpox 2425
pete 1435
CADmageren 1251
gibson 1230
Phylock 887
gandalf 836
AntonV 790
strarup 750
Benjamin... 700
10  tom.kise 610
Scroll hjul
Fra : David Holm


Dato : 30-08-01 13:37

Er der nogen der kender en god metode til at detektere om der scrolles med
hjulet... Jeg har fundet en masse der kan se om der scrolles, men ikke nogen
med hvilken retning...

mvh

David



 
 
Bjarke Walling Peter~ (30-08-2001)
Kommentar
Fra : Bjarke Walling Peter~


Dato : 30-08-01 16:54

David Holm skrev:
> Er der nogen der kender en god metode til at detektere om der scrolles med
> hjulet... Jeg har fundet en masse der kan se om der scrolles, men ikke
nogen
> med hvilken retning...

Har du prøvet følgende (jeg ved ikke om det virker, men du kan jo prøve
det):
Skriv dette i et modul:

Public Declare Function CallNextHookEx& Lib "user32" (ByVal _
hHook As Long, ByVal nCode As Long, ByVal wParam _
As Integer, lParam As Any)

Public Declare Function GetCurrentThreadId Lib "kernel32" () As Long

Public Declare Function RegisterWindowMessage& Lib "user32" _
Alias "RegisterWindowMessageA" (ByVal lpString As String)

Public Declare Function SetWindowsHookEx& Lib "user32" Alias _
"SetWindowsHookExA" (ByVal idHook As Long, ByVal lpfn _
As Long, ByVal hmod As Long, ByVal dwThreadId As Long)

Public Declare Function UnhookWindowsHookEx& Lib "user32" _
(ByVal hHook As Long)

Public Type POINTAPI
X As Long
Y As Long
End Type

Public Type MSG
hwnd As Long
message As Long
wParam As Long
lParam As Long
time As Long
pt As POINTAPI
End Type

Public Const WH_GETMESSAGE = 3
Public Const MSH_MOUSEWHEEL = "MSWHEEL_ROLLMSG"

Public IMWHEEL_MSG As Long
Public HWND_HOOK As Long

Public Sub WheelMoved(ByVal delta As Long, _
X As Long, Y As Long)
Form1.Caption = "Delta: " & CStr(delta) & " - Pos: " & CStr(X) & ", " &
CStr(Y)
End Sub

Public Function IMWheel(ByVal nCode As Long, ByVal _
wParam As Long, lParam As MSG) As Long
If lParam.message = IMWHEEL_MSG Then
WheelMoved lParam.wParam, lParam.pt.X, lParam.pt.Y
End If
IMWheel = CallNextHookEx(HWND_HOOK, nCode, wParam, lParam)
End Function

Public Function IMWheel_Hook() As Long
IMWHEEL_MSG = RegisterWindowMessage(MSH_MOUSEWHEEL)
HWND_HOOK = SetWindowsHookEx(WH_GETMESSAGE, _
AddressOf IMWheel, 0, GetCurrentThreadId)
End Function

Public Sub IMWheel_Unhook()
UnhookWindowsHookEx HWND_HOOK
End Sub

.... og dette i Form1's kode:

Private Sub Form_Load()
IMWheel_Hook
End Sub

Private Sub Form_Unload(Cancel As Integer)
IMWheel_Unhook
End Sub

.... og kør det! Og husk nu at bruge programmets luk-knap... hvis du bruger
stop-knappen i VB går det vist galt, fordi Unhook-rutinen da ikke bliver
kaldt!

- Bjarke Walling Petersen



David Holm (30-08-2001)
Kommentar
Fra : David Holm


Dato : 30-08-01 20:12

> Har du prøvet følgende (jeg ved ikke om det virker, men du kan jo prøve
> det):
Har jeg prøvet men det virkede desværre ikke... Jeg fandt derimod noget
andet kode der gjorde

mvh

David



Søg
Reklame
Statistik
Spørgsmål : 177501
Tips : 31968
Nyheder : 719565
Indlæg : 6408527
Brugere : 218887

Månedens bedste
Årets bedste
Sidste års bedste