Option Explicit
Private Declare Function SetWindowPos Lib "user32" _
    (ByVal hwnd As Long, ByVal hWndInsertAfter As Long, _
    ByVal x As Long, ByVal y As Long, ByVal cx As Long, _
    ByVal cy As Long, ByVal wFlags As Long) As Long '用于把窗体置于顶层Private Sub MDIForm_Load()
    SetWindowPos Me.hwnd, -1, Me.Left / Screen.TwipsPerPixelX, Me.Top \ Screen.TwipsPerPixelY, Me.Width \ Screen.TwipsPerPixelX, Me.Height \ Screen.TwipsPerPixelY, 0End Sub

解决方案 »

  1.   

    VB调用API函数使窗口保持在最上层 
    ---- 我们看到有的应用程序不管窗口是否活动都使窗口保持在最上层,常见的Microsoft Word的文件打开和编辑查找窗口就是这样。在VB开发中可以通过调用SetWindowsPos()API函数实现这个功能。该函数声明如下: Private Declare Function SetWindowPos
    Lib "user32" (ByVal hwnd As Long, _
    ByVal hWndInsertAfter As Long, ByVal
    x As Long, ByVal y As Long, _
    ByVal cx As Long, ByVal cy As Long, 
    ByVal wFlags As Long) As Long---- hWnd变元是窗口的句柄;x,y是窗口的左上角的坐标;cx、cy是窗口宽度和高度;hWndInsertAfter变元是窗口清单中hWnd窗口前面的窗口句柄,有四个可选值: 序号 可 选 值 作 用
    1 HWND_BOTTOM 把窗口放在窗口清单的底部
    2 HWND_TOP 把窗口放在窗口清单的字符顺序的顶部
    3 HWND_TOPMOST 把窗口放在窗口清单的顶部
    4 HWND_NOTOPMOST 把窗口放在窗口清单的顶部,最上层窗口之下---- WFlags变元为整型值,有八个可选值: 序号 可 选 值 作用
    1 SWP_DRAWFRAME 在窗口周围画一个方框
    2 SWP_HIDEWINDOW 隐藏窗口
    3 SWP_NOACTIVATE 不激活窗口
    4 SWP_NOMOVE 保持窗口当前位置
    5 SWP_NOREDRAW 窗口不自动重画
    6 SWP_NOSIZE 保持窗口当前尺寸
    7 SWP_NOZORDER 保持窗口在窗口清单中的当前位置
    8 SWP_SHOWWINDOW 显示窗口---- 下面的例子程序Test演示了对函数中的以上7个变元作正确的选择后,应用程序运行后窗口总可保持在最上层,程序清单如下: Option Explicit
    Private Declare Function SetWindowPos
    Lib "user32" (ByVal hwnd As Long, _
    ByVal hWndInsertAfter As Long,
    ByVal x As Long, ByVal y As Long, _
    ByVal cx As Long, ByVal cy As Long,
    ByVal wFlags As Long) As Long
    Private Const HWND_TOPMOST = -1
    Private Const SWP_SHOWWINDOWS = &H40Private Sub Form_Load()
    Dim retValue As Long
    retValue = SetWindowPos(Me.hwnd,
    HWND_TOPMOST, Me.CurrentX, _
    Me.CurrentY, 300, 300, SWP_SHOWWINDOWS)
    End Sub---- 备注:编写函数声明时,整个函数声明须在一行中写完,不可提行。一般是自动从系统中得到函数声明,方法是从VB的外接程序管理中启动“API 浏览”程序,在“API 浏览”程序中找到所需的函数声明,然后复制到VB代码中。  
    VB调用API函数使窗口保持在最上层 
    ---- 我们看到有的应用程序不管窗口是否活动都使窗口保持在最上层,常见的Microsoft Word的文件打开和编辑查找窗口就是这样。在VB开发中可以通过调用SetWindowsPos()API函数实现这个功能。该函数声明如下: Private Declare Function SetWindowPos
    Lib "user32" (ByVal hwnd As Long, _
    ByVal hWndInsertAfter As Long, ByVal
    x As Long, ByVal y As Long, _
    ByVal cx As Long, ByVal cy As Long, 
    ByVal wFlags As Long) As Long---- hWnd变元是窗口的句柄;x,y是窗口的左上角的坐标;cx、cy是窗口宽度和高度;hWndInsertAfter变元是窗口清单中hWnd窗口前面的窗口句柄,有四个可选值: 序号 可 选 值 作 用
    1 HWND_BOTTOM 把窗口放在窗口清单的底部
    2 HWND_TOP 把窗口放在窗口清单的字符顺序的顶部
    3 HWND_TOPMOST 把窗口放在窗口清单的顶部
    4 HWND_NOTOPMOST 把窗口放在窗口清单的顶部,最上层窗口之下---- WFlags变元为整型值,有八个可选值: 序号 可 选 值 作用
    1 SWP_DRAWFRAME 在窗口周围画一个方框
    2 SWP_HIDEWINDOW 隐藏窗口
    3 SWP_NOACTIVATE 不激活窗口
    4 SWP_NOMOVE 保持窗口当前位置
    5 SWP_NOREDRAW 窗口不自动重画
    6 SWP_NOSIZE 保持窗口当前尺寸
    7 SWP_NOZORDER 保持窗口在窗口清单中的当前位置
    8 SWP_SHOWWINDOW 显示窗口---- 下面的例子程序Test演示了对函数中的以上7个变元作正确的选择后,应用程序运行后窗口总可保持在最上层,程序清单如下: Option Explicit
    Private Declare Function SetWindowPos
    Lib "user32" (ByVal hwnd As Long, _
    ByVal hWndInsertAfter As Long,
    ByVal x As Long, ByVal y As Long, _
    ByVal cx As Long, ByVal cy As Long,
    ByVal wFlags As Long) As Long
    Private Const HWND_TOPMOST = -1
    Private Const SWP_SHOWWINDOWS = &H40Private Sub Form_Load()
    Dim retValue As Long
    retValue = SetWindowPos(Me.hwnd,
    HWND_TOPMOST, Me.CurrentX, _
    Me.CurrentY, 300, 300, SWP_SHOWWINDOWS)
    End Sub---- 备注:编写函数声明时,整个函数声明须在一行中写完,不可提行。一般是自动从系统中得到函数声明,方法是从VB的外接程序管理中启动“API 浏览”程序,在“API 浏览”程序中找到所需的函数声明,然后复制到VB代码中。  
      

  2.   

    好象不太管用似的,怎样让两个MDI子窗口同时打开的状态下,前一个为置顶状态,急需急需,回答问题后将另起贴赠五十分。
      

  3.   

    你把这些代码拷贝到子窗体中,看看可否。
    以前用在一个单独的窗体中,屡试不爽。
    ^_^
    Option Explicit'【VB声明】
    '  Private Declare Function SetWindowPos Lib "user32" (ByVal hwnd As Long, ByVal hWndInsertAfter As Long, ByVal x As Long, ByVal y As Long, ByVal cx As Long, ByVal cy As Long, ByVal wFlags As Long) As Long'【说明】
    '  这个函数能为窗口指定一个新位置和状态。它也可改变窗口在内部窗口列表中的位置。该函数与DeferWindowPos函数相似,只是它的作用是立即表现出来的(在vb里使用:针对vb窗体,如它们在win32下屏蔽或最小化,则需重设最顶部状态。如有必要,请用一个子类处理模块来重设最顶部状态'【返回值】
    '  Long,非零表示成功,零表示失败。会设置GetLastError'【备注】
    '  窗口成为最顶级窗口后,它下属的所有窗口也会进入最顶级。一旦将其设为非最顶级,则它的所有下属和物主窗口也会转为非最顶级。Z序列用垂直于屏幕的一根假想Z轴量化这种从顶部到底部排列的窗口顺序'【参数表】
    '  hwnd -----------  Long,欲定位的窗口'  hWndInsertAfter -  Long,窗口句柄。在窗口列表中,窗口hwnd会置于这个窗口句柄的后面。也可能选用下述值之一:
    '  HWND_BOTTOM        将窗口置于窗口列表底部
    '  HWND_TOP           将窗口置于Z序列的顶部;Z序列代表在分级结构中,窗口针对一个给定级别的窗口显示的顺序
    '  HWND_TOPMOST       将窗口置于列表顶部,并位于任何最顶部窗口的前面    -1
    '  HWND_NOTOPMOST     将窗口置于列表顶部,并位于任何最顶部窗口的后面    -2'  x --------------  Long,窗口新的x坐标。如hwnd是一个子窗口,则x用父窗口的客户区坐标表示'  y --------------  Long,窗口新的y坐标。如hwnd是一个子窗口,则y用父窗口的客户区坐标表示'  cx -------------  Long,指定新的窗口宽度'  cy -------------  Long,指定新的窗口高度'  wFlags ---------  Long,包含了旗标的一个整数,是下列之一:
    '  SWP_DRAWFRAME      围绕窗口画一个框
    '  SWP_HIDEWINDOW     隐藏窗口
    '  SWP_NOACTIVATE     不激活窗口                        &H10
    '  SWP_NOMOVE         保持当前位置 (x和y设定将被忽略)    &H2
    '  SWP_NOREDRAW       窗口不自动重画
    '  SWP_NOSIZE         保持当前大小 (cx和cy会被忽略)      &H1
    '  SWP_NOZORDER       保持窗口在列表的当前位置 (hWndInsertAfter将被忽略)
    '  SWP_SHOWWINDOW     显示窗口                          &H40
    '  SWP_FRAMECHANGED   强迫一条WM_NCCALCSIZE消息进入窗口,即使窗口的大小没有改变
    Private Declare Function SetWindowPos Lib "user32" ( _
    ByVal hwnd As Long, _
    ByVal hWndInsertAfter As Long, _
    ByVal x As Long, ByVal y As Long, _
    ByVal cx As Long, ByVal cy As Long, _
    ByVal wFlags As Long _
                                                    ) As Long
    Const HWND_TOPMOST = -1
    Const SWP_SHOWWINDOW = &H40Private Sub Form_load()
    Dim retValue As Long
    '将窗体设置为处于所有窗口的顶层,注意在 VB 中运行时,可能不行,但编译成EXE后就可以了
    retValue = SetWindowPos(Me.hwnd, HWND_TOPMOST, Me.CurrentX, Me.CurrentY, 300, 300, SWP_SHOWWINDOW)
    End Sub
      

  4.   

    MDI窗口置顶用我的办法,如果是Mid子窗口置顶:
    http://www.csdn.net/Expert/topicview.asp?id=580527
      

  5.   

    在MDI下如果两个子窗口同时打开的时候,我希望最后打开的被置顶,代码是顶好使的。
      

  6.   

    http://www.csdn.net/Expert/topicview.asp?id=580527
    回复人: enmity(灵感之源) (  ) 信誉:100  2002-3-16 20:58:48  得分:30  
     
     
      到http://caotang.myetang.com/temp/mdichildontop.zip下载一个例子,给你满意的答复。