vb 中有没有一个属性使一个FORM始终显示在最前呢? vb 中有没有一个属性使一个FORM始终显示在最前呢?就像REALPLAY的总在是最前显示 解决方案 » 免费领取超大流量手机卡,每月29元包185G流量+100分钟通话, 中国电信官方发货 没有这样的属性,可以使用api函数实现:'-------------------------------------------' 让一个窗体总是处于最前的例子'-------------------------------------------' 洪恩在线 求知无限'-------------------------------------------'程序说明:'本例应用SetWindowPos函数,设置窗体的显示属性'来实现让一个窗体总是处于其他窗体的前面而不会'被其他窗体所遮住。'-------------------------------------------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 LongConst HWND_TOPMOST = -1Const 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 可以用Timer控件,在其中每隔一段时间就设置窗体的Zorder 0,也可以使用SetWindowPos函数(API)来使用窗体置顶 报表打印问题 vba可以是使用adodb吗?可以的话怎么引入 关于SQL里DATETIME数据类型的问题 DB开发 怎么在SQL语句中使用日期值--急!在线等!.....即时给分! 请教:一个关于从数据库中取2进制图片信息的问题!!!!请进来看看再说 如何使用控件的DataSource属性 vb 如何通过网络访问没有共享出来的ACCESS文件!!! 怎么定义快捷键? 哪个有<< visal basic>>实用编程百例这本书的配套光盘里的源代码?清华大学出版社 vb open 文件出错 !!(急)
'-------------------------------------------
' 让一个窗体总是处于最前的例子
'-------------------------------------------
' 洪恩在线 求知无限
'-------------------------------------------
'程序说明:
'本例应用SetWindowPos函数,设置窗体的显示属性
'来实现让一个窗体总是处于其他窗体的前面而不会
'被其他窗体所遮住。
'-------------------------------------------
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 = &H40
Private 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