Transparent Borderless Forms in Visual Basic 2005

 Introduction

This article describes an approach to displaying transparent forms in a Windows application. Such may be useful to anyone wishing to display an odd shaped form for a splash screen or possibly a tool dialog with a transparent background.

transparent.gif

Figure 1: Transparent Forms

Getting Started

The solution contains three Windows Form classes; each shows something different about a transparent form. 

solutions-explorer-in-vb.net.gif

Figure 2:  Solution Explorer with the Project Visible

Code:  Form 1 (Form1.vb)

There is nothing much to creating the transparent form; setting the forms back color and transparency key property value to the same color is all that is required. In form 1 the form back color and transparency key are both set to lime green; this color does not occur within the image and so the image will not appear to have holes in it; do not use a transparency color that occurs in your images. That much takes care of making the form transparent.  Setting the forms FormBorderStyle property to none removes the forms border and all that will remain when the form is displayed is an image.  

properties-in-vb.net.gif

Figure 3:  Forms Transparency Key Property

Of course having a transparent borderless form eliminates the ability to drag the form around the desktop; at least without doing a bit more work. In order to set up the form for dragging in this condition a couple of DLL call are needed. The following contains the code behind the Form1 class.

The following user32.DLL calls (SendMessage and ReleaseCapture) are required to support the dragging and dropping of the form in the absense of a caption bar on the form.

     

<summary>

The SendMessage function sends a message to a window or windows.

</summary>

<param name="hWnd"></param>

<param name="msg"></param>

<param name="wParam"></param>

<param name="lParam"></param>

<returns></returns>

<remarks></remarks>

Declare Auto Function SendMessage Lib "user32.dll" (ByVal hWnd As IntPtr, _

ByVal msg As IntegerByVal wParam As IntPtr, ByVal lParam As IntPtr) As IntPtr


<summary>

ReleaseCapture releases a mouse capture

</summary>

<returns></returns>
<remarks></remarks>

Declare Function ReleaseCapture Lib "user32.dll" () As Boolean

 

/// <summary>

/// default constructor

/// </summary>

public Form1()

{

     InitializeComponent();

}

 

The picturebox fills the entire draggable area of the form  (those sections which are not visible cannot be used for a drag operation) and for that that reason the picture box controls mouse down event is used to support the borderless form dragging operations.

 

<summary>

Handles form drags

</summary>

<param name="sender"></param>

<param name="e"></param>

<remarks></remarks>

Private Sub pictureBox1_MouseDown(ByVal sender As System.Object, ByVal e

As System.Windows.Forms.MouseEventArgs) Handles pictureBox1.MouseDown

 

If e.Button = MouseButtons.Left Then

ReleaseCapture()

SendMessage(Me.Handle, &HA1, &H2, 2)

End If

End Sub

 

The rest of the class code is pretty straightforward and is not particularly relevant to the topic. The code is annotation to explain the remaining event handlers.


<summary>

Open new instance of form 2

</summary>

<param name="sender"></param>

<param name="e"></param>

<remarks></remarks>

Private Sub button2_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handlesbutton2.Click

Dim f As New Form2()

f.Show()

End Sub

 

<summary>

Open new instance of form 3

</summary>

<param name="sender"></param>

<param name="e"></param>

<remarks></remarks>

Private Sub button3_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handlesbutton3.Click

Dim f As New Form3()

f.Show()

End Sub


<summary>

Dispose main form and exit

</summary>

<param name="sender"></param>

<param name="e"></param>

<remarks></remarks>

Private Sub button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handlesbutton1.Click

Me.Dispose()

End Sub

End Class

Form 2  (Form2.vb)

The code behind Form2 is the same as it used in Form1; the only differences between the two forms are the complexity of the image used as the borderless form and that the background color and transparency key property values are different than that used on Form1.

Form 3 (Form3.cs)

Form3 is another spin on the same thing used in forms 1 and 2. The difference here is that the picture box contains a white rectangle; the transparency key value is set also to white which will defeat any attempts to drag the form. This form does have a border around it to enable dragging the form, if you set the border style to “None” then the form will no longer be draggable.

Summary

This article was intended to demonstrate an approach to creating transparent backed, borderless, draggable forms. The approach may be used to generate some sort of custom UI or may be used to build a classier looking splash screen. 


Similar Articles