想用我的VB程序,向外部程序发送一个鼠标滚轮消息,来控制外部程序的一个窗口内容向下滚动发 WM_VSCROLL 消息,对于EDIT框之类的,好用,但对于我要控制的外部程序不好用 
发 WM_MOUSEWHEEL 消息,也没成功,WM_MOUSEWHEEL的参数,我在VB下没用明白
请教WM_MOUSEWHEEL在VB下的用法

解决方案 »

  1.   

    http://community.csdn.net/Expert/topic/4284/4284223.xml?temp=.5617639
      

  2.   

    谢谢关注!
    楼上的方法,对EDIT之类的有效,我想控制资源管理器的窗口滚动,就不灵了
      

  3.   

    SendMessage hwnd, WM_MOUSEWHEEL, a, b我想向下滚动一行,a,b应该付什么值 ?
      

  4.   

    SendMessage hwnd, WM_MOUSEWHEEL, a, b向下滚动一行,a,b应该付什么值 ?
      

  5.   

    英语不好,实在没看懂MSDN上的说明 , 帮帮忙   ~~~~~~~~~~~~
      

  6.   

    SB_PAGEUP, VScroll1.hwnda是指的消息类型,比如pageup,还是pagedown
    b指的是滚动条的hwnd
      

  7.   

    这是微软网站上说的,没看懂,哪位大侠,能帮做个VB的 例子 WM_MOUSEWHEEL Notification--------------------------------------------------------------------------------
    The WM_MOUSEWHEEL message is sent to the focus window when the mouse wheel is rotated. The DefWindowProc function propagates the message to the window's parent. There should be no internal forwarding of the message, since DefWindowProc propagates it up the parent chain until it finds a window that processes it.A window receives this message through its WindowProc function. 
    SyntaxWM_MOUSEWHEEL    WPARAM wParam
        LPARAM lParam;
        
    ParameterswParam
    The high-order word indicates the distance the wheel is rotated, expressed in multiples or divisions of WHEEL_DELTA, which is 120. A positive value indicates that the wheel was rotated forward, away from the user; a negative value indicates that the wheel was rotated backward, toward the user. The low-order word indicates whether various virtual keys are down. This parameter can be one or more of the following values. 
    MK_CONTROL
    The CTRL key is down.
    MK_LBUTTON
    The left mouse button is down.
    MK_MBUTTON
    The middle mouse button is down.
    MK_RBUTTON
    The right mouse button is down.
    MK_SHIFT
    The SHIFT key is down.
    MK_XBUTTON1
    Windows 2000/XP: The first X button is down.
    MK_XBUTTON2
    Windows 2000/XP: The second X button is down.
    lParam
    The low-order word specifies the x-coordinate of the pointer, relative to the upper-left corner of the screen. The high-order word specifies the y-coordinate of the pointer, relative to the upper-left corner of the screen. 
    Return ValueIf an application processes this message, it should return zero. 
    ResUse the following code to get the information in the wParam parameter: fwKeys = GET_KEYSTATE_WPARAM(wParam);
    zDelta = GET_WHEEL_DELTA_WPARAM(wParam);Use the following code to obtain the horizontal and vertical position:xPos = GET_X_LPARAM(lParam); 
    yPos = GET_Y_LPARAM(lParam); You can also use the MAKEPOINTS macro to convert the lParam parameter to a POINTS structure. The wheel rotation will be a multiple of WHEEL_DELTA, which is set at 120. This is the threshold for action to be taken, and one such action (for example, scrolling one increment) should occur for each delta.The delta was set to 120 to allow Microsoft or other vendors to build finer-resolution wheels in the future, including perhaps a freely-rotating wheel with no notches. The expectation is that such a device would send more messages per rotation, but with a smaller value in each message. To support this possibility, you should either add the incoming delta values until WHEEL_DELTA is reached (so for a delta-rotation you get the same response), or scroll partial lines in response to the more frequent messages. You could also choose your scroll granularity and accumulate deltas until it is reached.Windows 95, Windows NT 3.51: Support for the mouse wheel is provided through a separately-running module, MSWheel, that generates a MSH_MOUSEWHEEL message. The MSWheel module, which consists of MSWheel.exe and MSWheel.dll, is installed with the IntelliPoint software that is shipped with the IntelliMouse pointing device. In addition, MSH_MOUSEWHEEL is defined in the header file (ZMouse.h) that an application must use to implement support for the wheel via the MSWheel module. MSH_MOUSEWHEEL
    zDelta = (int) wParam; // wheel rotation 
    xPos = LOWORD(lParam); // horizontal position of pointer 
    yPos = HIWORD(lParam); // vertical position of pointer Note, there is no fwKeys for MSH_MOUSEWHEEL. Otherwise, the parameters are exactly the same as for WM_MOUSEWHEEL.It is up to the application to forward MSH_MOUSEWHEEL to any embedded objects or controls. The application is required to send the message to an active embedded OLE application. It is optional that the application sends it to a wheel-enabled control with focus. If the application does send the message to a control, it can check the return value to see if the message was processed. Controls are required to return a value of TRUE if they process the message. Notification RequirementsMinimum DLL Version None 
    Header Declared in Winuser.h, include Windows.h 
    Minimum operating systems Windows 98, Windows NT 4.0