今天看到这位博客的博主,把Chris Oliver 写的时钟改了一些代码,变成这个样子,呵呵,有兴趣的朋友可以参考下学习下面的源代码:
1
import javafx.ui.*;
2
import javafx.ui.canvas.*;
3
import java.util.Date;
4data:image/s3,"s3://crabby-images/9e1b5/9e1b5b2a3e46b5341b22649797d1794392182f55" alt=""
5data:image/s3,"s3://crabby-images/2a1f3/2a1f35146451967292b66fa62c8f22027e7067cf" alt=""
public class Timer
{
6
private attribute elapsed: Number;
7
public attribute minutes: Number;
8
public attribute seconds: Number;
9
public attribute hours: Number;
10
public attribute running: Boolean;
11
}
12data:image/s3,"s3://crabby-images/9e1b5/9e1b5b2a3e46b5341b22649797d1794392182f55" alt=""
13
attribute Timer.elapsed = bind
14
if running then
15
[1..60] dur 60000 linear
16
while running
17
continue if true
18
else 0;
19data:image/s3,"s3://crabby-images/9e1b5/9e1b5b2a3e46b5341b22649797d1794392182f55" alt=""
20data:image/s3,"s3://crabby-images/2a1f3/2a1f35146451967292b66fa62c8f22027e7067cf" alt=""
trigger on Timer.elapsed = value
{
21
var now = new Date();
22
minutes = now.getMinutes();
23
seconds = now.getSeconds() +
24
[.35,0.34 .. 0.0] dur 350 +
25
(now.getTime() % 1000)/1000;
26
hours = now.getHours();
27
}
28data:image/s3,"s3://crabby-images/9e1b5/9e1b5b2a3e46b5341b22649797d1794392182f55" alt=""
29data:image/s3,"s3://crabby-images/2a1f3/2a1f35146451967292b66fa62c8f22027e7067cf" alt=""
public class Clock extends CompositeNode
{
30
public attribute ticking: Boolean;
31
}
32data:image/s3,"s3://crabby-images/9e1b5/9e1b5b2a3e46b5341b22649797d1794392182f55" alt=""
33data:image/s3,"s3://crabby-images/2a1f3/2a1f35146451967292b66fa62c8f22027e7067cf" alt=""
operation Clock.composeNode()
{
34data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
var t = Timer
{running: bind ticking};
35data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
return Group
{
36
transform: [translate(5,5),scale(1,1)]
37
var secs = bind t.seconds
38
var mins = bind t.minutes + secs/60
39
var hrs = bind t.hours + mins/60
40
content:
41
[
42data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
Rect
{
43
height: 200
44
width: 200
45
fill: white
46
},
47data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
ImageView
{
48
transform: []
49data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
image: Image
{url: "http://sellmic.com/lab/dev/jfx/clock/images/clock_face.png"}
50
},
51data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
Group
{
52
var hourHand =
53data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
ImageView
{
54
transform: bind rotate(hrs*30,255,245)
55data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
image: Image
{url: "http://sellmic.com/lab/dev/jfx/clock/images/hour_hand.png"}
56
}
57data:image/s3,"s3://crabby-images/96c01/96c01a9005d00151a1af2189b6a9f266915ba654" alt=""
58
var minuteHand =
59data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
ImageView
{
60
transform: bind rotate(mins *6,255,245)
61data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
image: Image
{url: "http://sellmic.com/lab/dev/jfx/clock/images/minute_hand.png"}
62
}
63
64
var secondHand =
65data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
ImageView
{
66
transform: bind rotate(t.seconds * 6,255,245)
67data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
image: Image
{url: "http://sellmic.com/lab/dev/jfx/clock/images/second_hand.png"}
68
}
69data:image/s3,"s3://crabby-images/96c01/96c01a9005d00151a1af2189b6a9f266915ba654" alt=""
70
content: [hourHand, minuteHand, secondHand]
71
},
72data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
ImageView
{
73
transform: []
74data:image/s3,"s3://crabby-images/8d7d9/8d7d99ac571b1efcbf1f7e7a4120707c8e90d1fd" alt=""
image: Image
{url: "http://sellmic.com/lab/dev/jfx/clock/images/pin.png"}
75
}]
76
};
77
}
78data:image/s3,"s3://crabby-images/9e1b5/9e1b5b2a3e46b5341b22649797d1794392182f55" alt=""
79data:image/s3,"s3://crabby-images/2a1f3/2a1f35146451967292b66fa62c8f22027e7067cf" alt=""
Clock
{ticking: true}
80data:image/s3,"s3://crabby-images/9e1b5/9e1b5b2a3e46b5341b22649797d1794392182f55" alt=""
81data:image/s3,"s3://crabby-images/9e1b5/9e1b5b2a3e46b5341b22649797d1794392182f55" alt=""