设为首页收藏本站Access中国

Office中国论坛/Access中国论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

12345下一页
返回列表 发新帖
查看: 5802|回复: 44
打印 上一主题 下一主题

[窗体] 这段代码为什么不能设定窗体的背景色为透明?怎么改才能达到目的呢?

[复制链接]
跳转到指定楼层
1#
发表于 2005-9-1 02:21:00 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
如何调用API来设定窗体的背景色为透明?以适应不同的用户桌面的颜色?

下面的代码为什么不能实现窗体的主体颜色为透明?

用VisualBasic制作半透明窗体





[quote]













函数SetLayeredWindowAttributes



  使用这个函数,可以轻松的实现半透明窗体。按照微软的要求,透明窗体窗体在创建时应使用WS_EX_LAYERED参数(用CreateWindowEx),或者在创建后设置该参数(用SetWindowLong),我选用后者。全部函数、常量声明如下:



Private Declare Function GetWindowLong Lib "user32" Alias "GetWindowLongA" (ByVal hwnd As Long, ByVal nIndex As Long) As Long



Private Declare Function SetWindowLong Lib "user32" Alias "SetWindowLongA" (ByVal hwnd As Long, ByVal nIndex As Long, ByVal dwNewLong As Long) As Long



Private Declare Function SetLayeredWindowAttributes Lib "user32" (ByVal hwnd As Long, ByVal crKey As Long, ByVal bAlpha As Byte, ByVal dwFlags As Long) As Long



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



Private Const WS_EX_LAYERED = &H80000



Private Const GWL_EXSTYLE = (-20)



Private Const LWA_ALPHA = &H2



Private Const LWA_COLORKEY = &H1



代码一:一个半透明窗体



Private Sub Form_Load()



  Dim rtn As Long



  rtn = GetWindowLong(hwnd, GWL_EXSTYLE)



  rtn = rtn Or WS_EX_LAYERED



  SetWindowLong hwnd, GWL_EXSTYLE, rtn



  SetLayeredWindowAttributes hwnd, 0, 200, LWA_ALPHA



End Sub





代码二:形状不规则的窗体



Private Sub Form_Load()



  Dim rtn As Long



  BorderStyler=0



  rtn = GetWindowLong(hwnd, GWL_EXSTYLE)



  rtn = rtn Or WS_EX_LAYERED



  SetWindowLong hwnd, GWL_EXSTYLE, rtn



  SetLayeredWindowAttributes hwnd, &HFF0000, 0, LWA_COLORKEY ’将扣去窗口中的蓝色



End Sub


[/quote]

这个感觉也是不行

[quote][quote]

Option Explicit

Private Declare Function SetWindowLong Lib "user32" Alias "SetWindowLongA" (ByVal hwnd As Long, ByVal nIndex As Long, ByVal dwNewLong As Long) As Long

'hwnd -----------  Long,欲为其取得信息的窗口的句柄

'nIndex ---------  Long,请参考GetWindowLong函数的nIndex参数的说明

'dwNewLong ------  Long,由nIndex指定的窗口信息的新值

Private Declare Function GetWindowLong Lib "user32" Alias "GetWindowLongA" (ByVal hwnd As Long, ByVal nIndex As Long) As Long

  'hwnd -----------  Long,欲为其获取信息的窗口的句柄

  'nIndex ---------  Long,欲取回的信息,可以是下述任何一个常数:

  'GWL_EXSTYLE

  '扩展窗口样式

  'GWL_STYLE

  '窗口样式

  'GWL_WNDPROC

  '该窗口的窗口函数的地址

  'GWL_HINSTANCE

  '拥有窗口的实例的句柄

  'GWL_HWNDPARENT

  '该窗口之父的句柄?不要用SetWindowWord来改变这个值

  'GWL_ID

  '对话框中一个子窗口的标识符

  'GWL_USERDATA

  '含义由应用程序规定

  'DWL_DLGPROC

  '这个窗口的对话框函数地址

  'DWL_MSGRESULT

  '在对话框函数中处理的一条消息返回的值

  'DWL_USER

  '含义由应用程序规定

  

Private Declare Function SetLayeredWindowAttributes Lib "user32" (ByVal hwnd As Long, ByVal crKey As Long, ByVal bAlpha As Byte, ByVal dwFlags As Long) As Long

'hwnd --透明窗体的句柄

'crKey --为颜色值

'bAlpha  -- 透明度,取值范围是[0,255]

'dwFlags -- 透明方式,可以取两个值:当取值为LWA_ALPHA时,crKey参数无效,

'bAlpha参数有效;当取值为LWA_COLORKEY时,bAlpha参数有效而窗体中的所有颜色为crKey的地方将变为透明

Const WS_EX_LAYERED = &H80000

Const GWL_EXSTYLE = (-20) '窗体扩展式样

Const LWA_COLORKEY = &H1  '关键颜色(异形窗体)

Const LWA_ALPHA = &H2   '透明度

Const LWA_COLORKEY_ALPHA = &H3 '透明 + 异形

Private Sub Form_Load()

    Dim NewStyle As Long '窗体的新式样

    Dim WinStyle As Long '记录窗体原来的式样

    WinStyle = GetWindowLong(Me.hwnd, GWL_EXSTYLE) '获得窗体的扩展式样

    Ne
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 分享淘帖 订阅订阅
2#
发表于 2005-9-1 03:12:00 | 只看该作者
以下是引用secowu在2005-8-31 18:21:00的发言:

如何调用API来设定窗体的背景色为透明?以适应不同的用户桌面的颜色?

Access的窗体很难做到,除非用UserForm,因为Access的窗体里面有个“主体”垫底,就算窗体透明了也没用。
3#
 楼主| 发表于 2005-9-1 16:57:00 | 只看该作者
好的,谢谢,正在试用“用户窗体”
4#
 楼主| 发表于 2005-9-1 17:19:00 | 只看该作者
问题来了:     1. 如何让MBD在启动时直接加载这个用户窗体?     2. 如何取消那个关闭按钮?(就是不让用户关闭一直加载该窗体目的是为了显示跳动的时间等项)     3. 如何让LABEL里的时间一秒一秒的跳动?     4. 好像用户窗体里没有那个TIMER事件
5#
 楼主| 发表于 2005-9-7 00:33:00 | 只看该作者
LucasLynn:   这个API你是最在行的了。。。。    有什么高招吗?
6#
发表于 2005-9-7 00:36:00 | 只看该作者
以下是引用secowu在2005-9-1 9:19:00的发言:



问题来了:

     1. 如何让MBD在启动时直接加载这个用户窗体?

     2. 如何取消那个关闭按钮?(就是不让用户关闭一直加载该窗体目的是为了显示跳动的时间等项)

     3. 如何让LABEL里的时间一秒一秒的跳动?

     4. 好像用户窗体里没有那个TIMER事件



1、Access启动会自动运行一个名为AutoExec的宏,你把窗体显示做进这个宏就可以。

2、这个要用API,具体的调用方法你查一下API手册。

3、用户窗体也可以使用定时器,附加控件就可以。
7#
 楼主| 发表于 2005-9-7 00:47:00 | 只看该作者
如果不用ACCESS的用户窗体,那么如何设置窗体的主体颜色为透明呢?听说牧人在API是最在行的了。。。。期待中。。。。
8#
发表于 2005-9-7 00:59:00 | 只看该作者
以下是引用secowu在2005-9-6 16:47:00的发言:

如果不用ACCESS的用户窗体,

那么如何设置窗体的主体颜色为透明呢?

听说牧人在API是最在行的了。。。。

期待中。。。。

少戴高帽子,API我用的时间比Access还短,你又听谁说我很在行了。知道的自然尽量帮你,不知道或者要花太多精力去查资料的,那我也帮不上了。

主体透明——做不到,至少我做不到。



用户窗体背景设置透明是可行的,两种方法,一种找VB窗体透明的源码,搜索引擎里面能找到,这个不需要代劳吧,另外一个办法,下载FoxAPI这个软件,是个VB API的声明库,如果不清楚要用哪个API,下一个chm格式的《新编Win32 API大全》,里面有API分类介绍。

[此贴子已经被作者于2005-9-6 17:46:06编辑过]

9#
 楼主| 发表于 2005-9-7 19:34:00 | 只看该作者
谢谢
10#
 楼主| 发表于 2005-10-19 00:16:00 | 只看该作者
用VisualBasic制作半透明窗体
函数SetLayeredWindowAttributes



  使用这个函数,可以轻松的实现半透明窗体。按照微软的要求,透明窗体窗体在创建时应使用WS_EX_LAYERED参数(用CreateWindowEx),或者在创建后设置该参数(用SetWindowLong),我选用后者。全部函数、常量声明如下:



Private Declare Function GetWindowLong Lib "user32" Alias "GetWindowLongA" (ByVal hwnd As Long, ByVal nIndex As Long) As Long



Private Declare Function SetWindowLong Lib "user32" Alias "SetWindowLongA" (ByVal hwnd As Long, ByVal nIndex As Long, ByVal dwNewLong As Long) As Long



Private Declare Function SetLayeredWindowAttributes Lib "user32" (ByVal hwnd As Long, ByVal crKey As Long, ByVal bAlpha As Byte, ByVal dwFlags As Long) As Long



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



Private Const WS_EX_LAYERED = &H80000



Private Const GWL_EXSTYLE = (-20)



Private Const LWA_ALPHA = &H2



Private Const LWA_COLORKEY = &H1



代码一:一个半透明窗体



Private Sub Form_Load()



  Dim rtn As Long



  rtn = GetWindowLong(hwnd, GWL_EXSTYLE)



  rtn = rtn Or WS_EX_LAYERED



  SetWindowLong hwnd, GWL_EXSTYLE, rtn



  SetLayeredWindowAttributes hwnd, 0, 200, LWA_ALPHA



End Sub





代码二:形状不规则的窗体



Private Sub Form_Load()



  Dim rtn As Long



  BorderStyler=0



  rtn = GetWindowLong(hwnd, GWL_EXSTYLE)



  rtn = rtn Or WS_EX_LAYERED



  SetWindowLong hwnd, GWL_EXSTYLE, rtn



  SetLayeredWindowAttributes hwnd, &HFF0000, 0, LWA_COLORKEY ’将扣去窗口中的蓝色



End Sub
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2024-5-30 08:05 , Processed in 0.098033 second(s), 33 queries .

Powered by Discuz! X3.3

© 2001-2017 Comsenz Inc.

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