工具 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

相关文章

高效录音转文字:2024年四大工具精选!

在快节奏的工作生活中,能够快速将录音转换成文字是一项非常实用的能力。特别是在需要记录会议纪要、讲座内容或者是采访素材的时候,一款优秀的在线录音转文字工具能派上大用场。以下推荐几个好用的录音转文字工具! 365在线转文字 直达链接:https://www.pdf365.cn/ 365在线转文字是一款提供在线录音转文字服务的工具,它以其高效、便捷的特点受到用户的青睐。用户无需下载安装任何软件,只

【Linux 从基础到进阶】Ansible自动化运维工具使用

Ansible自动化运维工具使用 Ansible 是一款开源的自动化运维工具,采用无代理架构(agentless),基于 SSH 连接进行管理,具有简单易用、灵活强大、可扩展性高等特点。它广泛用于服务器管理、应用部署、配置管理等任务。本文将介绍 Ansible 的安装、基本使用方法及一些实际运维场景中的应用,旨在帮助运维人员快速上手并熟练运用 Ansible。 1. Ansible的核心概念

超强的截图工具:PixPin

你是否还在为寻找一款功能强大、操作简便的截图工具而烦恼?市面上那么多工具,常常让人无从选择。今天,想给大家安利一款神器——PixPin,一款真正解放双手的截图工具。 想象一下,你只需要按下快捷键就能轻松完成多种截图任务,还能快速编辑、标注甚至保存多种格式的图片。这款工具能满足这些需求吗? PixPin不仅支持全屏、窗口、区域截图等基础功能,它还可以进行延时截图,让你捕捉到每个关键画面。不仅如此

PR曲线——一个更敏感的性能评估工具

在不均衡数据集的情况下,精确率-召回率(Precision-Recall, PR)曲线是一种非常有用的工具,因为它提供了比传统的ROC曲线更准确的性能评估。以下是PR曲线在不均衡数据情况下的一些作用: 关注少数类:在不均衡数据集中,少数类的样本数量远少于多数类。PR曲线通过关注少数类(通常是正类)的性能来弥补这一点,因为它直接评估模型在识别正类方面的能力。 精确率与召回率的平衡:精确率(Pr

husky 工具配置代码检查工作流:提交代码至仓库前做代码检查

提示:这篇博客以我前两篇博客作为先修知识,请大家先去看看我前两篇博客 博客指路:前端 ESlint 代码规范及修复代码规范错误-CSDN博客前端 Vue3 项目开发—— ESLint & prettier 配置代码风格-CSDN博客 husky 工具配置代码检查工作流的作用 在工作中,我们经常需要将写好的代码提交至代码仓库 但是由于程序员疏忽而将不规范的代码提交至仓库,显然是不合理的 所

10个好用的AI写作工具【亲测免费】

1. 光速写作 传送入口:http://u3v.cn/6hXWYa AI打工神器,一键生成文章&ppt 2. 讯飞写作 传送入口:http://m6z.cn/5ODiSw 3. 讯飞绘文 传送入口:https://turbodesk.xfyun.cn/?channelid=gj3 4. AI排版助手 传送入口:http://m6z.cn/6ppnPn 5. Kim

分享5款免费录屏的工具,搞定网课不怕错过!

虽然现在学生们不怎么上网课, 但是对于上班族或者是没有办法到学校参加课程的人来说,网课还是很重要的,今天,我就来跟大家分享一下我用过的几款录屏软件=,看看它们在录制网课时的表现如何。 福昕录屏大师 网址:https://www.foxitsoftware.cn/REC/ 这款软件给我的第一印象就是界面简洁,操作起来很直观。它支持全屏录制,也支持区域录制,这对于我这种需要同时录制PPT和老师讲

生信圆桌x生信分析平台:助力生物信息学研究的综合工具

介绍 少走弯路,高效分析;了解生信云,访问 【生信圆桌x生信专用云服务器】 : www.tebteb.cc 生物信息学的迅速发展催生了众多生信分析平台,这些平台通过集成各种生物信息学工具和算法,极大地简化了数据处理和分析流程,使研究人员能够更高效地从海量生物数据中提取有价值的信息。这些平台通常具备友好的用户界面和强大的计算能力,支持不同类型的生物数据分析,如基因组、转录组、蛋白质组等。

IntelliJ IDEA - 强大的编程工具

哪个编程工具让你的工作效率翻倍? 在日益繁忙的工作环境中,选择合适的编程工具已成为提升开发者工作效率的关键。不同的工具能够帮助我们简化代码编写、自动化任务、提升调试速度,甚至让团队协作更加顺畅。那么,哪款编程工具让你的工作效率翻倍?是智能的代码编辑器,强大的版本控制工具,还是那些让你事半功倍的自动化脚本?在这里我推荐一款好用的编程工具:IntelliJ IDEA。 方向一:工具介绍 Int

BIRT--商业智能和报表工具,从零开始

1.简介 BIRT (Business Intelligence and Reporting Tools), 是为 Web 应用程序开发的基于 Eclipse 的开源报表系统,特别之处在于它是以 Java 和 JavaEE 为基础。BIRT 有两个主要组件:基于 Eclipse 的报表设计器,以及部署到应用服务器上的运行时组件。 2.下载 官网下载网址:http://download.ec