工具 canvas 画时钟表

2024-02-12 14:44
文章标签 工具 canvas 钟表 画时

本文主要是介绍工具 canvas 画时钟表,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

自己写的工具,代码和Auto.js有差异
在这里插入图片描述

importClass(android.view.MotionEvent)
importClass(android.graphics.Paint)
importClass(java.util.TimeZone);
importClass(java.text.SimpleDateFormat);
ui.layout(
<vertical><text id="坐标1"/><text id="坐标2"/><canvas id="画布"h="1000"/>
</vertical>
);
// 初始化画笔
画时间=ui.画布.paint("#000000");
画时间.setTextSize(40);// 文字大小
画时间.setTextAlign(Paint.Align.CENTER);
画时间.setStyle(Paint.Style.FILL);// 填充
画表盘=ui.画布.paint("#000000");
画表盘.setTextSize(40);// 文字大小
画表盘.setStyle(Paint.Style.STROKE);//空心
画数字=ui.画布.paint("#000000");
画数字.setTextSize(40);// 文字大小
画数字.setStyle(Paint.Style.FILL);// 填充
画时针=ui.画布.paint("#ff0000");
画时针.setStyle(Paint.Style.FILL);// 填充
画分针=ui.画布.paint("#1976d3");
画分针.setStyle(Paint.Style.FILL);// 填充
画秒针=ui.画布.paint("#ffb806");
画秒针.setStyle(Paint.Style.FILL);// 填充画时刻=ui.画布.paint("#000000");
画时刻.setStrokeWidth(5);//设置画线宽度画秒刻=ui.画布.paint("#000000");
画秒刻.setStrokeWidth(2);//设置画线宽度
//画时刻.setTextAlign(Paint.Align.CENTER);
//画时刻.setStyle(Paint.Style.FILL);// 填充
// 计算时钟半径和指针长度
半径=300;
// 计算中心点坐标
中心x=540;
中心y=650;
setInterval(()=>{ui.画布.view.invalidate();
},1000);
ui.画布.onCanvas((canvas)=>{// 绘制表盘canvas.drawCircle(中心x,中心y,半径,画表盘);时钟(canvas,"12",0,-20,-10)时钟(canvas,"1",30,5,-10)时钟(canvas,"2",60,+15,0)时钟(canvas,"3",90,+10,+10)时钟(canvas,"4",120,5,25)时钟(canvas,"5",150,5,+35)时钟(canvas,"6",180,-10,40)时钟(canvas,"7",210,-20,35)时钟(canvas,"8",240,-30,20)时钟(canvas,"9",270,-30,17)时钟(canvas,"10",300,-45,-5)时钟(canvas,"11",330,-30,-10)刻度(canvas)时间()//canvas.drawText(小时+","+分钟+","+秒数,中心x,中心y,画时间);秒针(canvas);分针(canvas);时针(canvas);canvas.drawCircle(中心x,中心y,20,画时间);
})
//根据度数画数字 x y 偏移
function 时钟(canvas,sz,ds,x,y){let c=(中心x+半径*Math.sin(Math.toRadians(ds)));let d=(中心y-半径*Math.cos(Math.toRadians(ds)));canvas.drawText(sz,c+x,d+y,画数字);
}
function 刻度(canvas){//时刻度for(let i=0;i<360;i+=30){canvas.rotate(i,中心x,中心y);canvas.drawLine(中心x,中心y-半径,中心x,中心y-半径*0.9,画时刻);canvas.rotate(-(i),中心x,中心y);}//秒刻度for(let i=0;i<360;i+=6){canvas.rotate(i,中心x,中心y);canvas.drawLine(中心x,中心y-半径,中心x,中心y-半径*0.95,画秒刻);canvas.rotate(-(i),中心x,中心y);}
}
function 秒针(canvas){canvas.rotate(秒数*6,中心x,中心y);//canvas.drawLine(中心x,中心y-半径,中心x,中心y,画秒针);let 多边形=ui.画布.path()多边形.moveTo(中心x,中心y-半径);//尖多边形.lineTo(中心x+10,中心y-半径*0.8);//右下角多边形.lineTo(中心x,中心y);多边形.lineTo(中心x-10,中心y-半径*0.8);//左下角多边形.close();//闭合图形canvas.drawPath(多边形,画秒针);//三角形canvas.rotate(-(秒数*6),中心x,中心y);
}
function 分针(canvas,paint){canvas.rotate(分钟*6,中心x,中心y);//canvas.drawLine(中心x,中心y-半径*0.8,中心x,中心y,画分针);let 多边形=ui.画布.path()多边形.moveTo(中心x,中心y-半径*0.8);//尖多边形.lineTo(中心x+11,中心y-半径*0.6);//右下角多边形.lineTo(中心x,中心y);多边形.lineTo(中心x-11,中心y-半径*0.6);//左下角多边形.close();//闭合图形canvas.drawPath(多边形,画分针);//三角形canvas.rotate(-(分钟*6),中心x,中心y);
}
function 时针(canvas,paint){canvas.rotate(小时*30+(分钟*6/12),中心x,中心y);//canvas.drawLine(中心x,中心y-半径/2,中心x,中心y,画时针);let 多边形=ui.画布.path()多边形.moveTo(中心x,中心y-半径/2);//尖多边形.lineTo(中心x+12,中心y-半径*0.35);//右下角多边形.lineTo(中心x,中心y);多边形.lineTo(中心x-12,中心y-半径*0.35);//左下角多边形.close();//闭合图形canvas.drawPath(多边形,画时针);//三角形canvas.rotate(-(小时*30),中心x,中心y);
}
let 小时=2,分钟=25,秒数=0
function 时间(){let mydate=new java.util.Date();小时=mydate.getHours();分钟=mydate.getMinutes();秒数=mydate.getSeconds();
}
let sz=0
/*
ui.画布.onTouchEvent((event)=>{sz=event.getPointerCount();let action=event.getAction();switch(action){case MotionEvent.ACTION_DOWN://按下break;case MotionEvent.ACTION_MOVE://拖动for(let i=0;i <sz;i++){let id=event.getPointerId(i);let x=event.getX(i);let y=event.getY(i);if(id==0){ui.坐标1.setText("手指1="+parseInt(x)+","+parseInt(y))}else{ui.坐标2.setText("手指2="+parseInt(x)+","+parseInt(y))}};break;case MotionEvent.ACTION_UP://弹起break;}
})
*/

这篇关于工具 canvas 画时钟表的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/702802

相关文章

Python使用FFmpeg实现高效音频格式转换工具

《Python使用FFmpeg实现高效音频格式转换工具》在数字音频处理领域,音频格式转换是一项基础但至关重要的功能,本文主要为大家介绍了Python如何使用FFmpeg实现强大功能的图形化音频转换工具... 目录概述功能详解软件效果展示主界面布局转换过程截图完成提示开发步骤详解1. 环境准备2. 项目功能结

Linux系统之stress-ng测压工具的使用

《Linux系统之stress-ng测压工具的使用》:本文主要介绍Linux系统之stress-ng测压工具的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、理论1.stress工具简介与安装2.语法及参数3.具体安装二、实验1.运行8 cpu, 4 fo

Maven项目中集成数据库文档生成工具的操作步骤

《Maven项目中集成数据库文档生成工具的操作步骤》在Maven项目中,可以通过集成数据库文档生成工具来自动生成数据库文档,本文为大家整理了使用screw-maven-plugin(推荐)的完... 目录1. 添加插件配置到 pom.XML2. 配置数据库信息3. 执行生成命令4. 高级配置选项5. 注意事

Python使用pynput模拟实现键盘自动输入工具

《Python使用pynput模拟实现键盘自动输入工具》在日常办公和软件开发中,我们经常需要处理大量重复的文本输入工作,所以本文就来和大家介绍一款使用Python的PyQt5库结合pynput键盘控制... 目录概述:当自动化遇上可视化功能全景图核心功能矩阵技术栈深度效果展示使用教程四步操作指南核心代码解析

如何基于Python开发一个微信自动化工具

《如何基于Python开发一个微信自动化工具》在当今数字化办公场景中,自动化工具已成为提升工作效率的利器,本文将深入剖析一个基于Python的微信自动化工具开发全过程,有需要的小伙伴可以了解下... 目录概述功能全景1. 核心功能模块2. 特色功能效果展示1. 主界面概览2. 定时任务配置3. 操作日志演示

使用Python和Tkinter实现html标签去除工具

《使用Python和Tkinter实现html标签去除工具》本文介绍用Python和Tkinter开发的HTML标签去除工具,支持去除HTML标签、转义实体并输出纯文本,提供图形界面操作及复制功能,需... 目录html 标签去除工具功能介绍创作过程1. 技术选型2. 核心实现逻辑3. 用户体验增强如何运行

Python使用Turtle实现精确计时工具

《Python使用Turtle实现精确计时工具》这篇文章主要为大家详细介绍了Python如何使用Turtle实现精确计时工具,文中的示例代码讲解详细,具有一定的借鉴价值,有需要的小伙伴可以参考一下... 目录功能特点使用方法程序架构设计代码详解窗口和画笔创建时间和状态显示更新计时器控制逻辑计时器重置功能事件

利用Python实现Excel文件智能合并工具

《利用Python实现Excel文件智能合并工具》有时候,我们需要将多个Excel文件按照特定顺序合并成一个文件,这样可以更方便地进行后续的数据处理和分析,下面我们看看如何使用Python实现Exce... 目录运行结果为什么需要这个工具技术实现工具的核心功能代码解析使用示例工具优化与扩展有时候,我们需要将

Python+PyQt5实现文件夹结构映射工具

《Python+PyQt5实现文件夹结构映射工具》在日常工作中,我们经常需要对文件夹结构进行复制和备份,本文将带来一款基于PyQt5开发的文件夹结构映射工具,感兴趣的小伙伴可以跟随小编一起学习一下... 目录概述功能亮点展示效果软件使用步骤代码解析1. 主窗口设计(FolderCopyApp)2. 拖拽路径

MySQL Workbench工具导出导入数据库方式

《MySQLWorkbench工具导出导入数据库方式》:本文主要介绍MySQLWorkbench工具导出导入数据库方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝... 目录mysql Workbench工具导出导入数据库第一步 www.chinasem.cn数据库导出第二步