设为首页收藏本站Access中国

Office中国论坛/Access中国论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

返回列表 发新帖
查看: 739|回复: 2
打印 上一主题 下一主题

[Access本身] 请问设定窗体半透明一定要同时设有弹出方式为是才行吗?

[复制链接]

点击这里给我发消息

跳转到指定楼层
1#
发表于 2009-9-4 21:47:39 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
  1. '使用这个函数,可以轻松的实现半透明窗体。按照微软的要求,透明窗体窗体在创建时应使用WS_EX_LAYERED参数(用CreateWindowEx),或者在创建后设置该参数(用SetWindowLong),选用后者。全部函数、常量声明如下:

  2. Private Declare Function GetWindowLong Lib "user32" Alias "GetWindowLongA" (ByVal hwnd As Long, ByVal nIndex As Long) As Long
  3. Private Declare Function SetWindowLong Lib "user32" Alias "SetWindowLongA" (ByVal hwnd As Long, ByVal nIndex As Long, ByVal dwNewLong As Long) As Long
  4. Private Declare Function SetLayeredWindowAttributes Lib "user32" (ByVal hwnd As Long, ByVal crKey As Long, ByVal bAlpha As Byte, ByVal dwFlags As Long) As Long

  5. '其中hwnd是透明窗体的句柄,crKey为颜色值,bAlpha是透明度,取值范围是[0,255],dwFlags是透明方式,可以取两个值:当取值为LWA_ALPHA时,crKey参数无效,bAlpha参数有效;当取值为LWA_COLORKEY时,bAlpha参数有效而窗体中的所有颜色为crKey的地方将变为透明--这个功能很有用:我们不必再为建立不规则形状的窗体而调用一大堆区域分析、创建、合并函数了,只需指定透明处的颜色值即可.

  6. Private Const WS_EX_LAYERED = &H80000
  7. Private Const GWL_EXSTYLE = (-20)
  8. Private Const LWA_ALPHA = &H2
  9. Private Const LWA_COLORKEY = &H1

  10. '一个半透明窗体
  11. Private Sub Form_Load()
  12.   Dim rtn As Long
  13.   rtn = GetWindowLong(hwnd, GWL_EXSTYLE)
  14.   rtn = rtn Or WS_EX_LAYERED
  15.   SetWindowLong hwnd, GWL_EXSTYLE, rtn
  16.   SetLayeredWindowAttributes hwnd, 0, 200, LWA_ALPHA
  17. End Sub
复制代码
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 分享淘帖 订阅订阅

点击这里给我发消息

2#
 楼主| 发表于 2009-9-5 15:31:42 | 只看该作者
再顶顶,版主看看

点击这里给我发消息

3#
 楼主| 发表于 2009-9-6 13:02:07 | 只看该作者
再顶顶
您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|站长邮箱|小黑屋|手机版|Office中国/Access中国 ( 粤ICP备10043721号-1 )  

GMT+8, 2024-11-19 21:14 , Processed in 0.086891 second(s), 26 queries .

Powered by Discuz! X3.3

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表