⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 ʦ

📁 里面包括很多的驱动程序的
💻
字号:
C51编程:液晶上画圆的程序终于出来了,请大虾们帮我看看能否再简化一下。谢谢! [xiaoqi.] [96次] 01-5-22 下午 11:56:31

/************************************************/
/*画圆。数学方程(X-Ox)^2+(Y-Oy)^2=Rx^2          */
/************************************************/
//col,row为全局变量
void circle(Uchar Ox,Uchar Oy,Uchar Rx)
{
        unsigned int xx,rr,xt,yt,rs;
        yt=Rx;
        rr=Rx*Rx;
        rs=Rx*71/100;           //分开1/8圆弧来画,0.71=根号2
        for (xt=0;xt<=rs;xt++)
        {
                xx=xt*xt;
                while ((yt*yt)>(rr-xx))yt--;
                col=Ox+xt;              //第一象限
                row=Oy-yt;
                point();
                col=Ox-xt;              //第二象限
                row=Oy-yt;
                point();
                col=Ox-xt;              //第三象限
                row=Oy+yt;
                point();
                col=Ox+xt;              //第四象限
                row=Oy+yt;
                point();

/***************45度镜象变换,画另一半***************/

                col=Ox+yt;              //第一象限
                row=Oy-xt;
                point();
                col=Ox-yt;              //第二象限
                row=Oy-xt;
                point();
                col=Ox-yt;              //第三象限
                row=Oy+xt;
                point();
                col=Ox+yt;              //第四象限
                row=Oy+xt;
                point();
        }
        
}


怕是很难精简了! [lwd110] [7次] 01-5-23 上午 11:55:08 
要么在一个point()中画8个点,节约一点函数调用时间?




简化了一次,目标代码短了200字节左右。请看: [xiaoqi.] [35次] 01-5-23 下午 03:29:29 
/************************************************/
/*画圆。数学方程(X-Ox)^2+(Y-Oy)^2=Rx^2          */
/************************************************/

void circle(Uchar Ox,Uchar Oy,Uchar Rx)
{
        unsigned int xx,rr,xt,yt,rs;
        yt=Rx;
        rr=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--;
                col=Ox+xt;              //第一象限
                row=Oy-yt;
                point();
                col=Ox-xt;              //第二象限
                point();
                row=Oy+yt;              //第三象限
                point();
                col=Ox+xt;              //第四象限
                point();

/***************45度镜象画另一半***************/

                col=Ox+yt;              //第一象限
                row=Oy-xt;
                point();
                col=Ox-yt;              //第二象限
                point();
                row=Oy+xt;              //第三象限
                point();
                col=Ox+yt;              //第四象限
                point();
        }
}


利害!!有否上机试呢,效果好吗? [sampoo㊣] [1次] 01-5-23 下午 04:18:49 

显示完全ok!速度非常快 [xiaoqi.] [2次] 01-5-23 下午 04:25:24 

只改动一个表达式就可缩200字节,C51的算术表达式效率是否太低了? [lwd110] [4次] 01-5-23 下午 04:50:32 

修改了0.75的运算方法,抛弃了除法运算,一个16位的(avr)除法程序可不小啊 [xiaoqi.] [12次] 01-5-23 下午 05:59:48 
ICCAVR标准板没有加强优化,所以相对代码要稍长一些,C51用到8级优化当然不同。 

 
点击这里回复这篇贴子>>
_____________________________________________________________________________
Copyright?,C51BBS论坛 2000-2001 

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -