专家
公告
财富商城
电子网
旗下网站
首页
问题库
专栏
标签库
话题
专家
NEW
门户
发布
提问题
发文章
51单片机
用C语言怎么画圆呢?
2020-01-23 14:36
发布
×
打开微信“扫一扫”,打开网页后点击屏幕右上角分享按钮
站内问答
/
51单片机
17096
27
27
请问谁懂C语言画圆的原理?无穷多边形吗
友情提示:
此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
27条回答
Jason022
2020-01-23 15:59
/********************************************/
/* 画圆数学方程(X-Ox)^2+(Y-Oy)^2=Rx^2 */
/********************************************/
void GUI_circle( unsigned char Ox,unsigned char Oy,unsigned char Rx,unsigned char s )
{
unsigned int xx,rr;
unsigned int xt,yt;
unsigned int rs,row,col;
yt = Rx;
rr = ( unsigned int )Rx*Rx+1; // 补偿1 修正方形
rs = ( yt+( yt>>1 ) )>>1; // (*0.75)分开1/8圆弧来画
for ( xt=0; xt<=rs; xt++ )
{
xx = xt*xt;
while ( ( yt*yt )>( rr-xx ) )
{
yt--;
}
row = Ox+xt; // 第一象限
col = Oy-yt;
LCD_Point( row,col,s );
row = Ox-xt; // 第二象限
LCD_Point( row,col,s );
col = Oy+yt; // 第三象限
LCD_Point( row,col,s );
row = Ox+xt; // 第四象限
LCD_Point( row,col,s );
//***************45度镜象画另一半***************
row = Ox+yt; // 第一象限
col = Oy-xt;
LCD_Point( row,col,s );
row = Ox-yt; // 第二象限
LCD_Point( row,col,s );
col = Oy+xt; // 第三象限
LCD_Point( row,col,s );
row = Ox+yt; // 第四象限
LCD_Point( row,col,s );
}
}
复制代码
加载中...
查看其它27个回答
一周热门
更多
>
相关问题
【东软载波ESF0654 PDS开发板活动】开箱
1 个回答
东软载波ESF0654 PDS开发板外部中断
1 个回答
东软载波ESF0654 PDS开发板高级控制定时器AD16C4T
1 个回答
用串口调试助手为什么只能在hex模式接收发送而在文本模式不行
9 个回答
触摸芯片SC02B/SC04B在地砖灯的设计方案
1 个回答
相关文章
51单片机与蓝牙模块连接
0个评论
51单片机的硬件结构
0个评论
基于51单片机的无线遥控器制作
0个评论
51单片机 AD转换
0个评论
51单片机数码管递增显示
0个评论
如何实现对单片机寄存器的访问
0个评论
基于51单片机的指纹密码锁
0个评论
×
关闭
采纳回答
向帮助了您的知道网友说句感谢的话吧!
非常感谢!
确 认
×
关闭
编辑标签
最多设置5个标签!
51单片机
保存
关闭
×
关闭
举报内容
检举类型
检举内容
检举用户
检举原因
广告推广
恶意灌水
回答内容与提问无关
抄袭答案
其他
检举说明(必填)
提交
关闭
×
打开微信“扫一扫”,打开网页后点击屏幕右上角分享按钮
×
付费偷看金额在0.1-10元之间
确定
×
关闭
您已邀请
0
人回答
查看邀请
擅长该话题的人
回答过该话题的人
我关注的人
- /********************************************/
- /* 画圆数学方程(X-Ox)^2+(Y-Oy)^2=Rx^2 */
- /********************************************/
- void GUI_circle( unsigned char Ox,unsigned char Oy,unsigned char Rx,unsigned char s )
- {
- unsigned int xx,rr;
- unsigned int xt,yt;
- unsigned int rs,row,col;
- yt = Rx;
- rr = ( unsigned int )Rx*Rx+1; // 补偿1 修正方形
- rs = ( yt+( yt>>1 ) )>>1; // (*0.75)分开1/8圆弧来画
- for ( xt=0; xt<=rs; xt++ )
- {
- xx = xt*xt;
- while ( ( yt*yt )>( rr-xx ) )
- {
- yt--;
- }
- row = Ox+xt; // 第一象限
- col = Oy-yt;
- LCD_Point( row,col,s );
- row = Ox-xt; // 第二象限
- LCD_Point( row,col,s );
- col = Oy+yt; // 第三象限
- LCD_Point( row,col,s );
- row = Ox+xt; // 第四象限
- LCD_Point( row,col,s );
- //***************45度镜象画另一半***************
- row = Ox+yt; // 第一象限
- col = Oy-xt;
- LCD_Point( row,col,s );
- row = Ox-yt; // 第二象限
- LCD_Point( row,col,s );
- col = Oy+xt; // 第三象限
- LCD_Point( row,col,s );
- row = Ox+yt; // 第四象限
- LCD_Point( row,col,s );
- }
- }
复制代码一周热门 更多>