在VB中 有办法做一个透明窗体吗 上面只能看到控件的还有有菜单的窗体如何让它没标提呢? 我把窗体BorderStyle属性设为0 可是有了菜单他又有了标提拦了我的菜单是想做右建用的  菜单设为不可见

解决方案 »

  1.   

    1.通过api可以实现窗体透明
    2。你在其他窗体定义菜单,在没有标题的窗体中调用就可以了
      

  2.   

    透明
    Public Declare Function CreateCompatibleBitmap Lib "gdi32" Alias "CreateCompatibleBitmap" (ByVal hdc As Long, ByVal nWidth As Long, ByVal nHeight As Long) As Long Me.AutoRedraw = True
      hBitmap = CreateCompatibleBitmap(Me.hdc, 0, 0)
      SelectObject Me.hdc, hBitmap
      Me.Refresh
      

  3.   

    另外一种
    函数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 
      

  4.   

    没有做不到的,只有想不到的Private Declare Function GetWindowRect Lib "user32" (ByVal hWnd As _
            Long, lpRECT As RECT) As LongPrivate Declare Function GetClientRect Lib "user32" (ByVal hWnd As _
            Long, lpRECT As RECT) As LongPrivate Declare Function CombineRgn Lib "gdi32" (ByVal hDestRgn As _
            Long, ByVal hSrcRgn1 As Long, ByVal hSrcRgn2 As Long, ByVal _
            nCombineMode As Long) As LongPrivate Declare Function CreateRectRgn Lib "gdi32" (ByVal X1 As Long, _
            ByVal Y1 As Long, ByVal X2 As Long, ByVal Y2 As Long) As LongPrivate Declare Function ScreenToClient Lib "user32" (ByVal hWnd As _
            Long, lpPoint As POINTAPI) As LongPrivate Declare Function SetWindowRgn Lib "user32" (ByVal hWnd As _
            Long, ByVal hRgn As Long, ByVal bRedraw As Boolean) As LongConst RGN_AND = 1
    Const RGN_COPY = 5
    Const RGN_DIFF = 4
    Const RGN_OR = 2
    Const RGN_XOR = 3Private Type POINTAPI
        x As Long
        Y As Long
    End Type
    Private Type RECT
        Left As Long
        Top As Long
        Right As Long
        Bottom As Long
    End Type
    Sub DataSamp()
        Dim ad As Database
        Dim aserch As QueryDef
    End SubPublic Sub MakeTransparent(frm As Form)
        Dim rctClient As RECT, rctFrame As RECT
        Dim hClient As Long, hFrame As Long
        
        '获得窗口矩形区域
        GetWindowRect frm.hWnd, rctFrame
        GetClientRect frm.hWnd, rctClient
        
        '将窗口矩形坐标转换为屏幕坐标
        Dim lpTL As POINTAPI, lpBR As POINTAPI
        lpTL.x = rctFrame.Left
        lpTL.Y = rctFrame.Top
        lpBR.x = rctFrame.Right
        lpBR.Y = rctFrame.Bottom
        ScreenToClient frm.hWnd, lpTL
        ScreenToClient frm.hWnd, lpBR
        rctFrame.Left = lpTL.x
        rctFrame.Top = lpTL.Y
        rctFrame.Right = lpBR.x
        rctFrame.Bottom = lpBR.Y
        rctClient.Left = Abs(rctFrame.Left)
        rctClient.Top = Abs(rctFrame.Top)
        rctClient.Right = rctClient.Right + Abs(rctFrame.Left)
        rctClient.Bottom = rctClient.Bottom + Abs(rctFrame.Top)
        rctFrame.Right = rctFrame.Right + Abs(rctFrame.Left)
        rctFrame.Bottom = rctFrame.Bottom + Abs(rctFrame.Top)
        rctFrame.Top = 0
        rctFrame.Left = 0
        
        
        hClient = CreateRectRgn(rctClient.Left, rctClient.Top, rctClient.Right, rctClient.Bottom)
        hFrame = CreateRectRgn(rctFrame.Left, rctFrame.Top, rctFrame.Right, rctFrame.Bottom)
        
        CombineRgn hFrame, hClient, hFrame, RGN_XOR
        
        SetWindowRgn frm.hWnd, hFrame, True
    End SubPrivate Sub Command1_Click()
     MakeTransparent Me
    End Sub