基于JavaScript实现网红太空人表盘的完整代码

一、效果展示

用javascript写的一个太空人表盘。

http://xiazai.jb51.net/202103/yuanma/Watch_jb51.rar

二、源代码

html代码

<html>
<head>
 <title>太空人表盘</title>
 <meta charset="UTF-8">
 <link href="./assets/css/style.css" rel="external nofollow" rel="stylesheet">
 <script src="./assets/js/timeGeneration.js"></script>
</head>
<body>
<div class="jun-meter">
 <div class="jun-time-h-h" id="hh"></div>
 <div class="jun-time-h-l" id="hl"></div>
 <div class="jun-time-rect"></div>
 <div class="jun-human"></div>
 <div class="jun-time-m-h" id="mh"></div>
 <div class="jun-time-m-l" id="ml"></div>
 <div class="jun-time-s-h" id="sh"></div>
 <div class="jun-time-s-l" id="sl"></div>
 <div class="jun-date" id="date"></div>
 <div class="jun-calendar-date" id="calendarDate"></div>
</div>
</body>

<script>

 function WatchMeter() {
  // 初始化dom
  this._initDom()
  // 更新
  this.update()

  this.date = new TimeGeneration()

  this._render(this.date.getDate(), this.date.getCalendarDate(), this.date.getTime())

 }

 // 修改原型
 WatchMeter.prototype = {
  constructor: WatchMeter,
  // 初始化Dom
  _initDom: function () {
   this.elem = {}
   this.elem.hh = document.getElementById('hh')
   this.elem.hl = document.getElementById('hl')
   this.elem.mh = document.getElementById('mh')
   this.elem.ml = document.getElementById('ml')
   this.elem.sh = document.getElementById('sh')
   this.elem.sl = document.getElementById('sl')
   this.elem.date = document.getElementById('date')
   this.elem.calendarDate = document.getElementById('calendarDate')
  },

  // 更新
  update: function () {
   var _this = this
   setInterval(function () {
    _this._render(_this.date.getDate(), _this.date.getCalendarDate(), _this.date.getTime())
   }, 1000)
  },

  // 渲染
  _render: function (date, calendarDate, time) {
   this._setNumberImage(this.elem.hh, time[0])
   this._setNumberImage(this.elem.hl, time[1])
   this._setNumberImage(this.elem.mh, time[2])
   this._setNumberImage(this.elem.ml, time[3])
   this._setNumberImage(this.elem.sh, time[4])
   this._setNumberImage(this.elem.sl, time[5])
   this.elem.date.innerText = date[2] + " " +date[0] + "-" +date[1]
   this.elem.calendarDate.innerText = calendarDate
  },

  // 设置数字图片
  _setNumberImage: function (elem, value) {
   elem.style.backgroundImage = "url(./assets/img/" + value + ".svg)";
  }
 }

 var myWatchMeter = new WatchMeter()
</script>

</html>

js代码

// 生成时间 农历 公历 时间
function TimeGeneration() {

}

TimeGeneration.prototype = {
 constructor: TimeGeneration,

 WEEKDAY_NAME: ["周日", "周一", "周二", "周三", "周四", "周五", "周六"],
 NUMBER_STRING: "一二三四五六七八九十",
 MONTH_STRING: "正二三四五六七八九十冬腊",
 MONTH_ADD: [0, 31, 59, 90, 120, 151, 181, 212, 243, 273, 304, 334],
 CALENDAR_DATA: [0xA4B, 0x5164B, 0x6A5, 0x6D4, 0x415B5, 0x2B6, 0x957, 0x2092F, 0x497, 0x60C96, 0xD4A, 0xEA5, 0x50DA9, 0x5AD, 0x2B6, 0x3126E, 0x92E, 0x7192D, 0xC95, 0xD4A, 0x61B4A, 0xB55, 0x56A, 0x4155B, 0x25D, 0x92D, 0x2192B, 0xA95, 0x71695, 0x6CA, 0xB55, 0x50AB5, 0x4DA, 0xA5B, 0x30A57, 0x52B, 0x8152A, 0xE95, 0x6AA, 0x615AA, 0xAB5, 0x4B6, 0x414AE, 0xA57, 0x526, 0x31D26, 0xD95, 0x70B55, 0x56A, 0x96D, 0x5095D, 0x4AD, 0xA4D, 0x41A4D, 0xD25, 0x81AA5, 0xB54, 0xB6A, 0x612DA, 0x95B, 0x49B, 0x41497, 0xA4B, 0xA164B, 0x6A5, 0x6D4, 0x615B4, 0xAB6, 0x957, 0x5092F, 0x497, 0x64B, 0x30D4A, 0xEA5, 0x80D65, 0x5AC, 0xAB6, 0x5126D, 0x92E, 0xC96, 0x41A95, 0xD4A, 0xDA5, 0x20B55, 0x56A, 0x7155B, 0x25D, 0x92D, 0x5192B, 0xA95, 0xB4A, 0x416AA, 0xAD5, 0x90AB5, 0x4BA, 0xA5B, 0x60A57, 0x52B, 0xA93, 0x40E95],

 _getBit: function (m, n) {
  return (m >> n) & 1;
 },

 // 获取时间 array
 getTime: function () {
  var time = new Date();
  return [parseInt(time.getHours() / 10),
   parseInt(time.getHours() % 10),
   parseInt(time.getMinutes() / 10),
   parseInt(time.getMinutes() % 10),
   parseInt(time.getSeconds() / 10),
   parseInt(time.getSeconds() % 10)]
 },

 // 获取公历日期 array
 getDate: function () {
  var date = new Date();
  return [
   date.getMonth() + 1,
   date.getDate(),
   this.WEEKDAY_NAME[date.getDay()]
  ]
 },

 // 获取农历日期 string
 getCalendarDate: function () {
  var calendar = new Date();
  var tmp = calendar.getFullYear();

  if (tmp < 1900) {
   tmp += 1900;
  }

  var total = (tmp - 1921) * 365 + Math.floor((tmp - 1921) / 4) + this.MONTH_ADD[calendar.getMonth()] + calendar.getDate() - 38;
  if (calendar.getFullYear() % 4 == 0 && calendar.getMonth() > 1) {
   total++;
  }

  var isEnd = false;
  var n, m, k
  for (m = 0; ; m++) {
   k = (this.CALENDAR_DATA[m] < 0xfff) ? 11 : 12;
   for (n = k; n >= 0; n--) {
    if (total <= 29 + this._getBit(this.CALENDAR_DATA[m], n)) {
     isEnd = true;
     break;
    }
    total = total - 29 - this._getBit(this.CALENDAR_DATA[m], n);
   }
   if (isEnd) break;
  }

  var month = k - n + 1;
  var day = total;

  if (k == 12) {
   if (month == Math.floor(this.CALENDAR_DATA[m] / 0x10000) + 1) {
    month = 1 - month;
   }
   if (month > Math.floor(this.CALENDAR_DATA[m] / 0x10000) + 1) {
    month--;
   }
  }

  var tmp = "";
  if (month < 1) {
   tmp += "(闰)";
   tmp += this.MONTH_STRING.charAt(-month - 1);
  } else {
   tmp += this.MONTH_STRING.charAt(month - 1);
  }

  tmp += "月";
  tmp += (day < 11) ? "初" : ((day < 20) ? "十" : ((day < 30) ? "廿" : "三十"));
  if (day % 10 != 0 || day == 10) {
   tmp += this.NUMBER_STRING.charAt((day - 1) % 10);
  }
  return tmp;
 }

}

CSS代码

.jun-meter {
 position: relative;
 width: 640px;
 height: 640px;
 background-image: url("../img/ring.svg");
 background-repeat: no-repeat;
 background-size: 100%;
 margin: auto;
 margin-top: 7%;
}

.jun-time-rect {
 position: absolute;
 width: 30px;
 height: 80px;
 left: 275px;
 top: 180px;
 background-image: url("../img/rect.svg");
 background-size: 40px 40px;
}

.jun-time-h-h {
 position: absolute;
 width: 100px;
 height: 100px;
 left: 140px;
 top: 170px;
 background-image: url("../img/8.svg");
 background-repeat: no-repeat;
 background-size: 100%;
}

.jun-time-h-l {
 position: absolute;
 width: 100px;
 height: 100px;
 left: 200px;
 top: 170px;
 background-image: url("../img/8.svg");
 background-repeat: no-repeat;
 background-size: 100%;
}

.jun-time-m-h {
 position: absolute;
 width: 100px;
 height: 100px;
 left: 290px;
 top: 170px;
 background-image: url("../img/8.svg");
 background-repeat: no-repeat;
 background-size: 100%;
}

.jun-time-m-l {
 position: absolute;
 width: 100px;
 height: 100px;
 left: 350px;
 top: 170px;
 background-image: url("../img/8.svg");
 background-repeat: no-repeat;
 background-size: 100%;
}

.jun-time-s-h {
 position: absolute;
 width: 60px;
 height: 60px;
 left: 430px;
 top: 208px;
 background-image: url("../img/8.svg");
 background-repeat: no-repeat;
 background-size: 100%;
}

.jun-time-s-l {
 position: absolute;
 width: 60px;
 height: 60px;
 left: 470px;
 top: 208px;
 background-image: url("../img/8.svg");
 background-repeat: no-repeat;
 background-size: 100%;
}

.jun-calendar-date {
 position: absolute;
 width: 120px;
 height: 30px;
 left: 460px;
 top: 310px;
 line-height: 30px;
 font-size: 20px;
 text-align: center;
}

.jun-date {
 position: absolute;
 width: 120px;
 height: 30px;
 left: 460px;
 top: 345px;
 line-height: 30px;
 font-size: 20px;
 text-align: center;
}

.jun-human{
 position: absolute;
 width: 150px;
 height: 150px;
 left: 250px;
 top: 280px;
 background-image: url("../img/human.gif");
 background-repeat: no-repeat;
 background-size: 100%;
}

到此这篇关于基于JavaScript实现网红太空人表盘的完整代码的文章就介绍到这了,更多相关JavaScript实现网红太空人表盘内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

时间: 2021-03-21

js canvas实现适用于移动端的百分比仪表盘dashboard

本文为大家分享了canvas实现适用于移动端的百分比仪表盘,供大家参考,具体内容如下 由于最近工作中,经常会遇到一些动态百分比的仪表盘,一开始都是用图片样式方式实现: 但是随着越来越多的项目,决定用canvas绘制一个简易的仪表盘,便于以后项目中直接使用: 现版本只是书写为方法形式,也许之后会有时间对其优化为插件形式. 简简单单而已,以下直接给出代码和执行过程中的三张截图: <!doctype html> <html lang="en"> <head>

js实现手表表盘时钟与圆周运动

苹果手表表盘时钟与js圆周运动 实现结果 需求分析: 1.时钟时间按照北京时间进行显示; 2.时针.分针.秒针按照时钟运转标准进行运转: 3.小球跟随秒表围绕表盘进行圆周运动. 代码分析 1.html结构:时针.分针.秒针.小球分别用一个div,将他们一起放到一个大的div中: 2.css样式:表盘布局多使用相对定位与绝对定位,将表针与各时刻标刻移动到特定的位置: 3.js行为:为了实现动态获取时间,可以使用var now=new Date(),再利用定时器setInterval,实现每经过1s

D3.js实现简洁实用的动态仪表盘的示例

本文介绍了D3.js实现简洁实用的动态仪表盘的示例,分享给大家,具体如下: 动态效果图: 仪表盘效果图 细看上面的动态效果图,可以发现: 一个值变换到一个新的值时,是一个渐变的过程: 圆弧末尾有一个竖线,作为仪表盘的指针,在仪表盘数值变化时,有一个弹性的动画效果. 一开始,我是用Echarts来实现仪表盘,但是它无法满足上面的两点需求.所以后来改成用D3.js. D3.js可以完美地实现图表的定制,从细节上,完美地满足我们的需求. 初始化仪表盘 1.首先定义一个svg元素: <svg id=&quo

JavaScript通如何过RGraph实现动态仪表盘

目前针对于统计图的制作方法有很多,可以直接利用快逸报表中的自带统计图,还可以通过自定义统计图个性化定制,当然除此之外,在新的HTML5标准中,新增了一个非常重要的元素-canvas元素.使用该元素,可以在页面中直接进行各种复杂图形的制作.因此,如果使用该元素绘制统计图,比之前使用服务器端控件来生成统计图的方法更加具有优越性,因为使用了该元素之后,绘制统计图的工作是直接在客户端进行的,而不再是在服务器端所完成的了.这不仅意味着不再占用服务器端的资源,而且意味着可以直接利用客户端计算机的强大资源,绘

js canvas仿支付宝芝麻信用分仪表盘

这是一个仿支付宝芝麻信用分的一个canvas,其实就是一个动画仪表盘. 首先, 上原图: 这个是在下支付宝上的截图,分低各位见笑了.然后看下我用canvas实现的效果图: <canvas id="canvas" width="400" height="700" data-score='724'></canvas> <!-- 设置data-score,分数区间[400, 900] --> 唉,总感觉不像.这个是G

Android自定义View仿支付宝芝麻信用分仪表盘

先看下iOS的芝麻信用分截图 这是我做的效果,还是有点差距的 支付宝9.9版本芝麻信用分的实现 首先初始化各种画笔,默认的size,padding,小圆点. (因为实在找不到原版芝麻信用的带点模糊效果的小圆点,所以只好用这个代替) //View的默认大小 defaultSize = dp2px(250); //默认Padding大小 arcDistance = dp2px(14); //外层圆环画笔 mMiddleArcPaint = new Paint(Paint.ANTI_ALIAS_FLA

iOS仿支付宝芝麻信用分数仪表盘动画效果

先看看效果图: 仪表盘动画效果.jpg 1.圆环上绿点的旋转 2.分数值及提示语的变化 3.背景色的变化 直接上主要代码: 1.自定义ZLDashboardView仪表盘文件: .h 文件: /** * 根据跃动数字 * * 确定百分比 * 现在的跳动数字-->背景颜色变化 * */ #import <UIKit/UIKit.h> @interface ZLDashboardView : UIView @property (nonatomic, strong) UIImage *bgIm

Android自定义view之仿支付宝芝麻信用仪表盘示例

自定义view练习 仿支付宝芝麻信用的仪表盘 对比图: 首先是自定义一些属性,可自己再添加,挺基础的,上代码 <?xml version="1.0" encoding="utf-8"?> <resources> <declare-styleable name="RoundIndicatorView"> <!--最大数值--> <attr name="maxNum" form

Android仿支付宝上芝麻信用分雷达图

一.首先看下支付宝上芝麻信用分的效果图: 二.思路 1.确定雷达图中心点坐标 2.绘制多边形及连接线 3.根据维度值绘制覆盖区域 4.绘制分数 5.绘制每个维度的标题文字和图标 三.实现 获取布局的中心坐标 在onSizeChanged(int w, int h, int oldw, int oldh)方法里面,根据View的长宽,计算出雷达图的半径(这里取布局宽高最小值的四分之一,可以自定义),获取整个布局的中心坐标. public class CreditScoreView extends

Java调用用户芝麻信用分

本文实例为大家分享了Java调用用户芝麻信用分的具体代码,供大家参考,具体内容如下 1.导入芝麻信用API:zmxy-sdk-java-20180824112425.jar 和 fastjson-1.2.48.jar 2.代码如下: package com.zhima; import java.net.URLDecoder; import java.util.HashMap; import java.util.Map; import java.util.UUID; import com.alib

JS+CSS实现仿支付宝菜单选中效果代码

本文实例讲述了JS+CSS实现仿支付宝菜单选中效果代码.分享给大家供大家参考.具体如下: 这是一个漂亮的JS+CSS仿支付宝菜单,总体风格和形式与支付宝的菜单没什么两样,细心会发现这是一个CSS爱好者自己手功完成的,自己美化图片,重写CSS代码,为作者给我们奉献这么好的菜单而表示感谢. 运行效果截图如下: 在线演示地址如下: http://demo.jb51.net/js/2015/js-css-f-alipay-style-menu-codes/ 具体代码如下: <!DOCTYPE html

JS 仿支付宝input文本输入框放大组件的实例

input输入的时候可以在后边显示数字放大镜 <!doctype html> <html lang="en"> <head> <meta charset="UTF-8"> <title>JS 仿支付宝input文本输入框放大组件</title> <script src="js/jquery.min.js"></script> <style>

Android仿支付宝笑脸刷新加载动画的实现代码

看到支付宝的下拉刷新有一个笑脸的动画,因此自己也动手实现一下.效果图如下: 一.总体思路 1.静态部分的笑脸. 这一部分的笑脸就是一个半圆弧,加上两颗眼睛,这部分比较简单,用于一开始的展示. 2.动态笑脸的实现. 2.1.先是从底部有一个圆形在运动,运动在左眼位置时把左眼给绘制,同时圆形继续运动,运动到右眼位置时绘制右眼,圆形继续运动到最右边的位置. 2.2.当上面的圆形运动到最右边时候,开始不断绘制脸,从右向左,脸不断增长,这里脸设置为接近半个圆形的大小. 2.3.当脸画完的时候,开始让脸旋转

angular仿支付宝密码框输入效果

项目需求,使用ng写一个密码框格子支付模块,一开始使用一个input+letter-spacing来分割字符,但是发现间距非常不好控制,随着字符的输入文本框字符串间距还会自动调整.最终从网上查找到一款jq仿支付宝密码输入框,于是我模仿编写了个指令模块. 效果如下: 完整代码如下: <!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8"> <met