专家
公告
财富商城
电子网
旗下网站
首页
问题库
专栏
标签库
话题
专家
NEW
门户
发布
提问题
发文章
STM32
表盘指针时钟-----M3
2019-08-19 18:27
发布
×
打开微信“扫一扫”,打开网页后点击屏幕右上角分享按钮
站内问答
/
STM32/STM8
11798
13
1467
各位好!
小弟请教一个问题,裸机可否有办法实现表盘指针时钟?
效果图:
有知道的吗?希望指导指导,不慎感激!
友情提示:
此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
13条回答
青苹果PAD
1楼-- · 2019-08-19 22:15
这是用OLED屏幕显示的模拟时钟,希望对楼主有帮助。
温馨提示:以后有问题现在论坛中搜索试试,不要上来就直接提问。
本论坛的链接:
http://www.openedv.com/posts/list/27834.htm
加载中...
正点原子
2楼-- · 2019-08-20 02:52
你这种,只能考虑图片叠加了.
简单点吧.好实现.
如下图:
这种表盘效果,完全就是程序生成的.
优点就是:速度快,占用资源少.
加载中...
青苹果PAD
3楼-- · 2019-08-20 03:56
精彩回答 2 元偷偷看……
加载中...
青苹果PAD
4楼-- · 2019-08-20 06:31
原子哥,板子的资料上没有这个程序吧!
加载中...
正点原子
5楼-- · 2019-08-20 10:49
回复【5楼】青苹果PAD:
---------------------------------
没有,但是这代码很简单了.
加载中...
正点原子
6楼-- · 2019-08-20 11:55
两个函数搞定:
[mw_shl_code=c,true]//画圆形指针表盘 //x,y:坐标中心点 //size:表盘大小(直径) //d:表盘分割,秒钟的高度 void calendar_circle_clock_drawpanel(u16 x,u16 y,u16 size,u16 d) { u16 r=size/2;//得到半径 u16 sx=x-r; u16 sy=y-r; u16 px0,px1; u16 py0,py1; u16 i; gui_fill_circle(x,y,r,WHITE); //画外圈 gui_fill_circle(x,y,r-4,BLACK); //画内圈 for(i=0;i<60;i++)//画秒钟格 { px0=sx+r+(r-4)*sin((app_pi/30)*i); py0=sy+r-(r-4)*cos((app_pi/30)*i); px1=sx+r+(r-d)*sin((app_pi/30)*i); py1=sy+r-(r-d)*cos((app_pi/30)*i); gui_draw_bline1(px0,py0,px1,py1,0,WHITE); } for(i=0;i<12;i++)//画小时格 { px0=sx+r+(r-5)*sin((app_pi/6)*i); py0=sy+r-(r-5)*cos((app_pi/6)*i); px1=sx+r+(r-d)*sin((app_pi/6)*i); py1=sy+r-(r-d)*cos((app_pi/6)*i); gui_draw_bline1(px0,py0,px1,py1,2,YELLOW); } for(i=0;i<4;i++)//画3小时格 { px0=sx+r+(r-5)*sin((app_pi/2)*i); py0=sy+r-(r-5)*cos((app_pi/2)*i); px1=sx+r+(r-d-3)*sin((app_pi/2)*i); py1=sy+r-(r-d-3)*cos((app_pi/2)*i); gui_draw_bline1(px0,py0,px1,py1,2,YELLOW); } gui_fill_circle(x,y,d/2,WHITE); //画中心圈 } //显示时间 //x,y:坐标中心点 //size:表盘大小(直径) //d:表盘分割,秒钟的高度 //hour:时钟 //min:分钟 //sec:秒钟 void calendar_circle_clock_showtime(u16 x,u16 y,u16 size,u16 d,u8 hour,u8 min,u8 sec) { static u8 oldhour=0; //最近一次进入该函数的时分秒信息 static u8 oldmin=0; static u8 oldsec=0; u16 r=size/2;//得到半径 u16 sx=x-r; u16 sy=y-r; u16 px0,px1; u16 py0,py1; u8 r1; if(hour>11)hour-=12; /////////////////////////////////////////////// //清除小时 r1=d/2+4; //清除上一次的数据 px0=sx+r+(r-3*d-7)*sin((app_pi/6)*oldhour); py0=sy+r-(r-3*d-7)*cos((app_pi/6)*oldhour); px1=sx+r+r1*sin((app_pi/6)*oldhour); py1=sy+r-r1*cos((app_pi/6)*oldhour); gui_draw_bline1(px0,py0,px1,py1,2,BLACK); //清除分钟 r1=d/2+3; //清除上一次的数据 px0=sx+r+(r-2*d-7)*sin((app_pi/30)*oldmin); py0=sy+r-(r-2*d-7)*cos((app_pi/30)*oldmin); px1=sx+r+r1*sin((app_pi/30)*oldmin); py1=sy+r-r1*cos((app_pi/30)*oldmin); gui_draw_bline1(px0,py0,px1,py1,1,BLACK); //清除秒钟 r1=d/2+3; //清除上一次的数据 px0=sx+r+(r-d-7)*sin((app_pi/30)*oldsec); py0=sy+r-(r-d-7)*cos((app_pi/30)*oldsec); px1=sx+r+r1*sin((app_pi/30)*oldsec); py1=sy+r-r1*cos((app_pi/30)*oldsec); gui_draw_bline1(px0,py0,px1,py1,0,BLACK); /////////////////////////////////////////////// //显示小时 r1=d/2+4; //显示新的时钟 px0=sx+r+(r-3*d-7)*sin((app_pi/6)*hour); py0=sy+r-(r-3*d-7)*cos((app_pi/6)*hour); px1=sx+r+r1*sin((app_pi/6)*hour); py1=sy+r-r1*cos((app_pi/6)*hour); gui_draw_bline1(px0,py0,px1,py1,2,YELLOW); //显示分钟 r1=d/2+3; //显示新的分钟 px0=sx+r+(r-2*d-7)*sin((app_pi/30)*min); py0=sy+r-(r-2*d-7)*cos((app_pi/30)*min); px1=sx+r+r1*sin((app_pi/30)*min); py1=sy+r-r1*cos((app_pi/30)*min); gui_draw_bline1(px0,py0,px1,py1,1,GREEN); //显示秒钟 r1=d/2+3; //显示新的秒钟 px0=sx+r+(r-d-7)*sin((app_pi/30)*sec); py0=sy+r-(r-d-7)*cos((app_pi/30)*sec); px1=sx+r+r1*sin((app_pi/30)*sec); py1=sy+r-r1*cos((app_pi/30)*sec); gui_draw_bline1(px0,py0,px1,py1,0,RED); oldhour=hour; //保存时 oldmin=min; //保存分 oldsec=sec; //保存秒 } [/mw_shl_code]
加载中...
1
2
3
下一页
一周热门
更多
>
相关问题
STM32F4上I2C(在PROTEUS中模拟)调试不通的问题
6 个回答
芯片供应紧张,准备换个MCU,MM32L系列替换STM32L系列的怎么样?
7 个回答
STM32同时使用两个串口进行数据收发时数据丢包的问题
5 个回答
STM32F103串口通信死机问题
4 个回答
STM32WLE5CC连接SX1268在LoRa模式下能与 SX1278互通吗?
2 个回答
STM32开发板免费用活动
7 个回答
stm32 处理 DHT11占用太多时间,大家程序是怎么设计的
8 个回答
分享一个STM32单片机做的离线编程器代码
9 个回答
相关文章
ST公司第一款无线低功耗单片机模块有效提高物联网设计生产效率
0个评论
如何实现对单片机寄存器的访问
0个评论
通过USB用STM32片内自带Bootloader下载程序及注意事项
0个评论
欲练此功必先自宫之STM32汇编启动,放慢是为了更好的前行
0个评论
×
关闭
采纳回答
向帮助了您的网友说句感谢的话吧!
非常感谢!
确 认
×
关闭
编辑标签
最多设置5个标签!
STM32
保存
关闭
×
关闭
举报内容
检举类型
检举内容
检举用户
检举原因
广告推广
恶意灌水
回答内容与提问无关
抄袭答案
其他
检举说明(必填)
提交
关闭
×
关闭
您已邀请
15
人回答
查看邀请
擅长该话题的人
回答过该话题的人
我关注的人
温馨提示:以后有问题现在论坛中搜索试试,不要上来就直接提问。
本论坛的链接:
http://www.openedv.com/posts/list/27834.htm
简单点吧.好实现.
如下图:
这种表盘效果,完全就是程序生成的.
优点就是:速度快,占用资源少.
---------------------------------
没有,但是这代码很简单了.
[mw_shl_code=c,true]//画圆形指针表盘 //x,y:坐标中心点 //size:表盘大小(直径) //d:表盘分割,秒钟的高度 void calendar_circle_clock_drawpanel(u16 x,u16 y,u16 size,u16 d) { u16 r=size/2;//得到半径 u16 sx=x-r; u16 sy=y-r; u16 px0,px1; u16 py0,py1; u16 i; gui_fill_circle(x,y,r,WHITE); //画外圈 gui_fill_circle(x,y,r-4,BLACK); //画内圈 for(i=0;i<60;i++)//画秒钟格 { px0=sx+r+(r-4)*sin((app_pi/30)*i); py0=sy+r-(r-4)*cos((app_pi/30)*i); px1=sx+r+(r-d)*sin((app_pi/30)*i); py1=sy+r-(r-d)*cos((app_pi/30)*i); gui_draw_bline1(px0,py0,px1,py1,0,WHITE); } for(i=0;i<12;i++)//画小时格 { px0=sx+r+(r-5)*sin((app_pi/6)*i); py0=sy+r-(r-5)*cos((app_pi/6)*i); px1=sx+r+(r-d)*sin((app_pi/6)*i); py1=sy+r-(r-d)*cos((app_pi/6)*i); gui_draw_bline1(px0,py0,px1,py1,2,YELLOW); } for(i=0;i<4;i++)//画3小时格 { px0=sx+r+(r-5)*sin((app_pi/2)*i); py0=sy+r-(r-5)*cos((app_pi/2)*i); px1=sx+r+(r-d-3)*sin((app_pi/2)*i); py1=sy+r-(r-d-3)*cos((app_pi/2)*i); gui_draw_bline1(px0,py0,px1,py1,2,YELLOW); } gui_fill_circle(x,y,d/2,WHITE); //画中心圈 } //显示时间 //x,y:坐标中心点 //size:表盘大小(直径) //d:表盘分割,秒钟的高度 //hour:时钟 //min:分钟 //sec:秒钟 void calendar_circle_clock_showtime(u16 x,u16 y,u16 size,u16 d,u8 hour,u8 min,u8 sec) { static u8 oldhour=0; //最近一次进入该函数的时分秒信息 static u8 oldmin=0; static u8 oldsec=0; u16 r=size/2;//得到半径 u16 sx=x-r; u16 sy=y-r; u16 px0,px1; u16 py0,py1; u8 r1; if(hour>11)hour-=12; /////////////////////////////////////////////// //清除小时 r1=d/2+4; //清除上一次的数据 px0=sx+r+(r-3*d-7)*sin((app_pi/6)*oldhour); py0=sy+r-(r-3*d-7)*cos((app_pi/6)*oldhour); px1=sx+r+r1*sin((app_pi/6)*oldhour); py1=sy+r-r1*cos((app_pi/6)*oldhour); gui_draw_bline1(px0,py0,px1,py1,2,BLACK); //清除分钟 r1=d/2+3; //清除上一次的数据 px0=sx+r+(r-2*d-7)*sin((app_pi/30)*oldmin); py0=sy+r-(r-2*d-7)*cos((app_pi/30)*oldmin); px1=sx+r+r1*sin((app_pi/30)*oldmin); py1=sy+r-r1*cos((app_pi/30)*oldmin); gui_draw_bline1(px0,py0,px1,py1,1,BLACK); //清除秒钟 r1=d/2+3; //清除上一次的数据 px0=sx+r+(r-d-7)*sin((app_pi/30)*oldsec); py0=sy+r-(r-d-7)*cos((app_pi/30)*oldsec); px1=sx+r+r1*sin((app_pi/30)*oldsec); py1=sy+r-r1*cos((app_pi/30)*oldsec); gui_draw_bline1(px0,py0,px1,py1,0,BLACK); /////////////////////////////////////////////// //显示小时 r1=d/2+4; //显示新的时钟 px0=sx+r+(r-3*d-7)*sin((app_pi/6)*hour); py0=sy+r-(r-3*d-7)*cos((app_pi/6)*hour); px1=sx+r+r1*sin((app_pi/6)*hour); py1=sy+r-r1*cos((app_pi/6)*hour); gui_draw_bline1(px0,py0,px1,py1,2,YELLOW); //显示分钟 r1=d/2+3; //显示新的分钟 px0=sx+r+(r-2*d-7)*sin((app_pi/30)*min); py0=sy+r-(r-2*d-7)*cos((app_pi/30)*min); px1=sx+r+r1*sin((app_pi/30)*min); py1=sy+r-r1*cos((app_pi/30)*min); gui_draw_bline1(px0,py0,px1,py1,1,GREEN); //显示秒钟 r1=d/2+3; //显示新的秒钟 px0=sx+r+(r-d-7)*sin((app_pi/30)*sec); py0=sy+r-(r-d-7)*cos((app_pi/30)*sec); px1=sx+r+r1*sin((app_pi/30)*sec); py1=sy+r-r1*cos((app_pi/30)*sec); gui_draw_bline1(px0,py0,px1,py1,0,RED); oldhour=hour; //保存时 oldmin=min; //保存分 oldsec=sec; //保存秒 } [/mw_shl_code]
一周热门 更多>