js Canvas实现的日历时钟案例有哪些

网上科普有关“js Canvas实现的日历时钟案例有哪些”话题很是火热,小编也是针对js Canvas实现的日历时钟案例有哪些寻找了一些与之相关的一些信息进行分析,如果能碰巧解...

网上科普有关“js Canvas实现的日历时钟案例有哪些 ”话题很是火热,小编也是针对js Canvas实现的日历时钟案例有哪些寻找了一些与之相关的一些信息进行分析 ,如果能碰巧解决你现在面临的问题,希望能够帮助到您。

一 、.获取上下文对象?

var cxt = document.getElementById(‘元素名’).getContect(‘2d’);?

IE8或更早的浏览器不支持元素 。

二、 drawClock() – 实现画时钟?

1. clearRect() 清空给定矩形内的指定像素。?

context.clearRect(x,y,width,height);

属性 | ?值

-----|------------

x,y | 要清除的矩形左上角点的(x,y)坐标

width,height| 要清除的矩形宽度和高度,单位为像素12345

2.new Date() — 得到系统时间

var sec = now.getSeconds(); ?var min = now.getMinutes(); ?var hour = now.getHours(); ?123

3.画时钟的形状

cxt.beginPath(); ?cxt.lineWidth = 10; ?cxt.strokeStyle = "blue"; ?cxt.arc(550, 310, 300, 0, 360, false); ?cxt.closePath(); ?cxt.stroke(); 123456

beginPath()的作用是canvas的绘制方法 ,都会以上一次beginPath之后的所有路径为基础进行绘制。

closepath()是关闭路径,而不是结束路径,它会试图从当前路径的终点连一条路径到七、起点 ,让整个路径闭合起来 。

cxt.lineWidth() : 画笔的宽度

cxt.strokeStyle() : 设置或返回用于笔触的颜色 、渐变或模式。

属性值:color 指示绘图笔触颜色的 CSS 颜色值。默认值是 #000000 。

gradient 用于填充绘图的渐变对象(线性或放射性)

pattern 用于创建 pattern 笔触的 pattern 对象

stroke ()绘制已定义的路径

arc() 方法创建弧/曲线(用于创建圆或部分圆) 。如需通过 arc() 来创建圆 ,请把起始角设置为 0,结束角设置为 2*Math.PI。?

context.arc(x,y,r,sAngle,eAngle,counterclockwise);

参数

描述

x 圆的中心的 x 坐标。

y 圆的中心的 y 坐标 。

r 圆的半径。

sAngle 起始角,以弧度计。(弧的圆形的三点钟位置是 0 度) 。

eAngle 结束角 ,以弧度计。

counterclockwise 可选。规定应该逆时针还是顺时针绘图 。False = 顺时针,true = 逆时针。

4)drawScale — 自定义函数画刻度

function drawScale(size, width, color, value, startx, starty, endx, endy){ ?

for(var i = 0; i < size; i++){ ?

drawPointer(width, color, value, i, startx, starty, endx, endy); ?

} ?} ?12345

5. 画时钟刻度依托点

function drawPointer(width, color, value, angle, startx, starty, endx, endy){ ?

cxt.save(); //先保存当前画布 ?

cxt.lineWidth = width; ?//设置画笔的宽度 ?

cxt.strokeStyle = color; //设置画笔的颜色 ?

cxt.translate(550, 310); //重置异次元空间的原点坐标 ?

cxt.rotate(value * angle * Math.PI / 180); ?//设置旋转的角度,参数是弧度 ?

cxt.beginPath(); ?

cxt.moveTo(startx, starty); ?

cxt.lineTo(endx, endy); ?

cxt.closePath(); //先闭合路径 ,再画线 ?

cxt.stroke(); ? //开始画线 ?

cxt.restore(); ?//将旋转后的线段返回给画布 ?} ?12345678910111213

translate() 方法重新映射画布上的 (0,0) 位置。

-

JS代码如下:

//获取上下文文档对象 ?var clock = document.getElementById('clock'); ?

var cxt = clock.getContext('2d'); ?

//画指针 ?function drawPointer(width, color, value, angle, startx, starty, endx, endy){ ?

cxt.save(); //先保存当前画布 ?

cxt.lineWidth = width; ?//设置画笔的宽度 ?

cxt.strokeStyle = color; //设置画笔的颜色 ?

cxt.translate(550, 310); //重置异次元空间的原点坐标 ?

cxt.rotate(value * angle * Math.PI / 180); ?//设置旋转的角度,参数是弧度 ?

cxt.beginPath(); ?

cxt.moveTo(startx, starty); ?

cxt.lineTo(endx, endy); ?

cxt.closePath(); //先闭合路径,再画线 ?

cxt.stroke(); ? //开始画线 ?

cxt.restore(); ?//将旋转后的线段返回给画布 ?} ?

//画刻度 ?function drawScale(size, width, color, value, startx, starty, endx, endy){ ?

for(var i = 0; i < size; i++){ ?

drawPointer(width, color, value, i, startx, starty, endx, endy); ?

} ?

} ?

//为表盘的中心填充颜色 ?function drawFill(){ ?

cxt.save(); ?

cxt.beginPath(); ?

cxt.arc(550, 310, 7, 0, 360, false); ?

cxt.closePath(); ?

cxt.fillStyle = "red"; ?

cxt.fill(); ?

cxt.restore(); ?

} ?

//画时钟 ?function drawClock(){ ?

cxt.clearRect(0, 0, 1350, 620); ?//清空整个画布 ?

var now = new Date(); //获取系统时间 ,取出时,分,秒 ?

var sec = now.getSeconds(); ?

var min = now.getMinutes(); ?

var hour = now.getHours(); ?

min += sec / 60; ?

hour += min / 60; ?

if(hour > 12) hour -= 12; ?

cxt.beginPath(); ?

cxt.lineWidth = 10; ?

cxt.strokeStyle = "blue"; ?

cxt.arc(550, 310, 300, 0, 360, false); ?

cxt.closePath(); ?

cxt.stroke(); ?

drawScale(12, 7, "pink", 30, 0, -280, 0, -260); ?//画时刻度 ?

drawScale(60, 5, "pink", 6, ?0, -280, 0, -270); ?//画分刻度 ?

drawPointer(7, "purple", hour, 30, 0, 12, 0, -210); ?//画时针 ?

drawPointer(5, "yellow", min, 6, 0, 15, 0, -240); //画分针 ?

drawPointer(4, "red", sec, 6, 0, 17, 0, -250); ? //画秒针 ?

//细化秒针,为秒针加箭头 ?

drawPointer(3, "red", sec, 6, -7, -235, 0, -255); ?

drawPointer(3, "red", sec, 6, 7, -235, 0, -255); ?

drawFill(); ?

} ?

drawClock(); ?

setInterval(drawClock, 1000); ? //setInterval()方法中表示每隔1000ms,就执行drawClock一次 ?1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071

关于“js Canvas实现的日历时钟案例有哪些”这个话题的介绍,今天小编就给大家分享完了 ,如果对你有所帮助请保持对本站的关注!

本文来自作者[任我上青云]投稿,不代表石号立场,如若转载,请注明出处:https://s0429.com/cshi/202512-2136.html

(114)

文章推荐

  • 31省新增8例本土(31省新增确诊11例 本土8例l)

    31个省区市新增确诊65例,其中本土病例8例均在云南个省区市新增确诊65例,其中本土病例8例均在云南。7月19日0—24时,31个省(自治区、直辖市)和新疆生产建设兵团报告新增确诊病例65例。新增确诊病例:31个省(自治区、直辖市)和新疆生产建设兵团报告新增确诊病例77例。境外输入病例:8例(福建

    2025年11月23日
    36
  • 天津现在能正常进出吗(天津现在可以出入吗?)

    天津可以进出吗现在1、综上所述,天津现在可以正常进出,但需遵守相关防疫和交通限行规定。请务必提前了解并遵守相关规定,确保行程顺利。2、综上所述,天津现在已经能够正常出入,人们可以在遵循相关防疫政策的前提下,自由地进出天津进行正常的社会活动。3、天津目前能正常出入。首先,天津整体处于常态化疫情防控阶

    2025年11月23日
    29
  • 长沙的疫情最新消息(长沙疫情最新进展)

    现在长沙哪里有疫情截止2022年12月11日,芙蓉区,岳麓区,天心区有有疫情。根据长沙最新疫情数据报告,2022年11月26日通报长沙芙蓉区在隔离管控人员中发现5例新冠病毒阳性感染者,11月26日通报长沙岳麓区在外省返长人员中检出2例新冠病毒肺炎阳性感染者,11月26日通报长沙天心区检出3例新冠病

    2025年11月24日
    29
  • 石家庄疫情最新消息今天封城了(石家庄疫情最新消息今天风险等级)

    石家庄是不是封城了1、返石大学生的回家难题交通封锁受阻:由于河北多条高速实行交通管制,石家庄客运总站及机场班车暂时停运,多个航空公司取消石家庄机场航班,全市所有车辆及人员均不得出市,高风险地区藁城区全区人员不得离开本区,导致外地返石大学生即便到达石家庄,也可能因交通封锁而滞留。2、石家庄封城了吗

    2025年11月24日
    35
  • 新疆确诊(新疆确诊新冠肺炎)

    新疆本轮疫情密切接触者多已发病,官方作出重要判断1、新疆本轮疫情密切接触者多已发病,官方初步判断现有医学观察人员中病例处于下降趋势。具体内容如下:密切接触者发病情况与疫情趋势判断:乌鲁木齐市疾控中心主任芮宝玲表示,此轮疫情传播的聚集性活动存在流行病学关联,结合暴露时间,密切接触者多已发病。目前可初

    2025年11月26日
    24
  • 太原新增4例阳性感染者(太原新增1例)

    山西超100名快递员感染,涉疫快件流到了哪些地方?月16日,据山西省太原市卫健委通告,4月14日18:00-15日18:00,太原市新增加本地诊断病案4例,新增加没有症状的病毒感染者25例,在其中17人为因素韵达物流职工。同一天,太原市疫情防控工作中记者招待会通告,截止到4月15日24时,清徐韵达

    2025年11月27日
    29
  • 关于科普的演讲稿初中生800字(关于科普的演讲稿初中生800字怎么写)

    防震减灾科普先行优秀演讲稿1、防震减灾科普先行优秀演讲稿篇1大家好!地震灾害是世界上造成人们经济损失最严重和人员伤亡最多的自然灾害之一。我们要加强对地震科普知识的学习,正确地掌握避震和自救、互救的方法。我们要听地震预告,学会看地震发生前的预兆,比如:动物们的异常惊飞、逃窜、狂叫等,也可以预防

    2025年12月04日
    12
  • 作家写动物的文章怎么写

    网上有关“作家写动物的文章怎么写”话题很是火热,小编也是针对作家写动物的文章怎么写寻找了一些与之相关的一些信息进行分析,如果能碰巧解决你现在面临的问题,希望能够帮助到您。小狮子爱尔莎[奥地利]乔伊·亚当逊小狮子爱尔莎出生才两三天,它的妈妈就死了。我从岩石缝里把它抱出来,抚摸它,喂它奶粉和用鱼肝油

    2024年12月15日
    32
  • 云南新增本土15例(云南新增本土15例病例)

    截至4月5日24时新型冠状病毒肺炎疫情最新情况1、现有疑似病例1例。累计追踪到密切接触者993919人,尚在医学观察的密切接触者7773人。无症状感染者情况:新增无症状感染者17例。境外输入15例。本土2例(均在云南)。当日转为确诊病例13例(境外输入1例)。当日解除医学观察4例(均为境外输入)。

    2025年11月25日
    35
  • 成都疫情防控(成都疫情防控新规)

    成都的疫情何时解封1、目前成都每日新增感染者数量呈下降趋势,但尚未完全达到上述标准。参考当前疫情形势,若后续无大规模反弹,理想状态下预计全面解封时间可能在9月20日左右,但具体日期需以官方最终通报为准。关于解封后跨区上班:若各行政区均达到解封条件(即社会面清零且无中高风险区域),居民可跨区正常通勤

    2025年12月01日
    9

发表回复

本站作者后才能评论

评论列表(4条)

  • 任我上青云
    任我上青云 2025年12月07日

    我是石号的签约作者“任我上青云”!

  • 任我上青云
    任我上青云 2025年12月07日

    希望本篇文章《js Canvas实现的日历时钟案例有哪些》能对你有所帮助!

  • 任我上青云
    任我上青云 2025年12月07日

    本站[石号]内容主要涵盖:国足,欧洲杯,世界杯,篮球,欧冠,亚冠,英超,足球,综合体育

  • 任我上青云
    任我上青云 2025年12月07日

    本文概览:网上科普有关“js Canvas实现的日历时钟案例有哪些”话题很是火热,小编也是针对js Canvas实现的日历时钟案例有哪些寻找了一些与之相关的一些信息进行分析,如果能碰巧解...