使用JavaFX在面板中显示一个小闹钟(DisplayClock)

1.ClockPane类

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;

import java.util.Calendar;
import java.util.GregorianCalendar;

public class ClockPane extends Pane {

    private int hour;
    private int minute;
    private int second;

    public ClockPane(){
        setCurrentTime();
    }

    public ClockPane(int hour,int minute,int second){
        this.hour = hour;
        this.minute = minute;
        this.second = second;
    }

    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 void setCurrentTime(){
        Calendar calendar = new GregorianCalendar();

        this.hour = calendar.get(Calendar.HOUR_OF_DAY);
        this.minute = calendar.get(Calendar.MINUTE);
        this.second = calendar.get(calendar.SECOND);

        paintClock();
    }

    private void paintClock(){
        double clockRadius = Math.min(getWidth(),getHeight())*0.8*0.5;
        double centerX = getWidth()/2;
        double centerY = getHeight()/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.RED);

        double mLength  = clockRadius*0.05;
        double xMinute = 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,xMinute,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);
        hLine.setStroke(Color.GREEN);
        getChildren().addAll(circle,t1,t2,t3,t4,sLine,mLine,hLine);
    }

    @Override
    public void setWidth(double width){
        super.setWidth(width);
        paintClock();
    }

    @Override
    public void setHeight(double height){
        super.setHeight(height);
        paintClock();
    }
}

2.DisplayClock类(JavaFX)

import javafx.application.Application;
import javafx.geometry.Pos;
import javafx.scene.Scene;
import javafx.scene.control.Label;
import javafx.scene.layout.BorderPane;
import javafx.stage.Stage;



public class DisplayClock extends Application {

    public static void main(String[] args) {
        launch(args);
    }

    @Override
    public void start(Stage primaryStage) {
        ClockPane clock = new ClockPane();
        String timeString = clock.getHour()+":"+clock.getMinute()+":"+clock.getSecond();
        Label lblCurrentTime = new Label(timeString);

        BorderPane pane = new BorderPane();
        pane.setCenter(clock);
        pane.setBottom(lblCurrentTime);
        BorderPane.setAlignment(lblCurrentTime, Pos.TOP_CENTER);

        Scene scene = new Scene(pane,250,250);
        primaryStage.setTitle("DisplayClock");
        primaryStage.setScene(scene);
        primaryStage.show();
    }
}
  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

xupengboo

你的鼓励将是我创作最大的动力。

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值