版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、.VFP中仿MSN的右下角消息提示窗口(转) *!* VFP中仿MSN的右下角消息提示窗口*!* 作者:MEIZIBBSRichardWZP 2006.04.14*!* 调用方法:*!* PopWindows(cFrmCap,cFrmIco,nLayer,nWaitTime,cLblCap,cMess)*!* cFrmCap: C型,窗口的标题*!* cFrmIco: C型,窗口图标,若你程序中使用SET PATH设置了搜索路径,此处可以写相对路径*!* nLayer: N型,窗口透明度,最小值0(完全透明),最大值250(完全不透明)*!* nWaitTime: N型,等待时间。以毫秒为单位
2、,1秒=1000毫秒*!* cLblCap: C型,显示信息的标题*!* cMess: C型,要显示的信息*!* 适用VFP版本:VFP6、7、8、9*!* 适用WINDOWS版本98、2K、XP、2003SER*!* 调用示例:popWindows('提醒','E:gdm_accessPRGICOmy computer.ico',200,2000,'提醒','欢迎使用'+CHR(13)+'小小设计')*!* 说明:*!* 1、这只是一个思路,你可以通过此思路创建自己的消息窗口,比如加入图片*!* 2、因为调用的顶
3、层表单,且设置了透明度,所以不会影响你的基本界面*!* 3、若不希望窗口自动消失,可设置“等待时间”为0;*!* 4、当然,当窗口的EDITBOX获得焦点时,也不会自动消失的(单击表单后消失)*!* 5、编译为EXE为200K,占用内存300K以下(我用DELPHI编译后50K,占用内存30K,为何如此差距?)FUNCTION popWindowsLPARAMETERS pcCaption,pcIco,pnLayer,pnWaitTim,pcMesCap,pcMes,plMaxButt,plMinButtPUBLIC oFrmPopWindowoFrmPopWindow=NEWOBJECT(&
4、quot;FrmPopWindow")lcStuBar=SET("Status Bar")&&狐友xs160提供界面问题的解决办法SET STATUS BAR ONoFrmPopWindow.ShowSET STATUS BAR &lcStuBar.RETURNDEFINE CLASS FrmPopWindow AS form DataSession = 2AlwaysOnTop=.T.&&若编译为EXE或APP使用,此属性不用设置,TIMER里有设定,效果会更好(从WINDOWS任务栏后面开始上升)AllowOutput
5、= .F.ShowInTaskbar=.F. Height = 132 Width = 277 BackColor = RGB(255,255,255) BorderStyle = 2 Caption = pcCaption Icon = pcIco MaxButton = plMaxButt MinButton = plMinButt ShowWindow = 2 Visible = .F. Name = "FrmPopWindow" Layerdd= pnLayer MesCap = pcMesCap Mes = pcMes PROCEDURE Load this.Le
6、ft = SYSMETRIC(21) - this.Width - SYSMETRIC(3) * 2 this.Top = SYSMETRIC(22) this.AddProperty('FormHeight',this.Height) this.AddProperty('FormWidth',this.Width) this.AddProperty('FormActive',.T.) ENDPROC PROCEDURE Click this.formactive = .T. ENDPROC PROCEDURE Init THIS.MY_setw
7、indow(this.layerdd) this.lblCaption.caption = this.MesCap this.Edit1.value = this.Mes ENDPROC PROCEDURE My_SetWindow LPARAMETERS pnLayer DECLARE INTEGER SetLayeredWindowAttributes IN win32api INTEGER HWND, INTEGER crKey, INTEGER bAlpha, INTEGER dwFlags DECLARE INTEGER SetWindowLong IN user32.DLL INT
8、EGER hWnd, INTEGER nIndex, INTEGER dwNewLong DECLARE INTEGER GetWindowLong IN user32.DLL INTEGER hWnd, INTEGER nIndex #DEFINE LWA_COLORKEY 1 #DEFINE LWA_ALPHA 2 #DEFINE GWL_EXSTYLE -20 #DEFINE WS_EX_LAYERED 0x00080000 lnFlags = GetWindowLong(thisform.hwnd, GWL_EXSTYLE) lnFlags = BITOR(lnFlags, WS_EX
9、_LAYERED) SetWindowLong(thisform.HWnd , GWL_EXSTYLE, lnFlags) i=0 DO WHILE i<=254 j=i SetLayeredWindowAttributes(thisform.hwnd,RGB(255,255,255) , j, LWA_ALPHA) i = i +20 ENDDO SetLayeredWindowAttributes(thisform.hwnd,thisform.BackColor ,pnLayer, LWA_ALPHA) *!* *- 在任务栏中隐藏 *!* #DEFINE WS_EX_TOOLWIN
10、DOW 0x0000008 *!* lnFlags = GetWindowLong(thisform.hwnd, WS_EX_TOOLWINDOW) &&Gets the existing flags from the window *!* lnFlags = BITOR(lnFlags, WS_EX_TOOLWINDOW) &&Appends the Layered flag to the existing ones *!* SetWindowLong(thisform.HWnd , GWL_EXSTYLE, lnFlags) ENDPROC PROCEDUR
11、E DblClick thisform.Release ENDPROC PROCEDURE Unload thisform.Release ENDPROC ADD OBJECT lblCaption AS label WITH ; AutoSize = .T.,; BackStyle = 0,; Caption = '',; Height = 16,; Left = 6,; Top = 5,; Name = "lblCaption" ADD OBJECT Edit1 AS EditBox WITH ; Anchor = 15,; Height = 108,;
12、 Left = 0,; Name = 'Edit1',; Top = 24, ; Width = 277 PROCEDURE Edit1.MouseDown LPARAMETERS nButton, nShift, nXCoord, nYCoord thisform.FormActive = .F. ENDPROC PROCEDURE Edit1.LostFocus thisform.FormActive = .T. ENDPROC ADD OBJECT tmrShow AS Timer WITH ; Name = 'tmrShow',; Interval =
13、10 ADD OBJECT tmrWait AS Timer WITH ; Name = 'tmrWait',; Interval = pnWaitTim,; Enabled = .F. ADD OBJECT tmrHide AS Timer WITH ; Name = 'tmrHide',; Interval = 10,; Enabled = .F. PROCEDURE tmrShow.Timer IF SYSMETRIC(22)-thisform.Top = thisform.Height +SYSMETRIC(4) * 2 this.Enabled = .
14、F. thisform.tmrWait.Enabled = .T. thisform.AlwaysOnTop = .T. ELSE thisform.Top = thisform.Top - 1 ENDIF ENDPROC PROCEDURE tmrWait.Timer IF thisform.tmrHide.Enabled = .F. thisform.tmrHide.Enabled = .T. ENDIF ENDPROC PROCEDURE tmrHide.Timer IF thisform.FormActive IF thisform.Height<>thisform.Formheight OR thisform.Width<>thisform.Formwidth thisform.Height = thisf
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 二零二五年绿色生态建筑农民工劳动合同示范3篇
- 二零二五年度防盗门行业市场分析报告合同2篇
- 二零二五版加油站智能监控与数据分析合同3篇
- 二零二五白云区观白活力中心房地产合作开发投资框架合同2篇
- 二零二五年度智能家电产品研发与销售合同3篇
- 二零二五版养殖企业与个体养牛户合作合同3篇
- 二零二五版数据中心机房租赁及数据备份服务合同2篇
- 基于2025年度5G网络技术研发合作合同2篇
- 二零二五版拌和站产品质量追溯与售后服务合同2篇
- 二零二五版建筑工程土方中介合同纠纷调解机制3篇
- 物业费收取协议书模板
- 电工(中级工)理论知识练习题(附参考答案)
- 工业设计概论试题
- 2024-2030年中国商务服务行业市场现状调查及投资前景研判报告
- 起重机的维护保养要求与月度、年度检查记录表
- 消防设施维护保养记录表
- 城区生活垃圾填埋场封场项目 投标方案(技术方案)
- 垃圾分类巡检督导方案
- 大一护理生涯发展展示
- 五年级上册数学应用题100题及答案
- 新生儿急救与复苏培训
评论
0/150
提交评论