




已阅读5页,还剩5页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
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型,等待时间。以毫秒为单位,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、若不希望窗口自动消失,可设置“等待时间”为0;*!* 4、当然,当窗口的EDITBOX获得焦点时,也不会自动消失的(单击表单后消失)*!* 5、编译为EXE为200K,占用内存300K以下(我用DELPHI编译后50K,占用内存30K,为何如此差距?)FUNCTION popWindowsLPARAMETERS pcCaption,pcIco,pnLayer,pnWaitTim,pcMesCap,pcMes,plMaxButt,plMinButtPUBLIC oFrmPopWindowoFrmPopWindow=NEWOBJECT(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 = .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.Left = 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_setwindow(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 INTEGER 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_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_TOOLWINDOW 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 PROCEDURE 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,; 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 = 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 = .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.Heightthisform.Formheight OR thisform.Widththisform.Formwidth thisform.Height = thisform.FormHe
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 出版工作发言稿
- 2013.1.13法律逻辑学试题及答案(经典)
- 林场护林员培训
- 夏季高温防暑培训
- 二零二五版建筑工程设计施工一体化转让合同
- 2025版节能建筑瓷砖供货与绿色生活推广合同
- 2025版离婚后共同财产分割子女抚养及财产分割协议
- 2025版文化艺术交流活动组织服务合同模板
- 二零二五版科技研发资源共享服务合同
- 二零二五年度电商跨境电商支付与清算培训合同
- 2025年云南省事业单位招聘考试综合类专业能力测试试卷(工程类)难点解析
- 2025年秋期人教版2年级上册数学核心素养教案(第6单元)(教学反思有内容+二次备课版)
- 2025内蒙古西部天然气蒙东管道有限公司招聘20人笔试参考题库附带答案详解(10套)
- 2025店铺租赁合同协议书下载
- 2025年国企财务招聘笔试题和答案(基础知识测试题)
- 9型人格培训课件
- 2025年银行安全保卫知识考试题库(含答案)
- 曲靖市商务局招聘公益性岗位人员考试真题2024
- 2025年青岛市中考英语试卷(含答案解析)
- 投资评价管理办法
- 达州水务集团有限公司员工招聘考试真题2024
评论
0/150
提交评论