【问题标题】:Semi Transparent Form using VB6使用VB6的半透明表格
【发布时间】:2011-04-06 23:21:50
【问题描述】:

是否可以创建一个半透明的表单,它应该在任何打开的窗口上可见,而不是隐藏在后面?请指导!

【问题讨论】:

  • @GSerg Google 的第一个命中可能是不可靠的代码,尤其是因为它需要调用 Windows API。下面接受的答案引用了来自优秀网站的高质量代码。

标签: vb6


【解决方案1】:

当然,请参阅 Karl Peterson 的“半透明”示例:http://vb.mvps.org/samples/Translucent/

要使表单在其他窗口中可见,您需要使用 SetWindowPos API 函数。

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 Long

Private Const HWND_TOPMOST = -1
Private Const SWP_NOMOVE = &H2
Private Const SWP_NOSIZE = &H1
Private Const OnTopFlags = SWP_NOMOVE Or SWP_NOSIZE

Public Sub FormOnTop(frm As Form)
    Call SetWindowPos(frm.hWnd, HWND_TOPMOST, 0&, 0&, 0&, 0&, OnTopFlags)
End Sub

【讨论】:

  • 对不起,它没有帮助。我从提供的链接下载了代码并粘贴了 Joe 提供的代码。但是如果打开一个新窗口,比如打开任何浏览器,它会隐藏在浏览器窗口后面。
  • GSerg - 我在谷歌上搜索了代码,但只找到了使表单窗口半透明的代码,而不是我想要的。在所有不隐藏的窗口上都是半透明的,类似于在浏览器窗口上显示图表的带宽计.
  • 我会看一下我再次发布的示例和代码;您可以在您的项目中使用 CTranslucent 类,只需在您希望的任何 form_load 上调用透明度。同样在 form_load 上,使用 Me 对象调用 FormOnTop 函数,即“Call FormOnTop(Me)”
  • 谢谢乔。 form_load 代码 Call FormOnTop(Me) 运行良好。请编辑提供的答案中的代码,以便我可以勾选您的答案。
【解决方案2】:
'function to make transparent'

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 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 Const G = (-20)
Private Const LWA_COLORKEY = &H1        'to trans'
Private Const LWA_ALPHA = &H2           'to semi trans'
Private Const WS_EX_LAYERED = &H80000

Private Sub Form_Activate()
    Me.BackColor = vbBlue
    Trans 1
End Sub

Private Sub Trans(Level As Integer)
    Dim Msg As Long
    Msg = GetWindowLong(Me.hwnd, G)
    Msg = Msg Or WS_EX_LAYERED
    SetWindowLong Me.hwnd, G, Msg
    SetLayeredWindowAttributes Me.hwnd, vbBlue, Level, LWA_COLORKEY
End Sub

【讨论】:

    猜你喜欢
    • 2010-12-01
    • 1970-01-01
    • 2012-01-22
    • 2011-08-31
    • 1970-01-01
    • 2018-03-09
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多