javafx实现时钟效果

 更新时间:2020年11月15日 17:00:23   作者:一夜星尘  
这篇文章主要为大家详细介绍了javafx实现时钟效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了javafx实现时钟效果的具体代码,供大家参考,具体内容如下

核心为三个函数:

第一个为 public void dials,绘制表盘

第二个为 public void scale,绘制刻度,这里需要注意的是字体旋转

第三个为 public void point,绘制秒分时针以及打印时间,需要注意的是进制问题

总的源码如下:

package com.wu.demo;

import java.time.LocalDateTime;
import java.time.format.DateTimeFormatter;

import javafx.animation.KeyFrame;
import javafx.animation.Timeline;
import javafx.application.Application;
import javafx.collections.ObservableList;
import javafx.scene.Scene;
import javafx.scene.canvas.Canvas;
import javafx.scene.canvas.GraphicsContext;
import javafx.scene.layout.AnchorPane;
import javafx.scene.paint.Color;
import javafx.scene.paint.Paint;
import javafx.scene.text.Font;
import javafx.stage.Stage;
import javafx.util.Duration;

public class view extends Application{
 @Override
 public void start(Stage stage) throws Exception{
 AnchorPane root = new AnchorPane();
 Canvas canvas = new Canvas(800,650);
 root.getChildren().add(canvas);
 Scene scene = new Scene(root,800,650);
 stage.setScene(scene);
 stage.setResizable(false);
 stage.show();
 // 获取画板对象
 GraphicsContext gc = canvas.getGraphicsContext2D();
 // 创建时间轴
 Timeline timeLine = new Timeline();
 // 获取时间轴的帧列表
 ObservableList<KeyFrame> keyFrames = timeLine.getKeyFrames();
 // 添加关键帧
 keyFrames.add(new KeyFrame(Duration.seconds(0.1),e->{
 // 刷新操作
 gc.clearRect(0,0,800,650);
 // 绘制表盘
 dials(gc);
 // 绘制刻度
 scale(gc);
 // 绘制指针
 point(gc);
 }));
 // 设置时间轴播放次数为无限
 timeLine.setCycleCount(-1);
 // 播放时间轴
 timeLine.play();
 }
 /**
 * 绘制表盘
 * @param gc
 */
 public void dials(GraphicsContext gc) {
 // 保存现场
 gc.save();
 // 变换坐标到外切圆矩形左上角坐标
 gc.translate(100,25);
 gc.setLineWidth(8);
 gc.setStroke(Color.GRAY);
 gc.strokeOval(0, 0, 600, 600);
 gc.restore();
 }
 /**
 * 绘制刻度
 * @param gc
 */
 
 public void scale(GraphicsContext gc) {
 // 保存现场
 gc.save();
 // 变换坐标系原点到表盘中心
 gc.translate(400,325);
 // 坐标逆时针旋转角度-90
 gc.rotate(-90);
 // 设置字体大小
 gc.setFont(Font.font(20));
 for(int i = 1 ; i < 61 ; i++) {
 // 每一个刻度角度为6度
 gc.rotate(6);
 if(i % 5 == 0) {
 gc.save();
 // 当前坐标切换到 (250,0) 即刻度左边界位置
 gc.translate(250,0);
 // 设置表格数字位置 相对于桌面应该是竖直
 gc.rotate(90-i/5*30);
 gc.fillText(i/5+"",0,0);
 gc.restore();
 gc.fillRect(275,0,22,10);
 }
 else{
 gc.fillRect(285,0,12,5);
 }
 }
 // 恢复现场
 gc.restore();
 }
 /**
 * 绘制指针
 * @param gc
 */
 public void point(GraphicsContext gc) {
 LocalDateTime time = LocalDateTime.now();
 int seconds = time.getSecond();
 int minutes = time.getMinute();
 int hours = time.getHour();
 double[] pointX1 = new double[]{0,50,270,50};
 double[] pointY1 = new double[]{0,5,0,-5};
 double[] pointX2 = new double[]{0,30,210,30};
 double[] pointY2 = new double[]{0,10,0,-10};
 double[] pointX3 = new double[]{0,20,150,20};
 double[] pointY3 = new double[]{0,12,0,-12};
 gc.save();
 // 坐标移动至圆心
 gc.translate(400, 325);
 // 时间数字
 {
 String timeText1 = time.format(DateTimeFormatter.ofPattern("yyyy-MM-dd"));
 gc.setFill(Paint.valueOf("#c0c0c0"));
 gc.setFont(Font.font(20));
 gc.fillText(timeText1,-40,-200);
 String timeText2 = time.format(DateTimeFormatter.ofPattern("HH:mm:ss"));
 gc.setFill(Paint.valueOf("#c0c0c0"));
 gc.setFont(Font.font(115));
 gc.fillText(timeText2,-220,30);
 }
 // 秒钟
 {
 gc.save();
 gc.rotate(-90);
 gc.setFill(Color.RED);
 gc.rotate(seconds*6);
 // 四边形秒钟
 gc.fillPolygon(pointX1,pointY1, 4);
 gc.restore();
 }
 // 分钟
 {
 gc.save();
 gc.rotate(-90);
 gc.setFill(Color.BLUE);
 gc.rotate(minutes*6+0.1*seconds);
 // 四边形分钟
 gc.fillPolygon(pointX2,pointY2, 4);
 gc.restore();
 }
 // 时钟
 {
 gc.save();
 gc.rotate(-90);
 gc.setFill(Color.BLACK);
 gc.rotate(hours*30+minutes*0.5+seconds*(0.5/60));
 // 四边形时钟
 gc.fillPolygon(pointX3,pointY3, 4);
 gc.restore();
 }
 // 恢复现场
 gc.restore();
 
 }
 public static void main(String[] args) {
 launch(args);
 }
}


效果图:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • Spring在多线程环境下如何确保事务一致性问题详解

    Spring在多线程环境下如何确保事务一致性问题详解

    这篇文章主要介绍了Spring在多线程环境下如何确保事务一致性问题详解,说到异步执行,很多小伙伴首先想到Spring中提供的@Async注解,但是Spring提供的异步执行任务能力并不足以解决我们当前的需求,需要的朋友可以参考下
    2023-11-11
  • Java编程接口详细

    Java编程接口详细

    这篇文章主要小编主要给大家讲解的是Java编程中的接口,文章会从抽象类和抽象方法开始展开内容,感兴趣的小伙伴可以参考下面文章的具体内容
    2021-10-10
  • SpringBoot模板引擎之Thymeleaf的使用

    SpringBoot模板引擎之Thymeleaf的使用

    这篇文章主要介绍了SpringBoot模板引擎之Thymeleaf的使用,模板引擎是以业务逻辑层和表现层分离为目的的,将规定格式的模板代码转换为业务数据的算法实现,它可以是一个过程代码、一个类,甚至是一个类库,需要的朋友可以参考下
    2023-10-10
  • MybatisPlus调用原生SQL的实现方法

    MybatisPlus调用原生SQL的实现方法

    本文主要介绍了MybatisPlus调用原生SQL的实现方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-02-02
  • java中lambda表达式语法说明

    java中lambda表达式语法说明

    “Lambda 表达式”(lambda expression)是一个匿名函数,Lambda表达式基于数学中的λ演算得名,直接对应于其中的lambda抽象(lambda abstraction),是一个匿名函数,即没有函数名的函数。Lambda表达式可以表示闭包(注意和数学传统意义上的不同)。
    2016-09-09
  • Spring Boot中使用@Value加载配置的方法

    Spring Boot中使用@Value加载配置的方法

    @Value注解相信很多Spring Boot的开发者都已经有接触了,通过使用该注解,我们可以快速的把配置信息加载到Spring的Bean中,这篇文章主要介绍了为什么不推荐在SpringBoot中使用@Value加载配置,需要的朋友可以参考下
    2024-05-05
  • IDEA如何搭建Struts2项目

    IDEA如何搭建Struts2项目

    这篇文章主要介绍了IDEA如何搭建Struts2项目,文中通过图文介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-02-02
  • Java由浅入深讲解继承下

    Java由浅入深讲解继承下

    继承就是可以直接使用前辈的属性和方法。自然界如果没有继承,那一切都是处于混沌状态。多态是同一个行为具有多个不同表现形式或形态的能力。多态就是同一个接口,使用不同的实例而执行不同操作
    2022-04-04
  • java自定义异常以及throw和throws关键字用法

    java自定义异常以及throw和throws关键字用法

    这篇文章主要介绍了java自定义异常以及throw和throws关键字用法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-02-02
  • java如何对接企业微信的实现步骤

    java如何对接企业微信的实现步骤

    本文主要介绍了java如何对接企业微信的实现步骤,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-01-01

最新评论