| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1954 人关注过本帖
标题:[求助]点击窗体关闭钮如何实现弹出系统询问框?
只看楼主 加入收藏
jrs123
Rank: 2
等 级:论坛游民
威 望:1
帖 子:627
专家分:14
注 册:2006-9-5
结帖率:94.12%
收藏
 问题点数:0 回复次数:18 
[求助]点击窗体关闭钮如何实现弹出系统询问框?
下面是点击command1钮,则弹出系统询问的对话框,但如何实现点击窗体右上角关闭钮也会弹出这样的对话框?
Private Sub Command1_Click()
Dim Ltem As Long
Dim LpID As Long
Dim hLong As Long
Dim strWinName As String
strWinName = "olp"
hLong = FindWindow(vbNullString, strWinName)
If hLong Then
GetWindowThreadProcessId hLong, LpID
Ltem = OpenProcess(PROCESS_TERMINATE, False, LpID)
TerminateProcess Ltem, 0
hLong = 0
End If
If MsgBox("你确实要退出吗?", vbYesNo + vbExclamation, "系统询问") = vbYes Then
Unload Me
End
Else
Cancel = True
End If
End Sub
搜索更多相关主题的帖子: 窗体 系统 询问 
2007-02-17 12:52
121038
Rank: 1
等 级:新手上路
威 望:2
帖 子:414
专家分:0
注 册:2005-8-3
收藏
得分:0 
Private Sub Form_Unload(Cancel As Integer)
Cancel = True
Call Command1_Click
End Sub

2007-02-17 12:54
jrs123
Rank: 2
等 级:论坛游民
威 望:1
帖 子:627
专家分:14
注 册:2006-9-5
收藏
得分:0 

谢谢楼上朋友,点关闭钮可以实现要求,但出了一个意外;即点Command1弹出对话框后,要点两次"是",窗体才能关闭,不知何故,请指教.

2007-02-17 14:22
jrs123
Rank: 2
等 级:论坛游民
威 望:1
帖 子:627
专家分:14
注 册:2006-9-5
收藏
得分:0 
上面的原代码还有一个问题是:当点按钮“Command1”时,悬浮窗体就提前关闭了,就是说还未弹出“是”和“否”的对话框它就关闭了。
采用二楼代码后,点击窗体关闭钮,悬浮窗体同样会提前关闭.但与上面不同的是,只要按一下"是",就退出窗体了.
而点Command1后,变成了要点二次"是"才能关闭主窗体.(原来未采用点击窗体关闭钮时只要点一次就关闭窗体了)不知问题出在哪里?

[此贴子已经被作者于2007-2-17 15:01:11编辑过]

2007-02-17 14:47
121038
Rank: 1
等 级:新手上路
威 望:2
帖 子:414
专家分:0
注 册:2005-8-3
收藏
得分:0 
把代码传上来,否则不知道你哪有问题,这个代码单独用是没问题的

2007-02-17 15:07
jrs123
Rank: 2
等 级:论坛游民
威 望:1
帖 子:627
专家分:14
注 册:2006-9-5
收藏
得分:0 

今天是大年初一,大家新年好!祝大家新春愉快,万事如意!
谢谢各位帮助本人解决这跨年度的问题,
按理,上面的问题在单工程内是已经解决了,但该问题是出在引用了exe窗体而出现的,所以与常规有不同的地方,现在将原代码发上,请高手帮助解决.

4V9BQCA8.rar (229.16 KB) [求助]点击窗体关闭钮如何实现弹出系统询问框?


2007-02-18 11:14
jrs123
Rank: 2
等 级:论坛游民
威 望:1
帖 子:627
专家分:14
注 册:2006-9-5
收藏
得分:0 
下面代码能实现不提前关闭悬浮窗体,但点击Commind1关闭窗体时,需要点二次"是"才能关闭,问题出在何处?如何改?
Private Sub Command1_Click()
Dim Ltem As Long
Dim LpID As Long
Dim hLong As Long
Dim strWinName As String
strWinName = "olp"
hLong = FindWindow(vbNullString, strWinName)
If hLong Then
GetWindowThreadProcessId hLong, LpID
Ltem = OpenProcess(PROCESS_TERMINATE, False, LpID)
hLong = 0
End If
If MsgBox("你确实要退出吗?", vbYesNo + vbExclamation, "系统询问") = vbYes Then
TerminateProcess Ltem, 0
Unload Me
End
Else
Cancel = True
End If
End Sub
2007-02-20 22:44
ioriliao
Rank: 7Rank: 7Rank: 7
来 自:广东
等 级:贵宾
威 望:32
帖 子:2829
专家分:647
注 册:2006-11-30
收藏
得分:0 

Z4D5fqGb.rar (233.53 KB)

[此贴子已经被作者于2007-2-21 10:02:38编辑过]



FQ265o10.rar (229.54 KB) [求助]点击窗体关闭钮如何实现弹出系统询问框?


/images/2011/147787/2011051411021524.jpg" border="0" />
2007-02-21 09:57
jrs123
Rank: 2
等 级:论坛游民
威 望:1
帖 子:627
专家分:14
注 册:2006-9-5
收藏
得分:0 

谢谢楼上版主的帮助,改后的代码放到程序中,出现了一些问题,就是会在转页时,跳出多余的窗体,现传上附件,请更正为盼!

BL79ZExD.rar (66.62 KB) [求助]点击窗体关闭钮如何实现弹出系统询问框?


2007-02-24 15:07
PcrazyC
Rank: 6Rank: 6
等 级:贵宾
威 望:29
帖 子:5652
专家分:0
注 册:2006-10-20
收藏
得分:0 
Private Sub Form_QueryUnload(Cancel As Integer, UnloadMode As Integer)
If MsgBox("您真的要退出吗?", vbYesNo + vbQuestion, "系统提示") = vbYes Then
End
Else
Cancel = 1
End If
End Sub

这个不就够了

雁无留踪之意,水无取影之心
2007-02-24 18:02
快速回复:[求助]点击窗体关闭钮如何实现弹出系统询问框?
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.017369 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved