制作透明及不规则窗体

 
  使用这个函数,可以轻松的实现半透明窗体。按照微软的要求,透明窗体窗体在创建时应使用
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是透明方式,可以取两个值:当取值狶WA_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

 

 

 

 

 

 

 

 

‘=================================================================================

用VB创建不规则窗口

迄今为止,我们用VB编制的程序窗口大都是标准的四方形,看上去很没有个性。如果你想让你的程序与众不同的话,可以利用以下几个API函数来创建不规则窗 口:
CreateRectRgn(ByVal X1 As Long, ByVal Y1 As Long, ByVal X2 As Long, ByVal Y2 As Long) '创建一个矩形区域,四个参数分别代表左、上、右、下的坐标;
CreateEllipticRgn(ByVal X1 As Long, ByVal Y1 As Long, ByVal X2 As Long, ByVal Y2 As Long) '创建一个椭圆形区域,参数同上;
CreatePolygonRgn(pPoint As POINTAPI, ByVal nCount As Long, ByVal nPolyFillMode As Long) '创建一个多边形区域,pPoint参数为一个POINTAPI型数组,nCount参数说明顶点数,nPolyFillMode参数为填充模式;
CombineRgn(ByVal hDestRgn As Long, ByVal hSrcRgn1 As Long, ByVal hSrcRgn2 As Long, ByVal nCombineMode As Long) '合并两个区域,hDestRgn是合并后的区域,hSrcRgn1和hSrcRgn2是欲合并的目标区域,nCombineMode为合并方式;
SetWindowRgn((ByVal hWnd As Long, ByVal hRgn As Long, ByVal bRedraw As Boolean) '设置窗体为指定样式,hRgn为上述几个函数创建的区域,bRedraw决定是否立即重画窗体。
有了这些“神兵利器”,我们就可以随心所欲地制作出各式各样的窗体。示范程序如下:
Private Declare Function CreateEllipticRgn Lib "gdi32" (ByVal X1 As Long, ByVal Y1 As Long, ByVal X2 As Long, ByVal Y2 As Long) As Long
Private Declare Function SetWindowRgn Lib "user32" (ByVal hWnd As Long, ByVal hRgn As Long, ByVal bRedraw As Boolean) As Long
Private Sun Form_load()
Dim x,y As Long
x=CreateEllipticRgn(0,0,100,200)
y=SetWindowRgn(Me.hwnd,x,True)
End Sub
以上程序可以创建一个椭圆形窗体,并在VB6.0,Win 98环境下调试通过。有兴趣的朋友可以参考以上的API函数以及示范程序编写其它几种不规则窗口。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值