Flash Explained

Learn Flash easily.

Creating an analog clock with ActionScript using no design tools whatsoever!

October 12th, 2008 | Author: Luka | Category: ActionScript

I am most pleased to be able to show you how to create an analog clock in Flash using ActionScript only.

You won’t be touching any tools whatsoever. This is just about programming in Flash. Also, there is no timeline animation involved and no layers. And, this works in Flash MX, Flash MX 2004 and Flash 8.

Just look at the flash example below to see what is possible with actionscripting only.

That's right, even the shine on the left side of the clock frame was made with actionscript, just like the lines marking the hours and the minutes, and the clock hands too.

In this tutorial, you will make a simpler clock (but completely functional like the one above). At the end, I will briefly explain you how the stylish details were made and you will have the source for both clocks available for download.

Setting up the base movie clip for the clock

1 Open a new Flash document. Save it immediately so that you can just press CTRL+S later.

2 Name the first layer (and only one in this project) actions.

Naming the layer where the actions will be put in.

3 Select the first keyframe. This will be the only one, too - remember, there is no timeline animation here.

Select Window > Actions to open up the Actions panel for the frame you just selected. If you are new to actionscripting, know that all actions placed on this (first) keyframe will be executed immediately upon loading of this movie.

4 Enter in the following code:

this.createEmptyMovieClip("clock", 3);
clock._x = 150;
clock._y = 150;

The above piece of code creates a new movie clip out of nothing. The keyword this designates the object this piece of code is placed upon. As in this particular case the code is placed on the main timeline, the keyword this denotes the main timeline - this means the flash movie itself.

The createEmptyMovieClip command creates a new movie clip, obviously. There are two parameters between the parentheses which must be included if everything is to function as intended.

The first one is the instance name - "clock". That means the name of the movie clip you are creating. You need to specify it, because you wouldn't be able to manipulate the movie clip later if it has no name by which you can reference it. And, you have to put the name between quotation marks, otherwise flash will think that it is a variable and not an instance name you are talking about.

The second parameter is the depth of the movie clip. Think of that as a layer created with actionscript. The bigger the number, the higher the stack position of the movie clip. It means that the movie clip with, say, a depth of 50, will be in front of (on the screen) a movie clip with a lesser depth, like 40 or 6, or 11, etc. I put the depth 3 arbitrarily.

When creating a movie clip with the createEmptyMovieClip method, always give it a unique depth parameter. If you were to create a new movie clip after that, with the same depth as the previous one, that new movie clip would erase completely the previous one. Also, if any of the two parameters are missing (instance name or depth, or both), the creation of the movie clip will fail completely.

The next two lines are positioning the newly made movie clip on the stage. This is necessary because when you create a new movie clip using the createEmptyMovieClip method, it is by default positioned in the upper left corner of the stage, with the coordinates (0,0).

So the clock._x = 150; line positions the clock movie clip 150 pixels to the right from the left stage edge. The second one positions it 150 pixels down from the top edge of stage (the positive Y coordinates are below the top stage edge in flash). There is no this keyword at the beginning of the two lines because the movie clip was created on the main, or root, timeline in the first line of code, so you just write its name (clock) and flash will look for it on the root timeline.

If you test your movie at this point, you won't see anything, but the movie clip is created and positioned on stage. If you are still not convinced 🙂 then select Debug > List Objects while in the test movie mode. Flash will nicely list the movie clip.

Top of page

Making the circle - the clock's frame

5 Add this actionscript code after the existing one:

clock.createEmptyMovieClip("circle", 1);
clock.circle.lineStyle(4, 0x000066, 100);
clock.circle.moveTo(100, 0);
circleRadius = 100;
for (a=0; a<361; a++) {
radAngle = a*Math.PI/180;
xCoord = Math.cos(radAngle)*circleRadius;
yCoord = Math.sin(radAngle)*circleRadius;
clock.circle.lineTo(xCoord, yCoord);

Test your movie. You should have a circle drawn by flash like the one below showing up.

A circle drawn with actionscript.

Looks nice, huh? 🙂 And how does this work? Let me explain you.

First, you created a new movie clip using the createEmptyMovieClip command. This new movie clip is created inside the clock movie clip. Now why do that instead of repeating the same thing as you did in the beginning, using the this keyword?

Because if you move the original, the base movie clip clock, to another position on the stage (let's say you changed the layout of your flash site), the newly created circle would stay on the old position.

But, when you create the circle movie clip inside the clock movie clip by using the line

clock.createEmptyMovieClip("circle", 1);

this problem is solved. Now, if you decide to move the clock, the circle will follow it. In that way, you have all things situated inside the clock movie clip.

The line

clock.circle.lineStyle(4, 0x000066, 100);

sets the style of the line before the drawing starts. You always have to do this. If you're not familiar with actionscript drawing commands, I suggest you go and read the basic drawing with actionscript tutorial.

The line clock.circle.moveTo(100, 0); moves the circle movie clip's starting position for drawing. Note that the starting position of drawing for a movie clip is its registration point, which is the zero point of its own coordinate system. The stage is no longer used as a reference.

Why did you have to move the starting position for drawing? I will explain it in a moment.

The line circleRadius = 100; is where the circleRadius variable is defined and its value is 100. This value defines the radius of your clock's frame.

Now comes a for loop that actually draws the circular frame for your clock.

for (a=0; a<361; a++) {
radAngle = a*Math.PI/180;
xCoord = Math.cos(radAngle)*circleRadius;
yCoord = Math.sin(radAngle)*circleRadius;
clock.circle.lineTo(xCoord, yCoord);

This loop repeats 360 times. That's because there are 360 degrees in a circle and this piece of code is drawing the circle from point to point.

The first line inside the loop defines the radAngle variable. This variable's purpose is to store the angle for calculating the drawing points of the circle, in radians. This is necessary since the next two lines of code use flash's built-in math trigonometric functions which work with radians instead of degree values.

So the expression a*Math.PI/180 is a simple mathematical formula used to convert degree values into radians. Here is a little basic math reminder:

The formula for converting degrees into radians.

This angle increases every time as the loop increments. It stops when it comes full circle (pardon the pun) from 0 to 360 degrees.

Now comes the interesting part in which I will explain to you how the trigonometrical functions are used to draw the circle.

Top of page

The actionscript trigonometric functions used to find the coordinates for drawing explained

The X coordinate is found with this piece of actionscript:

xCoord = Math.cos(radAngle)*circleRadius;

It is stored in a variable called xCoord.

What does the right side of the expression do? I'll explain a little bit of high school math now. Wait. Wait! Don't run away 🙂 It IS easy. And it is fun once you see the possibilities and creativity it offers you. I pretty much shunned away all the math after my studies, but once I lay my hands on Flash and saw that I had to implement it if I wanted to do some advanced actionscripting, I quickly remembered and looked up what I needed. So will you! Continue and you'll see how interesting and cool math is!

So, you need to know the coordinates of every point on the circle to draw it. How do you find a point on a circle? Simple, with two pieces of data you already have. The angle and the radius. Look at the diagram below.

The trigonometry explained.

I took an angle of 30 degrees arbitrarily for the purpose of explaining this calculation. So, you're looking for the X and Y coordinates of the T point on the circle.

The X coordinate of the T point equals to the distance a on the diagram, which is the distance from the starting point (0,0) to the x point on the diagram. How to find the value of this distance? With trigonometry.

The triangle formed with the sides a, b and c in the diagram is a right triangle. It means there is a right angle (90°) inside it. It is found between the sides a and b. There are some great trigonometrical functions that can be used with this kind of triangle.

The cosine of an angle (the angle is marked with the greek letter lambda - ?) is the ratio of the length of the triangle side adjacent to the angle (a in the diagram) to the length of the hypotenuse (the hypotenuse being the side opposite the right angle, c in the diagram). So, the formula goes like this:

The cosine formula.

Written in a single line it goes like this:

cos ? = adjacent side / hypotenuse

If you apply the distances from the diagram to the formula, it would turn out this way:

cos ? = a / c

In your actionscript code, the angle ? is defined in the variable radAngle and the hypotenuse c is the radius of the circle, defined in the variable circleRadius. What is left is the adjacent side a, which is the X coordinate of the T point you're looking for. That coordinate is named xCoord in your code. So, the formula turned into actionscript looks like this:

Math.cos(radAngle) = xCoord / circleRadius;

But you're looking for the T point's X coordinate, right? So, the final line of code you need looks like this:

xCoord = Math.cos(radAngle) * circleRadius;

And that's it! The similar explanation goes for the Y coordinate. You're smart so just look at the diagram and apply the same logic to discover the explanation for finding the Y coordinate value.

So after finding both coordinates for each point (360 points in total because that's the number of iterations the loop is going through),

xCoord = Math.cos(radAngle)*circleRadius;
yCoord = Math.sin(radAngle)*circleRadius;

flash finally draws the line by executing the following code:

clock.circle.lineTo(xCoord, yCoord);

OK, the method lineTo draws the line to the coordinates specified within the parentheses. But where does the line start? Where is it drawn from?

This was defined in the line

clock.circle.moveTo(100, 0);

before the loop. After that first line is drawn, the loop passes to the next iteration and draws from the last point (as drawing in flash is set up to do, if there was no moveTo command in between) to the next one, which is again calculated with the aid of the cosine and sine functions.

But, you ask again, why did I used the moveTo command to move to the point (100, 0) and not some other point?

Because the calculation for the first angle is for the 0 degree angle, which is situated at three o'clock in flash. That's why you need to move the starting point for drawing here, so that it continues naturally following the circle.

Look at this diagram explaining it.

I put a lot of distance between the three marked points to make the diagram more easy to read. In reality, these points are right next to one another.

A diagram explaining how the circle is drawn with actionscript.

So, the first point (100, 0) is right on the horizontal axis of the circle. This is where the drawing will begin, this was done with the moveTo command explained above.

Soon after this line of code, the loop begins and the first point on the circle (T1) is calculated. A line is drawn from (100, 0) to (T1) with the lineTo command which follows the calculation of the point. The loop goes through the next iteration and calculates the coordinates for the second point (T2). A line is drawn from the previous point (T1) to this one (T2).

And this goes on until the loop ends, that is, after 358 more iterations. So, I suppose you got the trick by now: the circle is in fact a 360-sided polygon! But the sides of the polygon are so close that it look like a circle. Cool, no? Absolutely cool! 🙂

Top of page

Creating the markings for the hours and the minutes

The circle with the main concept of advanced drawing with actionscript being thoroughly explained, it's time for you to create the markings for the hours and the minutes.

The method used is the same, with some differences and catches.

6 Type in the following lines right after all the code you entered so far:

clock.circle.lineStyle(3, 0x000000, 100);
clock.circle.moveTo(100, 0);
circleRadius = 100;
smallerCircleRadius = 90;
for (h=0; h<12; h++) {
hourAngle = h*30;
radHourAngle = hourAngle*Math.PI/180;
xCoord1 = Math.cos(radHourAngle)*circleRadius;
yCoord1 = Math.sin(radHourAngle)*circleRadius;
xCoord2 = Math.cos(radHourAngle)*smallerCircleRadius;
yCoord2 = Math.sin(radHourAngle)*smallerCircleRadius;
clock.circle.moveTo(xCoord1, yCoord1);
clock.circle.lineTo(xCoord2, yCoord2);

Test your movie. The markings for the hours will appear. Let me quickly explain you how this is done.

The first line changes the style of the drawing line, so that it appears thicker. You can make it any color and thickness that you want, but the important thing is to make it more prominent than the minutes' markings. Remember, the time must be easily redable from the clock. Be nice to your users!

There is the circleRadius variable again, which is listed here for easier comprehension. There is also a new addition, smallerCircleRadius. These two circle radiuses will make it possible to draw a line from the outer circle to the inner circle.

The loop has only 12 iterations now, which makes sense because this is the number of the hours' markings on a standard analog clock.

Inside the loop, the first line of code defines the angle at which the calculations are made. This angle is the loop's iteration multiplied by 30.

I hear you asking: why? 🙂

Because a full circle has 360 degrees, and there are 12 hours on an analog clock. So by multiplying each iteration number (0, 1, 2... till 11) with 30, you obtain the angles at which the markings for the hours must be positioned.

After the conversion of the angle from degrees to radians (the same formula as in the previous step), there are two pairs of coordinates calculated, followed by a moveTo command that defines a new starting drawing point for each iteration, and then drawing with the lineTo command.

xCoord1 = Math.cos(radHourAngle)*circleRadius;
yCoord1 = Math.sin(radHourAngle)*circleRadius;
xCoord2 = Math.cos(radHourAngle)*smallerCircleRadius;
yCoord2 = Math.sin(radHourAngle)*smallerCircleRadius;
clock.circle.moveTo(xCoord1, yCoord1);
clock.circle.lineTo(xCoord2, yCoord2);

Look at the diagram below to see how easy it is to understand this.

The diagram explaining the drawing of the markings for the hours.

I put the points on another part of the circle, but this is applicable on all of it.

After placing the drawing position on B1, it draws the line to S1, which is found on the inner, smaller circle. The lines are drawn perfectly pointing at the center of the circle because the angle calculated is the same for the small and the big circle in each iteration. Then flash moves the starting drawing position again, this time to B2, and draws the line to S2.

It is easy once the main concept is grasped, isn't it?

You should create the markings for the minutes now, using a thinner line this time.

7 Place the following actionscript at the end of your current code:

clock.circle.lineStyle(1, 0x000000, 100);
clock.circle.moveTo(100, 0);
circleRadius = 99;
smallerCircleRadius = 91;
for (m=0; m<60; m++) {
minuteAngle = m*6;
radMinuteAngle = minuteAngle*Math.PI/180;
xCoord1 = Math.cos(radMinuteAngle)*circleRadius;
yCoord1 = Math.sin(radMinuteAngle)*circleRadius;
xCoord2 = Math.cos(radMinuteAngle)*smallerCircleRadius;
yCoord2 = Math.sin(radMinuteAngle)*smallerCircleRadius;
clock.circle.moveTo(xCoord1, yCoord1);
clock.circle.lineTo(xCoord2, yCoord2);

The only thing that needs to be noted at this step is that I changed the radiuses for both circles, so that the minutes' markings are a little bit shorter than the hours' markings.

The clock image drawn with actionscript.

This loop goes through 60 iterations because there are 60 minutes in an hour. Inside the loop, this number is multiplied by 6, to get the right angle for each minute's marking. Similar calculation as before: 360 degrees in a circle, 60 minutes in an hour. 360 divided by 60 yields 6. The rest (moving and drawing) is as same as for the hours' markings.

Test your movie. Cool! You should have the same result as in the image on the left (the screenshot on the image is scaled down).

Top of page

Drawing the seconds, minutes and hours hands

You'll now proceed to make the clock's hands. This is a little bit simpler than circle drawing with actionscript 🙂

8 Add the following code to the existing one:

clock.createEmptyMovieClip("hoursHand", 20);
clock.hoursHand.lineStyle(6, 0x000000, 100);
clock.hoursHand.moveTo(0, 0);
clock.hoursHand.lineTo(0, -50);

Test your movie. You should see the hours hand appear.

The hours hand drawn via actionscript.

This is simple, you only need to be careful about some details. At first, the movie clip is created. Its depth is set above the circle movie clip's hand, because you want all the hands to be above the circle and other drawings.

A thicker line is chosen for drawing style. Next, the beginning of the drawing is moved to (0, 0). This is very important. This is the registration point of the hours hand movie clip and it is around this point that the hand will rotate.

The lineTo command draws the hand.

9 Add the code that follows:

clock.createEmptyMovieClip("minutesHand", 30);
clock.minutesHand.lineStyle(5, 0x000000, 100);
clock.minutesHand.moveTo(0, 0);
clock.minutesHand.lineTo(0, -81);

clock.createEmptyMovieClip("secondsHand", 40);
clock.secondsHand.lineStyle(0, 0xFF0000, 100);
clock.secondsHand.moveTo(0, 0);
clock.secondsHand.lineTo(0, -90);

This is the code to create the minutes and the seconds hand.

Note that each hand movie clip's depth is bigger than the previous one. In that way, the clock hands are stacked one on top of another. I chose the depths 20, 30 and 40. It could have been 11, 12 and 13 or any other three numbers. But it is always wise to let some "space" between the depths. You never know, you might decide to add something in between later and then you'll be glad you did this.

Test the movie and you'll see the hands stacked one on top of another.

Top of page

Setting the clock in motion

Yes! Finally, you get to start the clock! Just a liiiiittle bit more!

10 Enter the final piece of code:

clock.onEnterFrame = function () {
clockDate = new Date();
seconds = clockDate.getSeconds();
this.secondsHand._rotation = seconds * 6;
minutes = clockDate.getMinutes();
this.minutesHand._rotation = minutes * 6;
hours = clockDate.getHours();
this.hoursHand._rotation = (hours * 30) + (minutes/2);

Test your movie. The seconds hand should tick! This is the best way to check if your clock is working.

This portion of code creates a function assigned to the circle movie clip's onEnterFrame event. This means that the function will get executed as many times per second as there are frames per second set in your movie's speed (fps option in your document's properties).

Inside the function, there is a new date object created. This is obligatory if you want flash to tell you what time or date it is. The lines

seconds = clockDate.getSeconds();
minutes = clockDate.getMinutes();
hours = clockDate.getHours();

create variables in which the information on current seconds, minutes and hours are stored.

A little bit more interesting are code lines that govern the rotation of the clock's hands.

this.secondsHand._rotation = seconds * 6;
this.minutesHand._rotation = minutes * 6;
this.hoursHand._rotation = (hours * 30) + (minutes/2);

The this keyword points to the clock movie clip, since it is situated in a function which is assigned to this same movie clip's onEnterFrame event. So, this.secondsHand points to the movie clip secondsHand which is placed inside the clock movie clip. Just simple actionscript paths.

Now, the _rotation property of these movie clips is what is found on the right side of these code lines. The _rotation property value is expressed in degrees.

Why are the minutes and seconds multiplied by 6?

For example, let's say that flash just read the time which said it is exactly 15 seconds now. This means the secondsHand movie clip should be pointing at 3 o'clock. This is 90 degrees in relation to its starting position of 0 degrees. That's why you have to multiply by 6. This is what happens at runtime:

this.secondsHand._rotation = seconds * 6;
this.secondsHand._rotation = 15 * 6;
this.secondsHand._rotation = 90;

The initial value for the _rotation property of any movie clip is 0 degrees, which is pointing straight upwards, in contrast with the sine and cosine values discussed in previous steps of this tutorial, which point at the right side, horizontally. OK? Don't confuse these two values, who have nothing to do with one another.

The same is with the clock's minutes hand.

But there is a difference with the hours hand. Its code says

this.hoursHand._rotation = (hours * 30) + (minutes/2);

If you just put in

this.hoursHand._rotation = hours * 30;

it would work, but in a misleading way. The result of the equation on the right side of the expression would be the following: let's say it's 11:50 now. 11 multiplied by 30 would yield 330, which means 330 degrees, which points right to 11 o'clock. This is ok, right?

No. It is not good! The hours hand would point straight at 11 o'clock, while it is 11:50. This means the hours hand should be pointing almost at 12 o'clock at this time. Just look at the image below to see what I mean.

The misleading and the good clock.

Imagine you have to be somewhere at noon. This particular clock makes you think it's almost 11 o'clock, instead of 12. Now you would miss that great movie, blind date or work interview (hopefully in the web design field). OK. How to correct this?

So, when it's, let's say, 11:30 (I'm not using 11:50 because 11:30 is easier to understand), the hours hand should be positioned right between 11 and 12 hour markings. So that's why you add the minutes divided in half.

Imagine it is 11:30. The calculation would go like this:

this.hoursHand._rotation = (hours * 30) + (minutes/2);
this.hoursHand._rotation = (11 * 30) + (30/2);
this.hoursHand._rotation = 330 + 15;
this.hoursHand._rotation = 345;

That's it - with this addition you get just the small increment you need to make the hours hand point to the right place.

You just finished the actionscript clock! Whoaaaa! Cool!

Top of page

The advantages of the actionscript-only clock

Just so that you know, the SWF generated from this flash document has a filesize of only 760 bytes!!! Do you realize what this means?

This means you can place this clock in an intro, preloader or in a banner! And it will load instantly, even on slower connections! Now that is radical! With this clock, you rule. Your site rules. Your client's site rules.

And, what's completely cool, this is written in ActionScript 1.0 and compatible with flash player 6 and above. So be sure to set the ActionScript version to 1.0 and the Flash player version to 6.0 in the Publish settings dialog if you are working in Flash 8 or Flash MX 2004.

You can also change the line thickness, colors and alpha of all the elements of the clock with just a few keystrokes. No re-editing or re-drawing. Just change the code! This lesson's source files (both the simple clock and the one with the shining frame) can be downloaded below.

Download the tutorial's zipped source FLA file

You want to be even more cool? Make the shine on the clock as you've seen it at the beginning of this tutorial. What's the catch with the actionscript shine? It is using the same routine as the one used for generating the circle and the hours and the minutes markings. You just have to make smaller the range of the loop for this effect and put in the code that changes the alpha of the thick white line that is drawn. The line is fading at both ends, creating the shining effect. Voila!

Download the source FLA file for the expanded example

Be Sociable, Share!


Submit a comment

  • upen Nov 29, 2008 at 9:21 am

    Very helpful…………..
    I didnt know a thing about action scripts
    explained very beautifully…
    gr8 job……

  • chan Dec 30, 2008 at 11:31 am

    awesome explanation
    nicely done/kept simple and to the point.

  • Bernie Apr 2, 2009 at 4:48 pm

    The most helpful tutorial I have ever found on the web


  • Mansur Apr 4, 2009 at 7:39 am

    Thank you I am used yourcode in my college site
    but I put your site name becus this your right

  • parth Apr 8, 2009 at 7:25 am

    This is wonderfully fantastic. Very good job. Thank you very much.

  • David Apr 27, 2009 at 7:15 am

    Awesome tutorials!!!! Very professional looking!!!!

    This code didn’t work for me in Flash CS3. 🙁

  • Erick May 7, 2009 at 4:28 pm

    Very well written. Alas, doesn’t work with Flash CS4 either.

  • Ddfloww Jun 3, 2009 at 4:48 pm

    david and erick… are you guys making you checked the appropriate actionscript and flash player on publishing settings ? i have both cs3 and cs4 and i see no problem with the code.

  • Tazman74 Jul 6, 2009 at 10:39 pm

    it’s a gread tutorial
    realy thanks
    now i finally have a clock on my site that realy fits the site
    i could keep the background transparent so it realy looks nice
    but is there anyway i can take the time of the clock
    from the world time server
    so it wil always have the correct time
    now it looks at the time of the user who loads the site

  • […] it doesn’t crash as it is supposed to be an alarm clock.Make your own darn clock using Flash and this tutorial. If you’re looking for a real challenge, however, try building a meatspace clock. Yeah, coding is […]

  • Ankit Aug 3, 2009 at 6:08 am

    Thanks for this great tut.
    I wanted to add 3,6,9,12 outside the circle and my name at the center of circle .How to go abt that?

  • rohit Sep 2, 2009 at 4:29 am

    hi thax you all … this is really needful for me thanx thanx very much
    i m web designer and i need help for web progaming .. if you can help me will be thank ful for you.. dont warry will pay for this… Rohit

  • Branden Oct 20, 2009 at 10:03 pm

    Thanks for the great tutorial however, I was wondering how we could go about making the actual numbers for the clock? IE 1,2,3,4 ..12 etc. Thanks!

  • tony L Jan 22, 2010 at 4:52 am

    waah… keren abss….bnr-bnr aq gk nyangka ternyata animasi bisa di desain dgn menggunakan script saja….hbt hbt….
    thx y dh bagi-bagi ilmunya 🙂

  • PerlAmutor Feb 18, 2010 at 9:13 pm

    this.hoursHand._rotation = (hours * 30) + (minutes/2);
    this.hoursHand._rotation = (11 * 30) + (30/2);
    this.hoursHand._rotation = 330 + 15;
    this.hoursHand._rotation = 345;

    This is a bad solution. What if i dont want 12 hours in circle, but 24? So:

    360/24 = 15°

    this.hoursHand._rotation = ((hours + minutes/60 + seconds/3600) * 15) % 360;

    360/60 = 6°
    this.minutesHand._rotation = ((minutes + seconds/60)*6) % 360;

    360/60 = 6°
    this.secondsHand._rotation = (seconds * 6) % 360;

    So with this solution we can use any numbers marks with any hand. For example 120 seconds per loop as 2 minutes (360/120=3° per mark) , or 180 minutes (360/180=2° per mark) as 3 hours movie per one loop.

  • Jake Mar 9, 2010 at 8:09 pm

    This entire site is filled incredibly useful, well written tutorials. Thanks for taking the time to share them.

  • mrmime Aug 18, 2010 at 8:10 am

    hi! thats awsome tutorial)) very good explanation

    one question ) I want to make 3 clocks for LONDON, NEW YOURK, local time,
    the tutorial shows how to make local time and it works great) what must be changed for other countries in this scripts)))?

    thanks a lot

  • Wow! A really very good example.

  • Ashif Sep 28, 2010 at 3:42 pm

    I Really want to thank you for explaining in such a way.

    It very nice and easy to understand


  • Joel Oct 3, 2010 at 3:10 am

    Luka, Awesome. Thanks for sourcefile too. Is changing in dimention will make me square clock from round one? I want to put it up on my website sidebar as a small square.

    Thanks again for this.

  • Diva Oct 24, 2010 at 4:24 pm

    wow that realy Amazing
    thank you for your good work

    but I have a question
    How can i get easy code by amendment to complement the full course at 23 hours or 2 hours, 3 hours, etc ?!

    and thanks again

  • sushan Nov 20, 2010 at 12:47 pm

    Great Job

  • admec multimedia Dec 2, 2010 at 12:08 pm

    i used to create clocks many times i.e. analogue and digtal, but i never designd using drawing options of flash action script.

    I like this tutorial. very simple and your way of explanation is quite nice.

    admec multimedia staff

  • Elena Jan 12, 2011 at 10:36 am

    how can the clock be set to show time on the different time zone? like you showed us this outstanding tutorial on Croatia map (thank you so much!), so could this kind of clock be placed on your Croatia site and show the time in Croatia?

  • febie kaye pineda Feb 18, 2011 at 4:34 pm

    i made it thanks…

  • aland May 2, 2011 at 12:45 am

    Fantastic excellent tutorial,learned here in 30 mins then what I learned in 1 month on other site
    thank you

  • sagar May 27, 2011 at 6:42 pm

    thanks… its helpful..

  • n Aug 25, 2011 at 10:58 pm

    Thank you for the very helpful tutorial

  • Mohan Jan 10, 2012 at 5:21 am

    Fantastic excellent tutorial, what a explanation
    u r true god…..

  • Mike Feb 19, 2012 at 10:58 am

    What if I want to use a ‘real’ image of a clock hand and have the second hand be ‘smooth-sweeping?’ I know that has something to do with “milliseconds” but have yet to be able to figure that–or changing the hands from just lines. Other than that, your script works great–I just need to be able to ‘tweak’ it a bit. Can you help? Oh and on the second hand also…how would I make it “bouncy” That would be nice to know too!

  • jim Apr 3, 2012 at 11:27 am

    How can I convert the fla file to a .flv file???

  • Radim Apr 16, 2012 at 2:16 pm

    Some other clock, can be set by dragging hour and minute hand to set other time.

    http://lab.php5.cz/hodiny2.fla (rename to FLA)

  • Gustavo Gomez Oct 12, 2012 at 12:45 am

    You´re a Professor!!!

  • Krsna say: “Time I am”. Well Done

  • Lourenço Jun 16, 2013 at 1:23 pm

    Great tutorial!!

    Thank you very much.

    I’m intersted in using this watch as a theatrical effect, but I would need to invert the colors, that is, to have a black background. Anyone knows how can I define the blackground color in action script?



  • GERRY Dec 18, 2013 at 9:52 pm

    What a great Tutorial! very easy and clear to follow. My end result doesn’t go though, the hands stay stuck at 12:00. There are no errors in the dialogue box and I have double checked the script – 3 times!
    Any clues?

  • Luka Jan 15, 2014 at 7:29 pm

    @ GERRY: This was written for ActionScript 2.0. Try swithcing to it in your FLA file preferences.

  • P Bainbridge Jan 16, 2014 at 12:15 pm

    Nice tutorial but i do feel a lot of it was overkill.

You must log in to post a comment.