51单片机计算机代码原理图,51单片机智能秒表的原理图与源代码

*******************************/

/*     智能秒表(完美版)      */

/*******************************/

#include

#define uint unsigned int

#define uchar unsigned char

sbit key1=P2^0;                //定义"启动/暂停"按钮

sbit key2=P2^1;                //定义"复位"按钮

sbit key3=P2^2;                                                        //定义"模式"按钮

sbit key4=P2^3;                                                        //定义"查看"按钮

sbit wei1=P2^4;                //定义位选

sbit wei2=P2^5;

sbit wei3=P2^6;

sbit wei4=P2^7;

bit flag_start,flag_mode,flag_5sec;

uchar temp,temp1,aa,aa1,shi,ge,shifen,baifen,num,i,j;

uchar time_data1[11],time_data2[11];

uchar code table[]={

0x3f,0x06,0x5b,0x4f,

0x66,0x6d,0x7d,0x07,

0x7f,0x6f,0x77,0x7c,

0x39,0x5e,0x79,0x71};          //不带小数点共阴极数码管编码

uchar code tabledp[]={

0xbf,0x86,0xdb,0xcf,

0xe6,0xed,0xfd,0x87,

0xff,0xef,0xf7,0xfc,

0xb9,0xde,0xf9,0xf1};        //带小数点共阴极数码管编码

void display(uchar shi,uchar ge,uchar shifen,uchar baifen);  //声明显示子函数

void delay(uint z);          //声明延时子函数

void init();                  //声明初始化函数

void key();                                                           //声明键扫描函数

void display_process();                              //声明显示处理函数

void main()

{

init();                                      //调用初始化子程序

while(1)

{

key();

display_process();

display(shi,ge,shifen,baifen);        //调用显示子函数

}

}

void delay(uint z)                       //延时子函数

{

uint x,y;

for(x=z;x>0;x--)

for(y=110;y>0;y--);

}

void display(uchar shi,uchar ge,uchar shifen,uchar baifen)   //显示子程序

{

P0=table[shi];        //使用动态扫描的方法实现数码管显示

wei1=0;

delay(1);

wei1=1;

P0=tabledp[ge];

wei2=0;

delay(1);

wei2=1;

……………………

…………限于本文篇幅 余下代码请从51黑下载附件…………

51计算器程序#include #include #define uchar unsigned char #define uint unsigned int sbit lcden=P3^4; sbit lcdrw=P3^6; sbit lcdrs=P3^5; uchar num,temp,jia=0,cheng=0,chu=0,jian=0,qing=0; uint key,key1,shu; uchar fuhao,flag1,flag=0; uchar table[]={ 0x3F,0x06,0x5B,0x4F,0x66,0x6D,0x7D,0x07,0x7F,0x6F,0x00,}; void delay(uint z) { uint x,y; for(x=z;x>0;x--) for(y=114;y>0;y--); } bit lcd_bz() { bit result; lcdrs = 0; lcdrw= 1; lcden = 1; _nop_(); _nop_(); _nop_(); _nop_(); result=(bit)(P0&0x80;); lcden=0; return result; } void write_com(uchar com) { while(lcd_bz()); lcdrs=0; lcden=0; lcdrw=0; P0=com; delay(5); lcden=1; delay(5); lcden=0; } void write_date(uchar date) { while(lcd_bz()); lcdrs=1; lcden=0; lcdrw=0; P0=date; delay(5); lcden=1; delay(5); lcden=0; } void lcd_init() { lcden=0; write_com(0x38); write_com(0x0c); write_com(0x06); write_com(0x01); } void keyscan() { P3=0xfe; temp=P3; temp=temp&0xf0; while(temp!=0xf0) { delay(5); temp=P3; temp=temp&0xf0; while(temp!=0xf0) { temp=P3; switch(temp) { case 0xee:key=1;num=0;break; case 0xde:key=2;num=0;break; case 0xbe:key=3;num=0;break; case 0x7e:num=1;break; //¼ÓºÅ } while(temp!=0xf0) { temp=P3; temp=temp&0xf0; } } } P3=0xfd; temp=P3; temp=temp&0xf0; while(temp!=0xf0) { delay(5); temp=P3; temp=temp&0xf0; while(temp!=0xf0) { temp=P3; switch(temp) { case 0xed:key=4;num=0;break; case 0xdd:key=5;num=0;break; case 0xbd:key=6;num=0;break; case 0x7d:num=2;break; //¼õºÅ } while( temp!=0xf0) { temp=P3; temp=temp&0xf0; } } } P3=0xfb; temp=P3; temp=temp&0xf0; while(temp!=0xf0) { delay(5); temp=P3; temp=temp&0xf0; while(temp!=0xf0) { temp=P3; switch(temp) { case 0xeb:key=7;num=0;break; case 0xdb:key=8;num=0;break; case 0xbb:key=9;num=0;break
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值