JavaFX实现简易时钟效果

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

首先要在面板中显示一个时钟,我们可以设计一个ClockPane类来显示一个时钟。

最终效果:

若要绘制一个时钟,需要绘制一个圆并为秒钟、分钟和小时绘制三个指针。为了画一个指针,需要确定一条直线的两端:一端是时钟的中央,位于(centerX,centerY);另外一端位于(endX,endY),由一下公式来确定:

endX=centerX+handLength×sin(θ)
endY=centerY-handLength×cos(θ)
(其中θ是指针和竖直方向12点的夹角)

因为一分钟有60秒,所以第2个指针的角度是:second×(2π/60)
分钟的位置由分钟和秒钟来决定。包含秒数的确切分钟数是minu+second/60。例如,如时间是3分30秒,那么总的分钟数就是3.5。由于一小时有60分钟,因此分针的角度是: (minute+second/60)×(2π/12)

由于一个圆被分为12个小时,所以时针的角度是: (hour+minute/60+second/(60×60))×(2π/12)

为了简化计算,在计算分针和时针角度的时候,可以忽略秒针,因为它们数字太小,基本可以忽略。因此,秒针、分针以及时针的端点可以如下计算:
secondX = centerX + secondHandLength × sin(second × (2π/60))
secondY = centerY - secondHandLength × cos(second × (2π/60))
minuteX = centerX + minuteHandLength × sin(minute × (2π/60))
minuteY = centerY - minuteHandLength × cos(minute × (2π/60))
hourX = centerX + hourHandLength × sin((hour+minute/60) × (2π/12))
hourX = centerX + hourHandLength × sin((hour+minute/60) × (2π/12))

这样就得到了ClockPane类的实现程序:

package com.company;

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;
 private double w=250,h=250;

 public ClockPane() {
  setCurrentTime();
 }

 public ClockPane(int hour,int minute,int second) {
  this.hour=hour;
  this.minute=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 GregorianCalendar();
  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 scondX=centerX+sLength*Math.sin(second*(2*Math.PI/60));
  double scondY=centerY-sLength*Math.cos(second*(2*Math.PI/60));
  Line sline=new Line(centerX,centerY,scondX,scondY);
  sline.setStroke(Color.RED);

  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)*(2*Math.PI/12));
  Line hline=new Line(centerX,centerY,hourX,hourY);
  hline.setStroke(Color.GREEN);

  getChildren().clear();
  getChildren().addAll(circle,t1,t2,t3,t4,sline,mline,hline);

 }
}

对程序的简要解读:①Java API的GregorianCalendar类可以使用它的无参构造方法来商城一个具有当前时间的Calendar实例。可以从一个Calendar对象,通过调用它的get(Calendar.HOUR)、get(Calendar.MINUTE)和get(Calendar.SECOND)方法来返回小时、分钟以及秒钟。②因为paintClock()方法在任何一个新的属性(hour、minute、second、w以及h)被设置的时候调用,所以之前的内容从面板中被清除。

然后就需要设计一个ClockAnimation类来显示时钟的动画

Timeline类可以用于通过使用一个或者更多的KeyFrame(关键帧)来编写任意动画。
你可以用Timeline来控制时钟的重绘,代码如下:

package com.company;

import javafx.animation.Timeline;
import javafx.application.Application;
import javafx.geometry.Pos;
import javafx.scene.Scene;
import javafx.scene.layout.BorderPane;
import javafx.stage.Stage;
import javafx.util.Duration;
import javafx.event.ActionEvent;
import javafx.event.EventHandler;
import javafx.animation.KeyFrame;
import javafx.scene.control.Label;

public class ClockAnimation extends Application {
 @Override
 public void start(Stage primaryStage) {
  ClockPane clock=new ClockPane();
  BorderPane borderPane=new BorderPane();

  EventHandler<ActionEvent> eventHandler=e -> {
   clock.setCurrentTime();
   String timeString=clock.getHour()+":"+clock.getMinute()+":"+clock.getSecond();
   Label lblCurrentTime=new Label(timeString);
   borderPane.setCenter(clock);
   borderPane.setBottom(lblCurrentTime);
   BorderPane.setAlignment(lblCurrentTime, Pos.TOP_CENTER);
  };

  Timeline animation=new Timeline(new KeyFrame(Duration.millis(1000),eventHandler));
  animation.setCycleCount(Timeline.INDEFINITE);
  animation.play();

  Scene scene=new Scene(borderPane,250,250);
  primaryStage.setTitle("ClockAnimation");
  primaryStage.setScene(scene);
  primaryStage.show();

  borderPane.widthProperty().addListener(ov ->
   clock.setW(borderPane.getWidth())
  );

  borderPane.heightProperty().addListener(ov ->
   clock.setH(borderPane.getHeight())
  );
 }
}

程序简单解读:①在时间线动画的每个关键帧中,这个处理器每秒被调用一次。所以动画中的时间每秒被更新一次。②最后两个监听器是用来修改时钟的面板的大小的,将这个监听器和窗体的宽度和高度属性进行注册,从而在场景的宽度和高度改变的情况下可以重新设置面板大小。代码保证了时钟面板的大小和场景大小是同步的。

最后运行就能达到上面图所示的效果了。

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

(0)

相关推荐

  • Java编程小实例—数字时钟的实现代码示例

    本文的实例是Java编程实现一个数字时钟,代码测试可用,练练手吧.代码如下: package me.socketthread; import java.awt.Color; import java.awt.Dimension; import java.awt.Font; import java.awt.Graphics; import java.awt.Graphics2D; import java.util.Calendar; import java.util.GregorianCalenda

  • javafx实现时钟效果

    本文实例为大家分享了javafx实现时钟效果的具体代码,供大家参考,具体内容如下 核心为三个函数: 第一个为 public void dials,绘制表盘 第二个为 public void scale,绘制刻度,这里需要注意的是字体旋转 第三个为 public void point,绘制秒分时针以及打印时间,需要注意的是进制问题 总的源码如下: package com.wu.demo; import java.time.LocalDateTime; import java.time.format

  • Java实现动态数字时钟

    本文实例为大家分享了Java实现动态数字时钟的具体代码,供大家参考,具体内容如下 构建: Clock继承 JFrame 为运行页面 ClockText 测试类 创建 Clock 对象 运行效果: 具体实现: 一.Clock类 四个JPnal 三个放时间 最后一个放日期 放时间的三个JPnal 分别加入 地点 时间 按钮 最后一个按钮添加日期 具体实现如下: public class Clock extends JFrame { private JPanel jPanelBeijing; priv

  • Java实现的简单数字时钟功能示例

    本文实例讲述了Java实现的简单数字时钟功能.分享给大家供大家参考,具体如下: 应用名称:Java数字时钟 用到的知识:Java GUI编程,线程 开发环境:win8+eclipse+jdk1.8 功能说明:可以显示当前系统的年月日.星期以及准确时间,并实时更新显示. 效果图: 源代码: import javax.swing.JFrame; import javax.swing.JPanel; import java.awt.BorderLayout; import javax.swing.JL

  • java实现时钟效果

    本文实例为大家分享了java实现时钟效果的具体代码,供大家参考,具体内容如下 实现效果如图: Java代码: 文件一:ClockPanel.java import static java.util.Calendar.HOUR; import static java.util.Calendar.MILLISECOND; import static java.util.Calendar.MINUTE; import static java.util.Calendar.SECOND; import j

  • Java实现动态模拟时钟

    本文实例为大家分享了java动态模拟时钟的具体代码,供大家参考,具体内容如下 应用名称:java动态模拟时钟 用到的知识:javaGUI,java 绘图 开发环境:win10+eclipse+jdk1.8 功能说明:通过java绘图画出一个虚拟的动态时钟 效果图: 源代码: import javax.swing.*; import java.awt.*; import java.util.*; import java.lang.Thread; import java.text.DecimalFo

  • Java实现的动态数字时钟功能示例【显示世界时间】

    本文实例讲述了Java实现的动态数字时钟功能.分享给大家供大家参考,具体如下: 构建: 1. Clock继承 JFrame 为运行页面 2. ClockText 测试类 创建 Clock 对象 运行效果: 具体实现: 一.Clock类  四个JPnal 三个放时间 最后一个放日期 放时间的三个JPnal 分别加入 地点 时间 按钮 最后一个按钮添加日期 具体实现如下: public class Clock extends JFrame { private JPanel jPanelBeijing

  • java多线程编程制作电子时钟

    模拟一个电子时钟,它可以在任何时候被启动或者停止,并可以独立的运行. 1.定义一个Clock类.它继承Label类,并实现Runnable接口.这个类中有一个Thread类型的clocker域,以及start()和run()方法.在run()方法中,每隔一秒就把系统时间显示为label的文本. class Clock extends Label implements Runnable { //定义Thread类型的clocker域 public Thread clocker=null; publ

  • java实现动态时钟并设置闹钟功能

    本文实例为大家分享了java实现动态时钟设置闹钟功能,供大家参考,具体内容如下 显示如上图所示的动态时钟,并且可以设置闹钟,播放mp3. 首先用到的是时钟(Timer)和日历(Calendar)得到系统的当前时间. 代码如下: import java.awt.Graphics; import java.awt.Graphics2D; import java.awt.geom.Ellipse2D; import java.awt.geom.Line2D; import java.io.Buffer

  • JavaFX实现简易时钟效果(二)

    本文实例为大家分享了JavaFX实现简易时钟效果的具体代码,供大家参考,具体内容如下 在前一篇博客中,我们已经绘制了一个静止时钟. 绘制简易时钟(一) 首先进行一个微调:让表盘根据窗口大小自动调整大小: 在 ShowClock.start() 中,添加对面板长宽的监听. pane.widthProperty().addListener(ov -> clock.setW(pane.getWidth())); pane.heightProperty().addListener(ov -> cloc

  • JavaFX实现简易时钟效果(一)

    本文实例为大家分享了JavaFX实现简易时钟效果的具体代码,供大家参考,具体内容如下 效果图 用当前时间创建时钟,绘制表盘. 钟表是静止的.让指针动起来,请参照:绘制简易时钟(二) 主函数文件 ShowClock: package primier; import javafx.application.Application; import javafx.geometry.Insets; import javafx.geometry.Pos; import javafx.scene.Scene;

  • JavaFX实现简易时钟效果

    本文实例为大家分享了JavaFX实现简易时钟效果的具体代码,供大家参考,具体内容如下 首先要在面板中显示一个时钟,我们可以设计一个ClockPane类来显示一个时钟. 最终效果: 若要绘制一个时钟,需要绘制一个圆并为秒钟.分钟和小时绘制三个指针.为了画一个指针,需要确定一条直线的两端:一端是时钟的中央,位于(centerX,centerY):另外一端位于(endX,endY),由一下公式来确定: endX=centerX+handLength×sin(θ) endY=centerY-handLe

  • vue2实现简易时钟效果

    本文实例为大家分享了vue2实现简易时钟效果的具体代码,供大家参考,具体内容如下 1.vue2+纯css实现 预览效果: 2.代码如下: <template>     <div class="main">         <div class="time">             <div class="hour_wrap">                 <div class="

  • 一个简易时钟效果js实现代码

    本文实例为大家分享了js时钟特效 的具体代码,供大家参考,具体内容如下 js代码 var canvas = document.getElementById("clock"); var clock = canvas.getContext("2d"); function zhong() { clock.save(); //开始画外层圆 clock.translate(200, 200); clock.strokeStyle = 'black'; clock.lineWi

  • Qt实现简易时钟

    本文实例为大家分享了Qt实现简易时钟展示的具体代码,供大家参考,具体内容如下 一.效果展示 简单实现时钟(圆盘+QLCDNumber),大小刻度,数字等. 二.实现 .pro QT += core gui greaterThan(QT_MAJOR_VERSION, 4): QT += widgets CONFIG += c++11 # The following define makes your compiler emit warnings if you use # any Qt featur

  • JavaFX实现简单日历效果

    本文实例为大家分享了JavaFX实现简单日历效果的具体代码,供大家参考,具体内容如下 1.先看效果: 2.代码: 1)ClockEdge.java类 这个类(Pane)主要是用来设置时钟边缘(为了美观对直了半天,其实想想也没必要~.~) package com.javaBasic.javaFX; import javafx.scene.layout.Pane; import javafx.scene.paint.Color; import javafx.scene.shape.Circle; i

  • JS实现的网页倒计时数字时钟效果

    本文实例讲述了JS实现的网页倒计时数字时钟效果.分享给大家供大家参考.具体实现方法如下: 复制代码 代码如下: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml&q

  • 使用JS显示倒计时数字时钟效果

    本文实例讲述了JS实现的网页倒计时数字时钟效果.分享给大家供大家参考.具体实现方法如下: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> &l

随机推荐