网页自动显示时间的时钟

简介

用html,JavaScript完成一个简易的自走时钟
主要参考:https://www.cnblogs.com/lemoncool/p/8527334.html
该教程后期帮助较大,可以先试着自己做,遇到难题再看该教程,而且其讲解也比较细致。

设置画布

首先在html中设置一个画布。因为只是简单的一个画布,直接规定高宽即可。

<canvas id="clock" width="650" height="650" style="border:1px solid #d3d3d3;"></canvas>

画圆

笔者就以自己其中一个圆举例

	ctx.beginPath(); //开始绘画
    ctx.arc(0,0,300,0,2*Math.PI);
    ctx.fillStyle="#000000";
    ctx.fill(); //设置颜色后填充
    ctx.stroke(); //与beginPath()一起不可缺少
设置刻度和数字

该步是设置刻度,设置数字的时候可以运用圆的相关知识进行更快的设置,方法和思维差别不大就不列举出来了。

   function scale()
    {
    var i;
    for(i=0;i<360;i++)
    {
        if(i%6 === 0)
        {
            ctx.lineWidth=2;

            if(i%30 === 0)
                ctx.lineWidth = 8;

            ctx.beginPath();
            ctx.moveTo(0,-280);
            ctx.lineTo(0,-260);
            ctx.strokeStyle="#000000";
            ctx.stroke();

            ctx.beginPath();
            ctx.moveTo(0,260);
            ctx.lineTo(0,280);
            ctx.strokeStyle="#000000";
            ctx.stroke();

            ctx.rotate(6*Math.PI/180);
        }
    }
    }
定义指针如何走

该步的难题在于如何通过save()和restore()做到更新画布的效果从而达到更新指针位置实现自动走的效果。

 function Hour(hour)
    {
        ctx.save();
        ctx.beginPath();
        var rad = 2 * Math.PI / 12 * hour;
        ctx.lineWidth = 10;
        ctx.rotate(rad);
        ctx.moveTo(0,40);
        ctx.lineTo(0,-90);
        ctx.strokeStyle="#000000";
        ctx.stroke();
        ctx.restore();
    }
最后设置一个函数整合起来

其中setInterval(“draw()”,1000)是用来规定多久执行一次该函数,因为单位是ms,所以一秒更新一次就设置成1000。

    function draw()
    {
        ctx.clearRect(0, 0, 650, 650);
        var time = new Date();
        var hour = time.getHours();
        var minute = time.getMinutes();
        var second = time.getSeconds();
        circle();
        number();
        scale();
        Hour(hour);
        Minute(minute);
        Second(second);
        ctx.restore();
    }
    setInterval("draw()",1000);
效果如下

在这里插入图片描述

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在STM32上显示实时时钟时间,您需要使用STM32的RTC(实时时钟)模块来实现。以下是一些步骤: 1. 配置RTC时钟:使用RCC_AHB1PeriphClockCmd()函数使能RTC时钟 2. 初始化RTC模块:使用RTC_InitTypeDef结构体初始化RTC 3. 设置RTC时间:使用RTC_SetTime()函数设置RTC时间 4. 读取RTC时间:使用RTC_GetTime()函数读取RTC时间 5. 显示RTC时间:您可以使用LCD显示屏或者串口终端来显示RTC时间。如果您使用LCD显示屏,则需要使用相应的库函数来控制显示,如果您使用串口终端,则需要使用printf()函数将RTC时间打印到终端上。 下面是一个简单的代码示例,用于显示STM32的RTC实时时间: ``` #include "stm32f4xx.h" #include <stdio.h> void RTC_Config(void); int main(void) { RTC_TimeTypeDef RTC_TimeStruct; RTC_Config(); while(1) { RTC_GetTime(RTC_Format_BIN, &RTC_TimeStruct); printf("Current Time: %02d:%02d:%02d\n", RTC_TimeStruct.RTC_Hours, RTC_TimeStruct.RTC_Minutes, RTC_TimeStruct.RTC_Seconds); } } void RTC_Config(void) { RCC_APB1PeriphClockCmd(RCC_APB1Periph_PWR, ENABLE); PWR_BackupAccessCmd(ENABLE); RCC_LSEConfig(RCC_LSE_ON); while(RCC_GetFlagStatus(RCC_FLAG_LSERDY) == RESET); RCC_RTCCLKConfig(RCC_RTCCLKSource_LSE); RCC_RTCCLKCmd(ENABLE); RTC_InitTypeDef RTC_InitStruct; RTC_InitStruct.RTC_HourFormat = RTC_HourFormat_24; RTC_InitStruct.RTC_AsynchPrediv = 127; RTC_InitStruct.RTC_SynchPrediv = 255; RTC_Init(&RTC_InitStruct); RTC_TimeTypeDef RTC_TimeStruct; RTC_TimeStruct.RTC_Hours = 10; RTC_TimeStruct.RTC_Minutes = 30; RTC_TimeStruct.RTC_Seconds = 0; RTC_SetTime(RTC_Format_BIN, &RTC_TimeStruct); } ``` 请注意,这只是一个简单的示例代码,您需要根据自己的需求进行修改和调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值