作者:mobiledu2502881683 | 来源:互联网 | 2023-08-21 19:40
原标题:[JavaFX] 绘制简易时钟(二)
在前一篇博客中,我们已经绘制了一个静止时钟。
绘制简易时钟(一)
- 首先进行一个微调:让表盘根据窗口大小自动调整大小:
在 ShowClock.start() 中,添加对面板长宽的监听。
pane.widthProperty().addListener(ov -> clock.setW(pane.getWidth()));
pane.heightProperty().addListener(ov -> clock.setH(pane.getHeight()));
- 添加对时间和钟表大小的更改方法
在 ClockPane 类中添加:
public ClockPane(int hour, int minute, int second) {
this.hour = hour;
this.minute = minute;
this.second = second;
paintClock();
}
public void setHour(int hour) {
this.hour = hour;
paintClock();
}
public void setMinute(int minute) {
this.minute = minute;
paintClock();
}
public void setSecond(int second) {
this.second = second;
paintClock();
}
public double getW() {
return w;
}
public void setW(double w) {
this.w = w;
paintClock();
}
public double getH() {
return h;
}
public void setH(double h) {
this.h = h;
paintClock();
}
- 用 Timeline 实现动态钟表
在 ShowClock 类中添加:
EventHandler<ActionEvent> eventHandler = e -> {
clock.setCurrentTime();
};
Timeline animation = new Timeline(
new KeyFrame(Duration.millis(1000), eventHandler));
animation.setCycleCount(Timeline.INDEFINITE);
animation.play();
就可以让时钟动起来了。
完整代码
ShowClock.java
package primier;
import javafx.application.Application;
import javafx.geometry.Pos;
import javafx.scene.Scene;
import javafx.stage.Stage;
import javafx.scene.layout.*;
import javafx.scene.control.*;
import javafx.event.ActionEvent;
import javafx.event.EventHandler;
import javafx.util.Duration;
import javafx.animation.KeyFrame;
import javafx.animation.Timeline;
public class ShowClock extends Application {
@Override
public void start(Stage primaryStage) {
ClockPane clock = new ClockPane();
EventHandler<ActionEvent> eventHandler = e -> {
clock.setCurrentTime();
};
Timeline animation = new Timeline(
new KeyFrame(Duration.millis(1000), eventHandler));
animation.setCycleCount(Timeline.INDEFINITE);
animation.play();
BorderPane pane = new BorderPane();
pane.setCenter(clock);
Scene scene = new Scene(pane, 250,250);
p文章来源站点https://www.yii666.com/rimaryStage.setTitle("Display Clock");
primaryStage.setScene(scene);
primaryStage.show();
pane.widthProperty().addListener(ov ->
clock.setW(pane.getWidth()));
pane.heightProperty().addListener(ov ->
clock.setH(pane.getHeight()));
}
public static void main (String[] args) { Application.launch(args); }
}
ClockPane.java
package primier;
import java.util.Calendar;
import java.util.GregorianCalendar;
import javafx.scene.layout.Pane;
import javafx.scene.paint.Color;
import javafx.scene.shape.Circle;
import javafx.scene.shape.Line;
import javafx.scene.text.Text;
public class ClockPane extends Pane {
private int hour;
private int minute;
private int second;
private double w = 250, h = 250;
public ClockPane() {
setCurrentTime();
}
public ClockPane(int hour, int minute, int second) {
this.hour = hour;
this.min文章来源地址34654.htmlute = minute;
this.second = second;
paintClock();
}
public int getHour() {
return hour;
}
public void setHour(int hour) {
this.hour = hour;
paintClock();
}
public int getMinute() {
return minute;
}
public void setMinute(int minute) {
this.minute = minute;
paintClock();
}
public int getSecond() {
return second;
}
public void setSecond(int second) {
this.second = second;
paintClock();
}
public double getW() {
return w;
}
public void setW(double w) {
this.w = w;
paintClock();
}
public double getH() {
return h;
}
public void setH(double h) {
this.h = h;
paintClock();
}
public void setCurrentTime() {
Calendar calendar = new GregorianCalewww.yii666.comndar();
this.hour = calendar.get(Calendar.HOUR_OF_DAY);
this.minute = calendar.get(Calendar.MINUTE);
this.second = calendar.get(Calendar.SECOND);
paintClock();
}
protected void paintClock() {
double clockRadius = Math.min(w,h)*0.8*0.5;
double centerX = w/2;
double centerY = h/2;
Circle circle = new Circle(centerX, centerY, clockRadius);
circle.setFill(Color.WHITE);
circle.setStroke(Color.BLACK);
Text t1 = new Text(centerX-5, centerY-clockRadius+12,"12");
Text t2 = new Text(centerX-clockRadius+3, centerY +5, "9");
Text t3 = new Text(centerX+clockRadius-10, centerY+3, "3");
Text t4 = new Text(centerX-3, centerY+clockRadius-3,"6");
double sLength = clockRadius * 0.8;
double secondX = centerX + sLength * Math.sin(second * (2 * Math.PI / 60));
double secondY = centerY - sLength * Math.cos(second * (2 * Math.PI / 60));
Line sLine = new Line(centerX, centerY, secondX, secondY);
sLine.setStroke(Color.GRAY);
double mLength = clockRadius * 0.65;
double minuteX = centerX + mLength * Math.sin(minute * (2 * Math.PI / 60));
double minuteY = centerY - mLength * Math.cos(minute * (2 * Math.PI / 60));
Line mLine = new Line(centerX, centerY, minuteX, minuteY);
mLine.setStroke(Color.BLUE);
double hLength = clockRadius * 0.5;
double hourX = centerX + hLength *
Math.sin((hour % 12 + minute / 60.0) * (2 * Math.PI / 12));
double hourY = centerY - hLength *
Math.cos((hour % 12 + minute / 60.0) * (2 * Math.PI / 12));
Line hLine = new Line(centerX, centerY, hourX, hourY);
sLine.setStroke(Color.GREEN);
getChildren().clear();
getChildren().addAll(circle, t1, t2, t3, t4, sLine, mLine, hLine);
}
}
来源于:[JavaFX] 绘制简易时钟(二)