Click here to Skip to main content
Licence 
First Posted 7 Dec 2006
Views 35,388
Bookmarked 23 times

Analog Clock

By | 7 Dec 2006 | Article
An article on creating a simple analog clock using drawing and math.

Sample Image

Introduction

This is your basic analog clock using Cos, Sin, Theta, and the form's aspect ratio to draw the circles and gather the placement of the markers and hands. This is my first submission on here, and I hope it is useful to someone out there. The code is heavily documented, and there is also a demo download.

Background

I first wrote the code for this way back in the QB 4.5 days, and later converted it to Flash MX. I was bored on one of my days off, and really didn't feel like working on the other projects I have going, so I did this for old time sakes. I hope you enjoy it.

Using the code

I separated the main drawings into different Subs to make the code easier to follow and understand.

The main sub that is called is the Draw_Graphics() and it calls the other Subs to do the drawing. I am using a Bitmap object and a Graphics object to paint the pictures, and then I push the picture to the form to prevent flickering.

Private Sub Draw_Graphics()
    '******************************************************************
    '******** The drawing sub which has the individual         ******** 
    '******** subs in it for easier understand-                ********
    '******** ing. First we will draw the clock base,          ********
    '******** then the face, on to the markers,                ********
    '******** then the date and time on the face,              ********
    '******** and finally the hands of the clock.              ********
    '******************************************************************
    Draw_Clock_Base()
    Draw_Clock_Face()
    Draw_Clock_Markers()
    Draw_Clock_DateTime()
    Draw_Clock_Hands()
End Sub

These objects and variables are used in the full scope of the form. Other variables are used within the Subs.

Dim bm As Bitmap
Dim g As Graphics
Dim PI As Double = 3.14159
Dim XC, YC, X, Y, R, OldSec As Integer
Dim Theta, AspectRatio As Double

Points of Interest

I don't do a lot of graphics programming, so when working with the DrawPolygon command, it kept wanting to default the last location to (0,0) and I couldn't figure out why, so I ended up drawing the lines manually. If anyone has any suggestions, please let me know.

License

This article has no explicit license attached to it but may contain usage terms in the article text or the download files themselves. If in doubt please contact the author via the discussion board below.

A list of licenses authors might use can be found here

About the Author

Uber1

Web Developer

United States United States

Member

What would life be without code?

Sign Up to vote   Poor Excellent
Add a reason or comment to your vote: x
Votes of 3 or less require a comment

Comments and Discussions

 
You must Sign In to use this message board. (secure sign-in)
 
Search this forum  
 FAQ
    Noise  Layout  Per page   
  Refresh
Generalgood work yeah Pinmembervivekc53:38 14 Jun '11  
GeneralWho is gonna use this PinmemberNirosh17:15 7 Dec '06  
GeneralRe: Who is gonna use this PinmemberUber119:35 7 Dec '06  
AnswerRe: Who is gonna use this PinmemberHanzie5310:15 19 Dec '06  
Hows about speeding up time, scale down and you've got a brilliant progess indicator...
 
Hanzie

General General    News News    Suggestion Suggestion    Question Question    Bug Bug    Answer Answer    Joke Joke    Rant Rant    Admin Admin   

Use Ctrl+Left/Right to switch messages, Ctrl+Up/Down to switch threads, Ctrl+Shift+Left/Right to switch pages.

Permalink | Advertise | Privacy | Mobile
Web04 | 2.5.120529.1 | Last Updated 7 Dec 2006
Article Copyright 2006 by Uber1
Everything else Copyright © CodeProject, 1999-2012
Terms of Use
Layout: fixed | fluid