`

JavaFX学习之样例8

阅读更多
  该代码实现一个简单的时钟

 
package clock;

import java.util.Calendar;

import javafx.animation.Animation;
import javafx.animation.Interpolator;
import javafx.animation.KeyFrame;
import javafx.animation.KeyValue;
import javafx.animation.Timeline;
import javafx.beans.property.DoubleProperty;
import javafx.scene.Group;
import javafx.scene.control.Label;
import javafx.scene.shape.Circle;
import javafx.scene.shape.Line;
import javafx.scene.transform.Rotate;
import javafx.util.Duration;

/**
 * Displays an animated AnalogueClock face.
 * Time is the system time for the local timezone.
 * see: analogue-clock.css for css formatting rules for the clock.
 */
public class AnalogueClock extends Group {
  final int HOUR_HAND_LENGTH   = 50;
  final int MINUTE_HAND_LENGTH = 75;
  final int SECOND_HAND_LENGTH = 88;
  final int SECOND_HAND_OFFSET = 15;

  AnalogueClock(String brandName, double clockRadius) {
    setId("analogueClock");

    getStylesheets().add(
      ResourceResolver.getResourceFor(
        getClass(),
        "analogue-clock.css"
      )
    );

    // construct the analogueClock pieces.
    final Circle face       = createClockFace(clockRadius);  //钟表面
    final Label  brand      = createBrand(face, brandName);  //钟表名
    final Line   hourHand   = createHand(                    //钟时指针
      "hourHand",
      clockRadius,
      0,
      percentOf(HOUR_HAND_LENGTH, clockRadius)
    );
    final Line   minuteHand = createHand(                    //钟分指针
      "minuteHand",
      clockRadius,
      0,
      percentOf(MINUTE_HAND_LENGTH, clockRadius)
    );
    final Line   secondHand = createHand(                    //钟秒指针
      "secondHand",
      clockRadius,
      percentOf(SECOND_HAND_OFFSET, clockRadius),
      percentOf(SECOND_HAND_LENGTH, clockRadius)
    );

    // animate the hands with the time.
    bindClockHandsToTime(hourHand, minuteHand, secondHand);

    getChildren().addAll(
      face,
      brand,
      createTicks(clockRadius),
      createSpindle(clockRadius),
      hourHand,
      minuteHand,
      secondHand
    );
  }

  //创建12条时间线
  /** @return radial ticks around the clock center to mark time. */
  private Group createTicks(double clockRadius) {
    final double TICK_START_OFFSET = percentOf(83, clockRadius);
    final double TICK_END_OFFSET   = percentOf(93, clockRadius);

    final Group  ticks = new Group();
    for (int i = 0; i < 12; i++) {
      Line tick = new Line(0, -TICK_START_OFFSET, 0, -TICK_END_OFFSET);
      tick.getStyleClass().add("tick");
      tick.setLayoutX(clockRadius);
      tick.setLayoutY(clockRadius);
      tick.getTransforms().add(new Rotate(i * (360 / 12)));
      ticks.getChildren().add(tick);
    }
    return ticks;
  }

  //创建中心点
  /** @return a rendered spindle around which the clockwork rotates */
  private Circle createSpindle(double clockRadius) {
    final Circle spindle = new Circle(clockRadius,  clockRadius, 5);
    spindle.setId("spindle");
    return spindle;
  }

  //创建圆
  private Circle createClockFace(double clockRadius) {
    final Circle face = new Circle(clockRadius, clockRadius, clockRadius);
    face.setId("face");
    return face;
  }

   //创建时,分,秒钟指针 
  private Line createHand(String handId, double clockRadius, double handOffsetLength, double handLength) {
    final Line secondHand = new Line(0, handOffsetLength, 0, -handLength);
    secondHand.setLayoutX(clockRadius);
    secondHand.setLayoutY(clockRadius);
    secondHand.setId(handId);
    return secondHand;
  }

  //创建名字
  private Label createBrand(Circle face, String brandName) {
    final Label brand = new Label(brandName);
    brand.setId("brand");
    brand.layoutXProperty().bind(face.centerXProperty().subtract(brand.widthProperty().divide(2)));
    brand.layoutYProperty().bind(face.centerYProperty().add(face.radiusProperty().divide(2)));
    return brand;
  }

  //绑定时间
  private void bindClockHandsToTime(final Line hourHand, final Line minuteHand, final Line secondHand) {
    // determine initial rotation for the clock hands.
    Calendar time = Calendar.getInstance();
    final double initialHourhandDegrees   = calculateHourHandDegrees(time);
    final double initialMinuteHandDegrees = calculateMinuteHandDegrees(time);
    final double initialSecondHandDegrees = calculateSecondHandDegrees(time);

    // animate the clock movements using timelines.
    createRotationTimeline(              // the hour hand rotates twice a day.
        createRotate(hourHand, initialHourhandDegrees).angleProperty(),  //创建一个Rotate,并获取角度属性
        Duration.hours(12),
        initialHourhandDegrees
    );
    createRotationTimeline(              // the minute hand rotates once an hour.
        createRotate(minuteHand, initialMinuteHandDegrees).angleProperty(),
        Duration.minutes(60),
        initialMinuteHandDegrees
    );
    createRotationTimeline(              // move second hand rotates once a minute.
        createRotate(secondHand, initialSecondHandDegrees).angleProperty(),
        Duration.seconds(60),
        initialSecondHandDegrees
    );
  }

  private Rotate createRotate(Line hand, double initialHandDegrees) {
    final Rotate hourRotate = new Rotate(initialHandDegrees);
    hand.getTransforms().add(hourRotate);
    return hourRotate;
  }

  /**
   * Performs a 360 degree rotation of the angleProperty once in every duration.
   * rotation starts from initialRotation degrees.
   */
  private void createRotationTimeline(DoubleProperty angleProperty, Duration duration, double initialRotation) {
    
	  Timeline timeline = new Timeline(
      new KeyFrame(
        duration,
        new KeyValue(
          angleProperty,
          360 + initialRotation,  
          Interpolator.LINEAR
        )  //转一圈
      )
    );
    timeline.setCycleCount(Animation.INDEFINITE);
    timeline.play();
  }

  //获取当前秒占多少度(1秒占360/60度)
  private int calculateSecondHandDegrees(Calendar time) {
	System.out.println(time.get(Calendar.SECOND) * (360 / 60));
    return time.get(Calendar.SECOND) * (360 / 60);  
  }

  private double calculateMinuteHandDegrees(Calendar time) {
    return (time.get(Calendar.MINUTE) + calculateSecondHandDegrees(time) / 360.0) * (360 / 60);
  }

  private double calculateHourHandDegrees(Calendar time) {
    return (time.get(Calendar.HOUR)   + calculateMinuteHandDegrees(time) / 360.0) * (360 / 12);
  }

  private double percentOf(double percent, double clockRadius) {
    return percent / 100 * clockRadius;
  }
  
  public static void main(String args[]){
	  Calendar calendar = Calendar.getInstance();
  }
}

主要是该类实现时钟
其中,关于line的移动疑惑了好久,为什么围绕着中心点转,自己弄了个例子调试了下,原来line是围绕着layoutX,layoutY转,上面设置了line的layoutX,layoutY为中心点,所以就围绕着中心点转。
其主要就是给line添加一个rotate,然后rotate的angerProperty一直变化。


这里有个javafx学习的中文网站,我把内容都丢那上面去了。
http://www.jfxee.com/
  • 大小: 9.7 KB
分享到:
评论

相关推荐

    javafx2introbyexample:javaFX中的样例代码

    这个名为"javafx2introbyexample"的压缩包包含了《JavaFX 8: Introduction by Example》这本书的示例代码,这本书是学习JavaFX 8编程的一个很好的资源。以下是对这些示例代码所涉及知识点的详细解释: 1. **JavaFX...

    JavaFX2开发教程

    运行时还允许你体验官方提供的样例程序,这些样例展示了JavaFX的各种功能,源代码可供学习参考。 在NetBeans环境中配置JavaFX开发环境是另一个关键步骤。JavaFX2.0在Mac系统上的安装提供了更丰富的功能,如高性能...

    我的代码样例

    综上所述,这个压缩包“我的代码样例”提供了丰富的编程实践材料,覆盖了Java API的运用以及完整的图书管理系统开发,对于Java初学者和进阶者都有很大的学习价值。通过分析和学习这些代码,可以提升编程技巧,了解...

    javaFX2.0教程

    在学习JavaFX的过程中,不断尝试、运行样例和构建自己的项目对于掌握JavaFX是非常有帮助的。随着JavaFX 2.0的出现,开发者有了一个功能强大、跨平台的工具来创建高质量的桌面应用程序。通过本教程,你将能够学习到...

    GUI样例.7z

    总的来说,这个压缩包提供的GUI样例涵盖了基础界面设计、用户认证流程以及基本计算功能的实现,对于学习和掌握GUI编程,尤其是事件驱动编程和用户交互设计,具有很高的参考价值。通过分析和实践这些案例,开发者能够...

    java学习和项目中一些典型的应用场景样例代码.zip

    这个名为"java学习和项目中一些典型的应用场景样例代码.zip"的压缩包显然包含了一些Java编程的实际应用示例,旨在帮助学习者理解Java在实际项目中的运用。下面,我们将深入探讨Java的一些关键应用场景和相关知识点。...

    jfreechart样例

    学习和使用JFreeChart样例,你可以逐步理解JFreeChart库的工作原理,掌握创建各种复杂图表的方法,并在自己的项目中灵活运用。这对于任何需要在Java环境中处理数据可视化需求的开发者来说,都是一个非常宝贵的资源。

    JAVA作业目录及样例

    本资源“JAVA作业目录及样例”是针对学习Java编程的学生们提供的一份宝贵的参考资料,它包含了Java程序设计实验和半期考试的相关内容,帮助学生理解和实践Java的核心概念。 Java程序设计实验部分通常涉及基本语法、...

    Java-Learning:java学习样例代码

    【Java学习样例代码】是针对Java编程语言的学习资源,主要包含了各种Java编程示例,旨在帮助初学者或有经验的开发者深入理解Java语言的核心概念和技术。这些代码样例涵盖了从基础语法到高级特性的广泛内容,对于学习...

    e(fx)lipse

    6. **样例代码**:提供JavaFX示例代码,帮助开发者了解和学习JavaFX API的用法。 7. **语法高亮**:对JavaFX剧本语言(FXML)提供语法高亮和错误检查。 在安装了**e(fx)lipse** 的Eclipse中,用户可以通过“File” ...

    demo.rar_DEMO

    9. **Swing和JavaFX**:这两者是Java的GUI库,样例程序可能会创建窗口应用,展示按钮、文本框、菜单等组件的使用。 10. **反射和注解**:反射允许在运行时检查类的信息,注解提供元数据,样例程序会展示它们如何...

    基于智能家居,从客厅到卧室,从中控到sensor,开发者可以体验各种家居的开发样例,打造自己的家居体验,享受万物互联的快感。

    这里,我们主要关注的是基于Java的开发样例,如在"learn-java-master"这个项目中,开发者可以学习如何使用Java语言来实现智能家居系统的关键部分。 首先,让我们深入了解一下Java在智能家居中的应用。Java是一种...

    WebViewSample源码

    总结来说,`WebViewSample`源码是一个学习JavaFX如何集成Web内容的绝佳实例。通过对源码的深入理解和实践,开发者可以掌握如何在JavaFX应用程序中利用`WebView`组件展示丰富的Web内容,并实现与网页的交互。这不仅...

    21天精通java源代码

    11. **Swing与JavaFX**:这两个是Java的图形用户界面(GUI)工具包,用于创建桌面应用程序。 12. **Java EE**:如果深入学习,还会涉及Java企业版,如Servlet、JSP、EJB等,用于构建服务器端应用。 通过21天的系统...

    JAVA简单实例

    3. **封装**: 封装是面向对象编程的三大特性之一,它隐藏了对象的内部实现细节,只对外提供公共接口。通过访问修饰符(如public、private、protected),可以控制类成员的可见性。 4. **继承与多态**: 继承允许一个...

    desktop-project:样例项目Kelompok

    为了深入理解这个项目,你需要查看源代码,学习其中的类结构、方法实现以及如何通过JavaFX或Swing等库创建图形用户界面。同时,了解如何在Java中实现文件I/O操作,处理系统事件,以及可能涉及的网络通信(如果有的话...

    Jfreechart学习资源

    JFreeChart是一个强大的开源库,专门用于生成高质量的2D图表,适用于各种Java应用程序,包括Swing、JavaFX、Applet以及Servlet。本文将深入探讨JFreeChart的基础知识、主要功能以及如何使用它来创建各种类型的图表。...

    Chris-Heavner-Portfolio-1:代码样例

    8. **算法和数据结构**:Java是学习和实现算法的好工具,可能在这个项目中,我们能看到排序、搜索或其他算法的实现。 9. **并发编程**:Java提供了丰富的并发API,如线程、同步机制(synchronized关键字,wait/...

    java编程实例(精心整理百个实例)

    8. **图形用户界面(GUI)设计**:Java提供了丰富的Swing和JavaFX库来创建桌面应用。实例将教你如何使用组件(如按钮、文本框、标签等)构建用户界面,响应用户事件,并实现交互逻辑。 这个Java编程实例集合是深入...

Global site tag (gtag.js) - Google Analytics