|
仿真原理圖如下(proteus仿真工程文件可到本帖附件中下載)
0.png (19.13 KB, 下載次數(shù): 76)
下載附件
2018-2-10 20:01 上傳
測(cè)量電容需要三步 1、按下"量程選擇按鍵" 2、按下"開(kāi)始測(cè)量按鍵" 3、按下"最終顯示按鍵"
0.png (54.72 KB, 下載次數(shù): 63)
下載附件
2018-2-10 20:02 上傳
單片機(jī)源程序如下:
- #include<reg52.h>
- #define DataPort P0 //定義數(shù)據(jù)端口 程序中遇到DataPort 則用P0 替換
- sbit LATCH1=P3^0;//定義鎖存使能端口 段鎖存
- sbit CAP=P1^2;//運(yùn)放輸出連接端,當(dāng)輸出高電平時(shí)停止計(jì)時(shí)
- sbit nf=P3^1;//測(cè)量控制總按鍵,低電平有效
- sbit lm1=P1^3;
- sbit lm2=P1^4;
- sbit lm3=P1^5;
- sbit lm4=P1^6;
- sbit key1=P3^2;
- sbit key2=P3^3;
- sbit key3=P3^4;
- sbit key4=P3^5;
- unsigned int num;
- unsigned char code
- dofly_DuanMa1[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71};// 顯示段碼值0~F,不顯示小數(shù)點(diǎn)。
- unsigned char code
- dofly_DuanMa2[]={0xbf,0x86,0xdb,0xcf,0xe6,0xed,0xfd,0x87,0xff,0xef,0xf7,0xfc,0xb9,0xde,0xf9,0xf1};// 顯示段碼值0~F,顯示小數(shù)點(diǎn)。
- dofly_WeiMa[]={0x01,0x02,0x04,0x08,0x10,0x20,0x40,0x80};//分別對(duì)應(yīng)相應(yīng)的數(shù)碼管點(diǎn)亮,即位碼
- unsigned char TempData[8]; //存儲(chǔ)顯示值的全局變量
- void Delay(unsigned int t); //延時(shí)函數(shù)聲明
- void delayms(unsigned char t);
- void Display(unsigned char FirstBit,unsigned char Num);
- void ke1(void) ;
- void ke2(void) ;
- void ke3(void) ;
- void ke4(void) ;
- void ke1(void)
- {
- TempData[0]=dofly_DuanMa1[num%1000/100];
- TempData[1]=dofly_DuanMa1[num%1000%100/10];
- TempData[2]=dofly_DuanMa2[num/1000];
- TempData[3]=dofly_DuanMa1[num%1000%100%10];
- TempData[4]=0x73;
- TempData[5]=0x71;
- }
- void ke2(void)
- {
- TempData[0]= dofly_DuanMa1[num%1000/100];
- TempData[1]=dofly_DuanMa2[num/1000];
- TempData[2]=dofly_DuanMa1[num%1000%100/10];
- TempData[3]=dofly_DuanMa1[num%1000%100%10];
- TempData[4]=0x73;
- TempData[5]=0x71;
- }
- void ke3(void)
- {
- TempData[0]=dofly_DuanMa1[num%1000/100];
- TempData[1]=dofly_DuanMa1[num%1000%100/10];
- TempData[2]=dofly_DuanMa2[num/1000];
- TempData[3]=dofly_DuanMa1[num%1000%100%10];
- TempData[4]=0x3e;
- TempData[5]=0x71;
- }
- void ke4(void)
- {
- TempData[0]=dofly_DuanMa1[num%1000%100/10];
- TempData[1]=dofly_DuanMa2[num%1000%100%10];
- TempData[2]=dofly_DuanMa1[num/1000];
- TempData[3]=dofly_DuanMa1[num%1000/100];
- TempData[4]=0x3e;
- TempData[5]=0x71;
- }
- bit key(void)
- {
- if(nf==0)
- {
- delayms(10);
- if(nf==0)
- return 0;
- }
- else
- return 1;
- }
-
- void Delay(unsigned int t)
- {
- while(--t);
- }
- void delayms(unsigned char t) //約延時(shí)1ms
- {
- while(--t)
- {
- Delay(245);
- Delay(245);
- }
- }
- void Display(unsigned char FirstBit,unsigned char Num)
- {
- unsigned char i;
-
- for(i=0;i<Num;i++)
- {
- DataPort=0; //清空數(shù)據(jù),防止有交替重影
- LATCH1=1; //段鎖存
- LATCH1=0;
- P2=dofly_WeiMa[i+FirstBit]; //取位碼
- DataPort=TempData[i]; //取顯示數(shù)據(jù),段碼
- LATCH1=1; //段鎖存
- LATCH1=0;
- Delay(200); // 掃描間隙延時(shí),時(shí)間太長(zhǎng)會(huì)閃爍,太短會(huì)造成重影
- }
- }
- void main()
- {
- P2=0x00;
- TMOD=TMOD|0x01;//選擇計(jì)數(shù)方式,定時(shí)計(jì)數(shù)器1
- EA=1;
- ET0=1;
- TH0=0x00;
- TL0=0x00;// 裝入計(jì)數(shù)初值,即為0
- while(1)
- {
- if (key1==0)
- {
- Delay(10);
- if (key1==0)
- lm1=0;
- while(key()==1);
- lm1=1;
- TR0=1;
- Delay(10);
- while(CAP==0);
- TR0=0;
- num=TH0*256+TL0+10;
-
- if(num>2100) //超出測(cè)量范圍是顯示1
- {
- TempData[0]=0x06;
- TempData[1]=TempData[2]=TempData[3]=0x00;
- TempData[4]=TempData[5]=0x00;
- }
- else
- {
- ke1();
- }
- while(1)
- {
- Display(0,6);
- }
- }
- else if (key2==0)
- {
- Delay(10);
- if (key2==0)
- lm2=0;
- while(key()==1);
- lm2=1;
- TR0=1;
- Delay(10);
- while(CAP==0);
- TR0=0;
- num=TH0*256+TL0+200;
- if(num>2100) //超出測(cè)量范圍是顯示1
- {
- TempData[0]=0x06;
- TempData[1]=TempData[2]=TempData[3]=0x00;
- TempData[4]=TempData[5]=0x00;
- }
- else
- {
- ke2();
- }
- while(1)
- {
- Display(0,6);
- }
- }
- else if (key3==0)
- {
- lm3=0;
- while(key()==1);
- lm3=1;
- TR0=1;
- Delay(10);
- while(CAP==0);
- TR0=0;
- num=TH0*256+TL0+40;
- if(num>2100) //超出測(cè)量范圍是顯示1
- {
- TempData[0]=0x06;
- TempData[1]=TempData[2]=TempData[3]=0x00;
- TempData[4]=TempData[5]=0x00;
- }
- else
- {
- ke3();
- }
- while(1)
- {
- Display(0,6);
- }
- }
- else if (key4==0)
- {
-
- Delay(10);
- if (key4==0)
- ……………………
- …………限于本文篇幅 余下代碼請(qǐng)從51黑下載附件…………
復(fù)制代碼
所有資料51hei提供下載:
電容表仿真.zip
(105.29 KB, 下載次數(shù): 61)
2018-2-10 13:39 上傳
點(diǎn)擊文件名下載附件
下載積分: 黑幣 -5
|
|