当前位置: 首页 > 编程笔记 >

Java实现动态模拟时钟

单淳
2023-03-14
本文向大家介绍Java实现动态模拟时钟,包括了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.DecimalFormat;
 
public class StillClock extends JPanel {
 
 /**
  * @param args
  */
 private int hour;
 private int minute;
 private int second;
  
 //构造函数
 public StillClock() {
  setCurrentTime();
 }
 
 //返回小时
 public int getHour() {
  return hour;
 }
  
  
 public int getMinute() {
  return minute;
 }
  
  
  
 public int getSecond() {
  return second;
 }
  
  
 //绘制时钟
 protected void paintComponent(Graphics g) {
   
  super.paintComponent(g);
  //初始化
  int clockRadius = (int)(Math.min(getWidth(), getHeight()) * 0.8 * 0.5);
  int xCenter = getWidth() / 2;
  int yCenter = getHeight() / 2;
  //画圆
  g.setColor(Color.black);
  g.drawOval(xCenter - clockRadius, yCenter - clockRadius, 2 * clockRadius, 2 * clockRadius);
  g.drawString("12", xCenter - 5, yCenter - clockRadius + 15);
  g.drawString("9", xCenter - clockRadius + 3, yCenter + 5);
  g.drawString("3", xCenter + clockRadius - 10, yCenter + 3);
  g.drawString("6", xCenter - 3, yCenter + clockRadius - 3);
  //画秒针
  int sLength = (int)(clockRadius * 0.8);
  int xSecond = (int)(xCenter + sLength * Math.sin(second * (2 * Math.PI / 60)));
  int ySecond = (int)(yCenter - sLength * Math.cos(second * (2 * Math.PI / 60)));
   
  g.setColor(Color.red);
  g.drawLine(xCenter, yCenter, xSecond, ySecond);
   
  //画分针
  int mLenth = (int)(clockRadius * 0.65);
  int xMinute = (int)(xCenter + mLenth * Math.sin(minute * (2 * Math.PI / 60)));
  int yMinute = (int)(xCenter - mLenth * Math.cos(minute * (2 * Math.PI / 60)));
  g.setColor(Color.blue);
  g.drawLine(xCenter, yCenter, xMinute, yMinute);
   
  //画时针
  int hLength = (int)(clockRadius * 0.5);
  int xHour = (int)(xCenter + hLength * Math.sin((hour % 12 + minute / 60.0) * (2 * Math.PI / 12)));
  int yHour = (int)(yCenter - hLength * Math.cos((hour % 12 + minute / 60.0) * (2 * Math.PI / 12)));
  g.setColor(Color.green);
  g.drawLine(xCenter, yCenter, xHour, yHour);
   
  //画数字时钟
  g.setColor(Color.black);
  DecimalFormat s=new DecimalFormat("00");
  g.drawString(s.format(getHour()) + ":" + s.format(getMinute()) + ":" + s.format(getSecond()), xCenter - 22, yCenter - clockRadius - 15);
   
 }
  
 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);
 }
  
  
 public static void main(String[] args) {
  // TODO Auto-generated method stub
  JFrame frame = new JFrame("DiaplayClock");
    frame.setResizable(false);
  frame.setTitle("DiaplayClock");
  frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
  frame.setSize(300,350);
  frame.setVisible(true);
   
  while(true) {
   StillClock clock = new StillClock();
   frame.getContentPane().add(clock);
   clock.setVisible(true);
   frame.validate();
   try {
    Thread.sleep(1000);
     
   }
   catch (InterruptedException e) {
    e.printStackTrace(); 
   }
   clock.setVisible(false);
   frame.remove(clock);
   clock = null;
   frame.validate();
    
  }
 
 }
}

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

 类似资料:
  • 本文向大家介绍Java实现动态数字时钟,包括了Java实现动态数字时钟的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了Java实现动态数字时钟的具体代码,供大家参考,具体内容如下 构建: Clock继承 JFrame 为运行页面 ClockText 测试类 创建 Clock 对象  运行效果: 具体实现: 一、Clock类 四个JPnal 三个放时间 最后一个放日期 放时间的三个JP

  • 本文向大家介绍Python爬虫实现模拟点击动态页面,包括了Python爬虫实现模拟点击动态页面的使用技巧和注意事项,需要的朋友参考一下 动态页面的模拟点击: 以斗鱼直播为例:http://www.douyu.com/directory/all 爬取每页的房间名、直播类型、主播名称、在线人数等数据,然后模拟点击下一页,继续爬取 代码如下 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多

  • 本文向大家介绍js实现动态时钟,包括了js实现动态时钟的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了js实现动态时钟的具体代码,供大家参考,具体内容如下 示例展示: 更多JavaScript时钟特效点击查看:JavaScript时钟特效专题 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持呐喊教程。

  • 本文向大家介绍javascript实现模拟时钟的方法,包括了javascript实现模拟时钟的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了javascript实现模拟时钟的方法。分享给大家供大家参考。具体实现方法如下: 希望本文所述对大家的javascript程序设计有所帮助。

  • 本文向大家介绍JS+CSS实现动态时钟,包括了JS+CSS实现动态时钟的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了JS+CSS实现动态时钟的具体代码,供大家参考,具体内容如下 知识点总结: document.querySelector()方法返回文档中匹配指定 CSS 选择器的一个元素。 setInterval() 方法可按照指定的周期(以毫秒计)来调用函数或计算表达式。 set

  • 本文向大家介绍Vue数据驱动模拟实现1,包括了Vue数据驱动模拟实现1的使用技巧和注意事项,需要的朋友参考一下 一、前言 Vue有一核心就是数据驱动(Data Driven),允许我们采用简洁的模板语法来声明式的将数据渲染进DOM,且数据与DOM是绑定在一起的,这样当我们改变Vue实例的数据时,对应的DOM元素也就会改变了。 如下: 当我们在chrome控制台,更改vm.name时,页面中的数据也

  • 本文向大家介绍Vue数据驱动模拟实现3,包括了Vue数据驱动模拟实现3的使用技巧和注意事项,需要的朋友参考一下 一、前言 在"模拟Vue之数据驱动2"中,我们实现了个Observer构造函数,通过它可以达到监听已有数据data中的所有属性。 但,倘若我们想在某个对象中,新增某个属性呢? 如下: 那么岂不是,新增的infor属性,以及它的对象属性,没有得到监听。 此时,应该怎么处理呢? 通过走读Vu

  • 本文向大家介绍Vue数据驱动模拟实现4,包括了Vue数据驱动模拟实现4的使用技巧和注意事项,需要的朋友参考一下 一、前言 在"模拟Vue之数据驱动3"中,我们实现了为每个对象扩展一个$set方法,用于新增属性使用,这样就可以监听新增的属性了。 当然,数组也是对象,也可以通过$set方法实现新增属性。 但是,对于数组而言,通常我们是通过push之类的方法吧。 PS:Vue中明确指出push、pop、