在51单片机中如何利用宋老师的简易计算器程序改成可以实现连加连减 5

 我来答
Faceman无悔
2019-07-17
知道答主
回答量:1
采纳率:0%
帮助的人:727
展开全部
uchar code LedChar[]={
0x3f,0x06,0x5b,0x4f,
0x66,0x6d,0x7d,0x07,
0x7f,0x6f}; //0~9数码管缓冲区
uchar LedBuff[] = {
0x00,0x00,0x00,0x00,
0x00,0x00};
uchar code KeyCodeMap[4][4] = {
{ 0x31, 0x32, 0x33, 0x26 }, //数字键1、数字键2、数字键3、向上键
{ 0x34, 0x35, 0x36, 0x25 }, //数字键4、数字键5、数字键6、向左键
{ 0x37, 0x38, 0x39, 0x28 }, //数字键7、数字键8、数字键9、向下键
{ 0x30, 0x1B, 0x0D, 0x27 } //数字键0、ESC键、 回车键、 向右键
};
uchar KeySta[4][4] = {
{1,1,1,1},{1,1,1,1},
{1,1,1,1},{1,1,1,1}
};
void keydriver();
void main()
{
EA = 1;
TMOD = 0X01;
TH0 = 0XFC;
TL0 = 0X67;
TR0 = 1;
ET0 = 1;
LedBuff[0] = LedChar[0];

while(1)
{
keydriver();
}
}
void shownumber(signed long num)
{
unsigned char sign;
uchar buf[6];
signed char i;
if (num < 0) //首先提取并暂存符号位
{
sign = 1;
num =-num;
}
else
{
sign = 0;
}

for(i=0;i<6;i++)
{
buf[i] = num%10;
num = num/10;
}
for(i=5;i>=1;i--)
{
if(buf[i] == 0)
{
LedBuff[i] = 0x00;
}
else
{
break;
}
}
if (sign != 0) //负数时,需在最前面添加负号
{
if (i < 5) //当有效位数小于6位时添加负号,否则显示结果将是错的
{
LedBuff[i+1] = 0x40;
}
}

for( ;i>=0;i--)
{
LedBuff[i] = LedChar[buf[i]];
}
}
void keyaction(uchar keycode)
{
static char oprt = 0;
static signed long result = 0;
static signed long addend = 0;

if((keycode >= 0x30) && (keycode <= 0x39))
{
addend = (addend*10) + (keycode - 0x30);
shownumber(addend);
}

else if(keycode == 0x26) //+
{
oprt = 0;
result += addend;
addend = 0;
shownumber(result);
}

else if(keycode == 0x28) //-
{
oprt = 1;
if(result == 0 )
{
result = addend -result;
}
else
{
result -= addend;
}
addend = 0;
shownumber(result);
}

else if(keycode == 0x25) //x
{
oprt = 2;
if(result == 0)
{
result = addend - result;
}
else
{
result *= addend;
//result = result * 1;
}
addend = 0;
shownumber(result);
}

else if(keycode == 0x27) //%
{
oprt = 3;
if(result == 0)
{
result = addend - result;
}
else
{
result /= addend;
}
addend = 0;
shownumber(result);
}

else if(keycode == 0x0d)
{
if (oprt == 0)
{
result += addend; //进行加法运算
}
else if(oprt == 1)
{
result -= addend; //进行减法运算
}

else if(oprt == 2)
{
result *= addend;
}

else if(oprt == 3)
{
result /= addend;
}
addend = 0;
shownumber(result); //运算结果显示到数码管
}

else if(keycode == 0x1b)
{
result = 0;
addend = 0;
shownumber(addend);
}
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
阳光的凌宝宝
2018-12-16 · TA获得超过979个赞
知道小有建树答主
回答量:1.7万
采纳率:9%
帮助的人:1343万
展开全部
得到木头[数字];GreedIsGood
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 2条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式