求助:如何將窗體置于最前?

bodatec 2003-05-10 10:25:35
這個窗體不關閉,無法操作其它的窗體.要怎么實現呢?
...全文
20 点赞 收藏 5
写回复
5 条回复
切换为时间正序
当前发帖距今超过3年,不再开放新的回复
发表回复
lihonggen0 2003-05-10
让窗口一直在上面

  很多流行软件都有这样一个选项:always on top。它可以让窗口在最上面,别的窗口不能覆盖它。我们在 vb 中,可以使用下面的方法来实现:
private const swp_nosize = &h1
private const swp_nomove = &h2
private const swp_nozorder = &h4
private const swp_noredraw = &h8
private const swp_noactivate = &h10
private const swp_framechanged = &h20
private const swp_showwindow = &h40
private const swp_nocopybits = &h80
private const swp_noownerzorder = &h200
private const swp_drawframe = swp_framechanged
private const swp_noreposition = swp_noownerzorder
private const hwnd_top = 0
private const hwnd_bottom = 1
private const hwnd_topmost = -1
private const hwnd_notopmost = -2
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 mbontop as boolean
private property let ontop (setting as boolean)
if setting then
setwindowpos hwnd, -1, 0, 0, 0, 0, swp_nomove or swp_nosize
else
setwindowpos hwnd, -2, 0, 0, 0, 0, swp_nomove or swp_nosize
end if
mbontop = setting
end property
 
private property get ontop() as boolean
'return the private variable set in property let
ontop = mbontop
end property
调用 ontop=true 即可让窗口 always on top。



回复
lihonggen0 2003-05-10

怎样使我的程序总处于屏幕最前方?(Always on top)

 

如果你想让你的程序处于前方,可以使用以下代码:

 

Form1.ZOrder

 

配合计时器使用,每隔一段很小的时间间隔调用这种方法可以使窗体Form1处于屏幕前方,但是用户还是可能使别的窗体在短暂的时间里处于Form1的上方。所以这种方法并不能使窗体真正的实现Always on top,而要真正的Always on top可以使用API函数SetWindowPos,代码如下:

 

'声明函数:

Declare Function SetWindowPos Lib "user32" _

(ByVal h%, ByVal hb%, ByVal x%, ByVal y%, _

ByVal cx%,ByVal cy%,ByVal f%) As Integer

Global Const SWP_NOMOVE = 2

Global Const SWP_NOSIZE = 1

Global Const FLAGS = SWP_NOMOVE Or SWP_NOSIZE

Global Const HWND_TOPMOST = -1

Global Const HWND_NOTOPMOST = -2

'把窗体放在最前面:

 

res% = SetWindowPos (Form1.hWnd, HWND_TOPMOST, _

0, 0, 0, 0, FLAGS)

'如果res%=0, 就产生错误

 

'使窗体恢复普通模式:

res% = SetWindowPos (Form1.hWnd, HWND_NOTOPMOST, _

0, 0, 0, 0, FLAGS)




 


回复
Dickson 2003-05-10
SetWindowPos

VB声明
Declare Function SetWindowPos Lib "user32" Alias "SetWindowPos" (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
参数表
参数 类型及说明
hwnd Long,欲定位的窗口
hWndInsertAfter Long,窗口句柄。在窗口列表中,窗口hwnd会置于这个窗口句柄的后面。也可能选用下述值之一:
HWND_BOTTOM 将窗口置于窗口列表底部
HWND_TOP 将窗口置于Z序列的顶部;Z序列代表在分级结构中,窗口针对一个给定级别的窗口显示的顺序
HWND_TOPMOST 将窗口置于列表顶部,并位于任何最顶部窗口的前面
HWND_NOTOPMOST 将窗口置于列表顶部,并位于任何最顶部窗口的后面
x Long,窗口新的x坐标。如hwnd是一个子窗口,则x用父窗口的客户区坐标表示
y Long,窗口新的y坐标。如hwnd是一个子窗口,则y用父窗口的客户区坐标表示
cx Long,指定新的窗口宽度
cy Long,指定新的窗口高度
wFlags Long,包含了旗标的一个整数
SWP_DRAWFRAME 围绕窗口画一个框
SWP_HIDEWINDOW 隐藏窗口
SWP_NOACTIVATE 不激活窗口
SWP_NOMOVE 保持当前位置(x和y设定将被忽略)
SWP_NOREDRAW 窗口不自动重画
SWP_NOSIZE 保持当前大小(cx和cy会被忽略)
SWP_NOZORDER 保持窗口在列表的当前位置(hWndInsertAfter将被忽略)
SWP_SHOWWINDOW 显示窗口
SWP_FRAMECHANGED 强迫一条WM_NCCALCSIZE消息进入窗口,即使窗口的大小没有改变
注解
窗口成为最顶级窗口后,它下属的所有窗口也会进入最顶级。一旦将其设为非最顶级,则它的所有下属和物主窗口也会转为非最顶级。Z序列用垂直于屏幕的一根假想Z轴量化这种从顶部到底部排列的窗口顺序


2.强制禁止别的窗口得到焦点。


回复
饮水需思源 2003-05-10
form1.show 1
form1.zorder 0
回复
Intelement 2003-05-10
这是应用程序级的

Private Sub Command1_Click()
Dim frm As Form1
Set frm = New Form1
frm.Show vbModal ' Notice
End Sub

回复
相关推荐
基于java的企业人事管理系统设计--软件工程课程设计(含源码与论文设计).rar 1 引言 4 1.1 课程设计目标 4 1.2 编程工具(编程环境)介绍 4 1.3 实施时间及主要实施步骤 4 2 需求分析 5 3 系统总体设计 6 4 数据库设计 6 5 主要功能模块的设计与实现 10 5.1 功能模块1详细设计(综合查询员工信息)..........................................................10 5.1.1 详细设计.......................................................................................................10 5.1.2 算法流程........................................................................................................15 5.1.3 界面设计及测试结果.....................................................................................15 6 调试分析 15 7 用户手册 16 8 测试结果 17 8.1 员工信息的添加...................................................................................................17 8.2 员工信息的修改...................................................................................................17 8.3 员工信息的删除...................................................................................................18 8.4 员工信息的综合查询...........................................................................................18 8.5 员工信息按性别统计的结果................................................................................19 8.6 员工信息按状态统计的结果...............................................................................19 8.7 员工信息按职称统计的结果................................................................................20 9 结论 20 10 参考文献 20
发帖
VB基础类
创建于2007-09-28

7493

社区成员

VB 基础类
申请成为版主
帖子事件
创建了帖子
2003-05-10 10:25
社区公告
暂无公告