怎样使VB窗口透明而控件不透明

fuyong1997 2010-03-02 01:23:56
我希望程序的窗口中除控件外其他部分都透明,请问这个怎样实现啊?
我试过用SetLayeredWindowAttributes 这个API函数使窗口透明,但是控件都看不见了。
或者我在窗口中用API函数画了个图,怎样使图画以外的部分都透明啊,即只显示图画部分。
知道的朋友帮帮忙,谢了。
...全文
185 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
oldjiang 2010-07-16
  • 打赏
  • 举报
回复
嘟嘟看看
fuyong1997 2010-03-02
  • 打赏
  • 举报
回复
谢谢了
刚试了下 好像可以
是不是SetLayeredWindowAttributes的第二个参数就是使和窗口的背景色相同的颜色变为透明
谢谢了。
of123 2010-03-02
  • 打赏
  • 举报
回复
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
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()
Me.BackColor = vbBlue
Dim rtn As Long
rtn = GetWindowLong(hwnd, GWL_EXSTYLE)
rtn = rtn Or WS_EX_LAYERED
SetWindowLong hwnd, GWL_EXSTYLE, rtn
SetLayeredWindowAttributes hwnd, vbBlue, 0, LWA_COLORKEY
End Sub

1,486

社区成员

发帖
与我相关
我的任务
社区描述
VB API
社区管理员
  • API
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧