Visual Basic Online Course - Analog Clock in VB6

Visual Basic Online Course - Analog Clock in VB6

vb6-analog-clock-project
Analog Clock using Visual Basic 6.0

Steps to create an Analog Clock
In Visual Basic 6.0


Introduction
Which level would read this?
Creating Digital Clock using Visual Basic 6.0 is easy, you only need a timer and a textbox or label to accomplish this, actually creating personal calendar & time are so easy. But Analog Clocks are not that easy for a Visual Basic beginner, but is a good example to start moving from being a beginner to professional.
Logic
How does it work?
We all have Analog Clocks in our houses or even wear one in our right hand, and we know that it refers to time and some of them show (Day, Month, Year) too, but we are not here to discuss how the timing system work, only the Analog Clock. The Analog Clock has 3 indicators or hands (Seconds, Minutes, Hours) and they don't just spin in circles, they TICK.
The indicator/hand of Seconds ticks 60 tick in order to cause 1 tick to the indicator/hand of the Minutes, and each 60 ticks of the indicator/hand of Minutes cause 1 tick to the indicator/hand of Hours.So, we have an equation which is :
1 hour=60 minutes
1 minute=60 seconds
1 second=1 tick of the Visual Basic Timer Control.
Project Design
How to design an Analog Clock for Visual Basic 6.0 ?
Yes, designing for VB6 is different from designing for VB.Net. We will need a photo of an Analog Clock, you can use Google search to download Analog Clock.JPEG or just download one of those Photos :
Coding in visual Basicvisual basic trainingvisual basic codingmicrosoft visual basic language coding

Or you can design one like this :
1) Using any painting application (PhotoShop or Paint) create a circle with 12 signs represent the 12 hours (1, 2, 3, ... 12) and make sure that your photo's dimensions are equal (Square) I.e 300x300 px in order to fit the form's dimensions.
2) Save your photo as JPEG format as by default Visual Basic 6.0 doesn't work with PNGs or GIFs.
3) Include your photo in your application's main folder.
4) Open Visual Basic 6.0 and Create New Project.
5) Make sure your form's dimension are equal and that you are using Twips as ScaleMode and Set AutoDraw to True.
6) Set the Photo property as your photo in your main folder.
7) Place a new PictureBox control on your form in the middle of it and a Label control.
How it works ...
>How do the Clock hands go round in circles ?
The circle (Clock face) is a circle with (12) numbers, this circle is divided into 360 degrees (even units) with 0 degree at 3 O'clock and 90 degrees at 12 O'clock, and the movement on the form (Circle) starts from PointF at the upper-left corner where X increase as we move to the right and Y increases as we move to the downSee Shape (1) & Shape (2) for details.

Shape1
Shape (1)
Shape2
Shape (2)
- Best way to understand a circle is when you know that circles are drawn according to the square within, meaning that when you draw a square shape then you be sure that the elliptic shape surrounds the square that touches the 4 corners or this square is an even circle with even 360 units called degrees. See shape (3).
Visual Basic codes-analog-clock
Shape (3) - Square shape within an elliptic shape (Circle) touches it in the 4 corners.
- Now, when we want to know the central point where the 3 hands (Hours Hand, Minutes Hand and Seconds Hand) will spin around, then we will need to specify the central point "PointF" (X,Y) in the very middle of the circle, which will be also the center of the square shape within, and as long as our form will be a square shape (Width=Height) then it's easy to calculate the position of this point.
Dim X As Single
Dim Y As Single
X = Me.Width / 2
Y = Me.Height / 2
view rawgistfile1.vb hosted with ❤ by GitHub
- Now, we want to draw 3 hands starting from this PointF and the 3 hands have different length (Seconds Hand is the tallest, Hours Hand is the shortest). Unless you know how to centralize the 3 hands on the form, we won't be drawing these hands at the Design Time (IDE). To draw a line you need to know its length. PointF (X,Y) is the start Point of drawing while PointE (X,Y) is the end point of drawing.
Line.Length=PointF to PointE , so according to shape (2), if I want to draw a line with length 500 Pixels then I need to set the PointF to PointE=500 like this Me.Line (0,0)-(500,500), VbRed , that means that I will draw a line from the Point (0,0) to the Point(500,500), if my form is 500Px then I will be drawing a line from the upper-left corner PointF to the lower-right corner PointE, see Shape (4).
vb6-analog-clock-project
Shape (4) - X,Y understanding
- In our example the form is a circle, but the form has even coordinates (4650 X 4650) twips while 4650 twips=310 Pixels ( * To convert twips to pixels we use 4650 / 15).
Naturally our Radius (R) is (4650/2)=2325 Twips (155 Pixels). In order to draw a circle on a form with 2325 Twips Radius, then our code is as following and is a part of the application project example of course. If you applied this code to a new Visual Basic 6.0 project then you will get a Round Shaped Form, but you will see it better if you set the Picture property of the form to a 310X310 Pixels JPG Picture and set the BorderStyle property of the form to=0 - None :
Option Explicit
Private Declare Function SetWindowRgn Lib "user32" (ByVal hwnd As Long, _
ByVal hRgn As Long, _
ByVal bRedraw As Boolean) As Long
Private Declare Function CreateEllipticRgn Lib "gdi32" (ByVal X1 As Long, _
ByVal Y1 As Long, _
ByVal X2 As Long, _
ByVal Y2 As Long) As Long
Private Declare Function DeleteObject Lib "gdi32" (ByVal hObject As Long) As Long
Dim X As Single
Dim Y As Single
Private Sub Form_Load()
Dim RGN As Long
With Me
.Width = Val(310 * 15)
.Height = Val(310 * 15)
.Left = (Screen.Width - .Width) / 2
.Top = (Screen.Height - .Height) / 2
.Picture = LoadPicture(App.Path & "/analog clock1.JPG")
.BackColor = vbWhite
X = .Width / 2
Y = .Height / 2
End With
'Make a round shaped form...
RGN = CreateEllipticRgn(0, 0, 310, 310)
Call SetWindowRgn(Me.hwnd, RGN, True)
Call DeleteObject(RGN)
End Sub
view rawgistfile1.vb hosted with ❤ by GitHub
- Drawing a line on the form : We said that if you wanted to draw a line on the form you must determine a starting point to draw from PointF (X1, Y1) and an end point to end draw to it PointE (X2, Y2) but, how do we determine the Line's length ? See Shape (5) first .....
vb6-analog-clock-understanding
Shape (5) - Drawing line on the form 'Green line'
- The picture in Shape (5) shows how is it done to draw a line from PointF(X1,Y1) to PointE(X2,Y2) or from (2325,2325) to (1500,1500) using Twips as the measuring unit and how twip points are placed on a Visual Basic form of a size of (4650 X 4650) twips. Remember that we started drawing from the center point until we reached (1500X1500) the PointE.
- The Size of this line When you measure, it will be (825 Twips from doing 2325-1500). Why the line is leaning and not straight ?
The answer is : Because of its Angle
-What is a line's Angle ?
Angle generally is that figure Angels in VB6or is the figure formed when 2 rays meet in one point, while the 2 rays are called the Angle Sides. Angle is measured by the Degree(s) like that symbol º, for example (90º ). How to use Angles in Visual Basic drawing lines on the form.
It is confusing because we only have one line and we want to make an Angle for it, and notice that the line slopes.

How to determine the Angle of a line drawn in Visual Basic 6.0 ?
We don't have a protractor but we have this :
60 seconds and minutes ticks within a circle [Seconds & Minutes hand]
12 Hours ticks [Hour hand]

Each tick represents an even angle, so we have :
59 angles to create a minute 
59 angles to create an hour
23 angles to create a day
Source Code
You can always download the source code from the bottom of the page.
But, study the code well and try to make changes to it, I will make it more flexible to use in another update soon.
Option Explicit
'===================================================
'Analog Clock
'--------------------------------------------------
'Creates a round(circle) shaped form
'and draws H, M, S indicators
'I made it easy to understand for VB6.0 beginers
'--------------------------------------------------
'Author: Evry1falls
'Date: 2013
'Visit : https://vb6access2003.blogspot.com
'All lines of code are explained in the Blog, Visit :
'https://vb6access2003.blogspot.com/2013/02/VB6-Analog-Clock.html
'--------------------------------------------------
'Reference:
'Larry Serflaten, Dipak Auddy
'Everything
'Google : evry1falls
'===================================================
'API to create windowless form
Private Declare Function SetWindowRgn Lib "user32" (ByVal hwnd As Long, _
ByVal hRgn As Long, _
ByVal bRedraw As Boolean) As Long
Private Declare Function CreateEllipticRgn Lib "gdi32" (ByVal X1 As Long, _
ByVal Y1 As Long, _
ByVal X2 As Long, _
ByVal Y2 As Long) As Long
Private Declare Function DeleteObject Lib "gdi32" (ByVal hObject As Long) As Long
'API to move windowless form
Private Const HTCAPTION As Long = 2
Private Const WM_NCLBUTTONDOWN As Long = &HA1
Private Declare Function SendMessage Lib "user32" Alias "SendMessageA" (ByVal hwnd As Long, _
ByVal wMsg As Long, _
ByVal wParam As Long, _
lParam As Any) As Long
Private Declare Function ReleaseCapture Lib "user32" () As Long
'The length of H,M,S indicators...
Private Const hWidth As Long = 1100
Private Const mWidth As Long = 1400
Private Const sWidth As Long = 1500
'Globals to store canvas(Picture Object)'s
'center co-ord.
Private X As Single
Private Y As Single
Private PI2 As Double
Private Sub Form_Load()
Dim RGN As Long
' PI / 2
PI2 = Atn(1) * 2
With Me
.BackColor = vbWhite
.Width = Me.Width
.Height = Me.Height
'Let's save the points...
X = .Width / 2
Y = .Height / 2
End With 'me
Label1.Caption = "Evry1falls" & vbCrLf & "@evry1falls.freevar.com"
'Make a round windowless! form...
RGN = CreateEllipticRgn(0, 0, 310, 310)
Call SetWindowRgn(Me.hwnd, RGN, True)
Call DeleteObject(RGN)
End Sub
Private Sub Form_MouseDown(Button As Integer, _
Shift As Integer, _
X As Single, _
Y As Single)
'Moving the form using mouse button from any location on the form held with mouse
If Button = 1 Then
ReleaseCapture
SendMessage Me.hwnd, WM_NCLBUTTONDOWN, HTCAPTION, ByVal 0&
End If
End Sub
Private Sub Form_Unload(Cancel As Integer)
'Stop the timer
Timer1.Enabled = False
End Sub
Private Sub Label1_MouseDown(Button As Integer, _
Shift As Integer, _
X As Single, _
Y As Single)
'Move form when drag the label
Form_MouseDown Button, Shift, X, Y
End Sub
Private Sub lblClose_Click()
'Exit App.
Unload Me
End Sub
Private Sub Timer1_Timer()
Dim Angle, PX, PY, OX, OY, WX, WY
Me.Cls
'Get Hr Angle...
Angle = (180 - (Hour(Now) * 6) * 5 - (Minute(Now) * 6) / 12) * 3.1415 / 180
'Hr. point
PX = X + (hWidth * Sin(Angle))
PY = Y + (hWidth * Cos(Angle))
'Opposite side
OX = X - (Sin(Angle) * 100)
OY = Y - (Cos(Angle) * 100)
'Hand width
WX = Sin(Angle + PI2) * 90
WY = Cos(Angle + PI2) * 90
'Draw Hr. hand...
Me.Line (OX, OY)-(PX, PY), vbYellow ' From opposite side to pointer
Me.Line -(OX + WX, OY + WY), vbBlue ' To one opposite side
Me.Line -(OX - WX, OY - WY), vbBlue ' To other opposite side
Me.Line -(PX, PY), vbBlue ' Back to pointer
Me.Circle (X, Y), 50, vbYellow
'Get Min Angle...
Angle = (180 - (Minute(Now) * 6)) * 3.1415 / 180
'Min point
PX = X + (mWidth * Sin(Angle))
PY = Y + (mWidth * Cos(Angle))
'Opposite side
OX = X - (Sin(Angle) * 100)
OY = Y - (Cos(Angle) * 100)
'Hand width
WX = Sin(Angle + PI2) * 90
WY = Cos(Angle + PI2) * 90
'Draw Min. hand...
Me.Line (OX, OY)-(PX, PY), vbYellow ' From opposite side to pointer
Me.Line -(OX + WX, OY + WY), vbMagenta ' To one opposite side
Me.Line -(OX - WX, OY - WY), vbMagenta ' To other opposite side
Me.Line -(PX, PY), vbMagenta ' Back to pointer
Me.Circle (X, Y), 50, vbYellow
'Get Sec Angle...
Angle = (180 - (Second(Now) * 6)) * 3.1415 / 180
'Draw Sec. hand...
Me.Line (X, Y)-(X + (sWidth * Sin(Angle)), Y + (sWidth * Cos(Angle))), vbRed
End Sub
view rawgistfile1.vb hosted with ❤ by GitHub
Download Link
The file has been tested for virus infection.The file (Analog Clock with Visual Basic 6.rar) contains these files :
microsoft visual basic coding
File is hosted for free on Mediafire.com, file (Analog Clock with Visual Basic 6.rar) - download

VB6 Popular Posts

Visual Basic Online Course - Run-time error '3021' : Either BOF or EOF is True, or the current record has been deleted.

VB 0.6 TreeView Control lesson Part1

VB 0.6 TreeView Control Lesson Part2