基于单片机的多路抢答器课程设计报告(2)

2019-01-19 14:41

单片机原理及系统课程设计报告

附录 源程序代码

#include sbit start=P1^0; sbit please=P1^1; sbit stop=P1^2; sbit ans=P1^3; sbit p1=P3^0; sbit p2=P3^1; sbit light1=P3^6; sbit light2=P3^7; sbit S=P2^0; sbit G=P2^1;

unsigned char code time[10]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90}; unsigned char cont=0,shi,ge,i; unsigned char T; //答题时间 void inter() interrupt 1 {

TH0=(65536-50000)/256; TL0=(65536-50000)%6; cont++; }

main() {

while(1) {

// 1.待机阶段 while( start==1 ) { S=1; G=0; P0=time[0]; for( i=0 ; i<100 ; i++ ) ; P0=0xff; S=0; G=1; P0=time[0]; for( i=0 ; i<100 ; i++ ) ; P0=0xff; } // 2.抢答阶段 while(1) { // 1).开始抢答

6

单片机原理及系统课程设计报告

ans=0; // 判断那个选手抢到题 while(1) { if ( p1==0 ) { light1=0; break; } if ( p2==0 ) { light2=0; break; } } // 禁止其他选手再选题 while( please==1 ) ; // 2).开始答题 ans=1; T=6; TMOD=0x01;

TH0=(65536-50000)/256; TL0=(65536-50000)%6; EA=1; ET0=1; TR0=1;

while( T<200&&stop==1 ) { shi=T/10; ge=T; S=1; G=0; P0=time[shi]; for( i=0 ; i<100 ; i++ ) ; P0=0xff; S=0; G=1; P0=time[ge]; for( i=0 ; i<100 ; i++ ) ; P0=0xff; if ( cont>20 ) { cont=0;T--; }

7

单片机原理及系统课程设计报告

}

// 3).停止答题 P3=0xff; break; } } }

8


基于单片机的多路抢答器课程设计报告(2).doc 将本文的Word文档下载到电脑 下载失败或者文档不完整,请联系客服人员解决!

下一篇:学雷锋活动倡议书

相关阅读
本类排行
× 注册会员免费下载(下载后可以自由复制和排版)

马上注册会员

注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
微信: QQ: