Solved

Place vb6 form above System Tray

Posted on 2009-04-03
7
497 Views
Last Modified: 2013-11-25
Dear

I need to Place one Form in Vb6 Just above System Tray with 6 cm in length and 2.5 cm in width.
Any suggestions, Need Help
With Thankx and Regards
0
Comment
Question by:Showkatdar
  • 3
  • 2
  • 2
7 Comments
 
LVL 31

Expert Comment

by:Frosty555
ID: 24062352
Use Screen.Width and Screen.Height to get the size of the screen.

Then position your form at:
    Form1.Width = Screen.Width - Form1.Width - 15
    Form1.Height = Screen.Height - Form1.Height - 50

Tweak the number at the end to take into account borders on your form, and the taskbar at the bottom of the screen.

Then you can size your form to be whatever size you like and it should appear in the bottom right corner.

You may also want to set your borderstyle to "None" or "Toolbar" so that the border isn't quite as thick and in the way.
0
 
LVL 85

Accepted Solution

by:
Mike Tomlinson earned 500 total points
ID: 24062812
Using Screen.XXX alone may actually put your form on TOP of the System TaskBar and/or other DeskBands that are running.  What if the TaskBar is made bigger (taller) or they have other such apps running?   What if the TaskBar is dragged to the Top of the screen?  Then your app will be in the bottom right but not flush with the edges...

To properly place your form in the bottom right without obscuring the TaskBar/DeskBands you need to use the SystemParametersInfo() API with the SPI_GETWORKAREA flag:
http://msdn.microsoft.com/en-us/library/ms724947(VS.85).aspx

    SPI_GETWORKAREA: Retrieves the size of the work area on the primary display monitor. The work area is the portion of the screen not obscured by the system taskbar or by application desktop toolbars.

An Example:
Option Explicit
 
Private Type RECT
    Left As Long
    Top As Long
    Right As Long
    Bottom As Long
End Type
 
Private Const SPI_GETWORKAREA = 48
Private Declare Function SystemParametersInfo Lib "user32" Alias "SystemParametersInfoA" (ByVal uAction As Long, ByVal uParam As Long, ByRef lpvParam As Any, ByVal fuWinIni 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 Long
 
Private Sub Form_Load()
    Dim desktopRect As RECT
    Dim formHeight As Single
    Dim formWidth As Single
 
    formHeight = 150 ' desired height of form in pixels
    formWidth = 150 ' desired width of form in pixels
    Call SystemParametersInfo(SPI_GETWORKAREA, vbNull, desktopRect, 0)
    Call SetWindowPos(Me.hwnd, 0, desktopRect.Right - formWidth, desktopRect.Bottom - formHeight, formWidth, formHeight, 0)
End Sub

Open in new window

0
 

Author Comment

by:Showkatdar
ID: 24062872
Dear Idle Mind,

Thanks for your reply. It is working fine. I accept your reply but need one more little help if you could. Is there any way to give some Effects to this form. Like 3d, or something other than that, should be Interactive.
Thank you and Regards
0
Courses: Start Training Online With Pros, Today

Brush up on the basics or master the advanced techniques required to earn essential industry certifications, with Courses. Enroll in a course and start learning today. Training topics range from Android App Dev to the Xen Virtualization Platform.

 
LVL 85

Expert Comment

by:Mike Tomlinson
ID: 24062973
Sorry.  I don't have any recommendations for making the form "prettier"...I code plain looking apps.  =)

Maybe Frosty has some ideas?...
0
 

Author Closing Comment

by:Showkatdar
ID: 31566330
OK Thankx For your wonderful help. It is working. Thankx.
0
 
LVL 31

Expert Comment

by:Frosty555
ID: 24064800
I don't know what you mean by 3D effects, but there are a number of utilities out there to let you "skin" a vb6 form (make it non-rectangular).

See this EE question:
http://www.experts-exchange.com/Programming/Languages/Q_20358281.html

This example:
http://www.freevbcode.com/ShowCode.Asp?ID=1813
0
 
LVL 31

Expert Comment

by:Frosty555
ID: 24064813
Making your form "Always On Top":


-------------------- FORM1.FRM ------------------------
 
Private Sub Command1_Click()
If (MsgBox("Should The Window Be Topmost?", vbQuestion+vbYesNo,"Question") = vbYes) Then
' Set Window to Topmost
SetTopmost(Me, True)
Else
' Cancel Topmost
SetTopmost(Me, False)
End If
End Sub
 
 
 
-------------------- ALWAYSONTOP.BAS -------------------
 
 
Option Explicit
Global ipbans As String
 
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 uFlags As Long) As Long
    
Public Const HWND_TOPMOST = -1
Public Const HWND_NOTOPMOST = -2
 
Public Const SWP_NOSIZE = &H1
Public Const SWP_NOMOVE = &H2
Public Const SWP_NOACTIVATE = &H10
 
Public Sub SetTopmost(Form As Form, ByVal Topmost As Boolean)
    Dim hWndInsertAfter As Long
    
    If Topmost Then
        hWndInsertAfter = HWND_TOPMOST
    Else
        hWndInsertAfter = HWND_NOTOPMOST
    End If
    
    SetWindowPos Form.hWnd, hWndInsertAfter, 0, 0, 0, 0, _
        SWP_NOSIZE Or SWP_NOMOVE Or SWP_NOACTIVATE
End Sub

Open in new window

0

Featured Post

Announcing the Most Valuable Experts of 2016

MVEs are more concerned with the satisfaction of those they help than with the considerable points they can earn. They are the types of people you feel privileged to call colleagues. Join us in honoring this amazing group of Experts.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

There are many ways to remove duplicate entries in an SQL or Access database. Most make you temporarily insert an ID field, make a temp table and copy data back and forth, and/or are slow. Here is an easy way in VB6 using ADO to remove duplicate row…
If you need to start windows update installation remotely or as a scheduled task you will find this very helpful.
Get people started with the process of using Access VBA to control Excel using automation, Microsoft Access can control other applications. An example is the ability to programmatically talk to Excel. Using automation, an Access application can laun…
Show developers how to use a criteria form to limit the data that appears on an Access report. It is a common requirement that users can specify the criteria for a report at runtime. The easiest way to accomplish this is using a criteria form that a…

808 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question