怎么让窗体透明,而窗体上的控件不透明????(100分)
窗体透明的功能我已经实现,代码如下: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 = &H1Private 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请问:怎么让窗体透明,而窗体上的控件不透明???

解决方案 »

  1.   

    自己UP!自己UP!自己UP!自己UP!自己UP!自己UP!自己UP!
      

  2.   

    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 SetWindowPos Lib "user32" (ByVal hwnd As Long, ByVal hWndInsertAfter As Long, ByVal x As Long, ByVal y As Long, ByVal cx As Long, ByVal cy As Long, ByVal wFlags As Long) As LongPrivate Const GWL_EXSTYLE = (-20)
    Private Const WS_EX_TRANSPARENT = &H20&
    Private Const SWP_FRAMECHANGED = &H20
    Private Const SWP_NOMOVE = &H2
    Private Const SWP_NOSIZE = &H1
    Private Const SWP_SHOWME = SWP_FRAMECHANGED Or SWP_NOMOVE Or SWP_NOSIZE
    Private Const HWND_NOTOPMOST = -2Private Sub Command1_Click()
    SetWindowLong Form1.hwnd, GWL_EXSTYLE, WS_EX_TRANSPARENT
    SetWindowPos Form1.hwnd, HWND_NOTOPMOST, 0&, 0&, 0&, 0&, SWP_SHOWME
    End Sub
      

  3.   

    自己再UP!自己再UP!自己再UP!自己再UP!自己再UP!自己再UP!
      

  4.   

    http://community.csdn.net/Expert/topic/4141/4141798.xml?temp=5.984133E-02
      

  5.   

    变通方法不知道可行否?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
        Text1.BackColor = vbRed
        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
        'SetLayeredWindowAttributes hwnd, 0, 200, LWA_ALPHA
    End Sub
      

  6.   

    你可以先用SetParent打散再用MoveWindow 移动^_^我也不太懂不知道有没有更好的跟随方法!
    如何对香香朋友有帮助就给点分吧!我没没分了!谢谢了
      

  7.   

    To: lxcc(Contour) 
    謝謝你的回復,對不起,我把標題寫錯了應該是:
    怎么让窗体 半 透明,而窗体上的控件不透明????
      

  8.   

    自己再UP!自己再UP!自己再UP!自己再UP!自己再UP!自己再UP!
      

  9.   

    你最好用.net很方便就做倒呢,java也可以。
    http://www.swl8.com
      

  10.   

    可以再建窗体来放控件,不然就必须用半透明的算法把窗体背景设掉。如果单用半透明的API肯定不行~
      

  11.   

    怎么让窗体  半  透明,而窗体上的控件 不 透明????
    自己再UP!自己再UP!自己再UP!自己再UP!自己再UP!自己再UP!沒有程序員解決不了的問題,只有解決不了問題的程序員!
      

  12.   

    非常感謝大家的幫助!!!
    其實、我只是想要一個VB畫面上的 VSFLEXGRID 的背景透明,而其他控件都不透明的效果!!!我現在實現的方法是:
    1.用一個畫面做VSFLEXGRID的背景
    2.用另一個半透明畫面做操作畫面、上面有一個 VSFLEXGRID 和其他控件、這是一個主要業務操作畫面。
    問題是:VSFLEXGRID 的背景是半透明了,但其他控件的背景也是半透明的了,這樣畫面的字顔色和輸入的字符的顔色都變淡了,有一種模糊,看不清的感覺。
      

  13.   

    2K可以用SetLayeredWindowAttributes,只要你窗体的颜色跟控件颜色不一样就可以了.或者用截取像素颜色创建区域然后合成区域的方法.第2个参数为FALSE就可以了.HDC用窗体的.
      

  14.   

    ***其實、我只是想要一個VB畫面上的 VSFLEXGRID 的背景透明,而其他控件都不透明的效果!!!你要怎么个透明法啊?
    VSFLEXGRID 的背景透到桌面还是窗体?