欧美极品高清xxxxhd,国产日产欧美最新,无码AV国产东京热AV无码,国产精品人与动性XXX,国产传媒亚洲综合一区二区,四库影院永久国产精品,毛片免费免费高清视频,福利所导航夜趣136
標題:
單片機電容表的proteus仿真與源程序
[打印本頁]
作者:
愛愛愛
時間:
2018-2-10 13:39
標題:
單片機電容表的proteus仿真與源程序
仿真原理圖如下(proteus仿真工程文件可到本帖附件中下載)
0.png
(19.13 KB, 下載次數: 76)
下載附件
2018-2-10 20:01 上傳
測量電容需要三步 1、按下"量程選擇按鍵" 2、按下"開始測量按鍵" 3、按下"最終顯示按鍵"
0.png
(54.72 KB, 下載次數: 63)
下載附件
2018-2-10 20:02 上傳
單片機源程序如下:
#include<reg52.h>
#define DataPort P0 //定義數據端口 程序中遇到DataPort 則用P0 替換
sbit LATCH1=P3^0;//定義鎖存使能端口 段鎖存
sbit CAP=P1^2;//運放輸出連接端,當輸出高電平時停止計時
sbit nf=P3^1;//測量控制總按鍵,低電平有效
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,不顯示小數點。
unsigned char code
dofly_DuanMa2[]={0xbf,0x86,0xdb,0xcf,0xe6,0xed,0xfd,0x87,0xff,0xef,0xf7,0xfc,0xb9,0xde,0xf9,0xf1};// 顯示段碼值0~F,顯示小數點。
dofly_WeiMa[]={0x01,0x02,0x04,0x08,0x10,0x20,0x40,0x80};//分別對應相應的數碼管點亮,即位碼
unsigned char TempData[8]; //存儲顯示值的全局變量
void Delay(unsigned int t); //延時函數聲明
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) //約延時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; //清空數據,防止有交替重影
LATCH1=1; //段鎖存
LATCH1=0;
P2=dofly_WeiMa[i+FirstBit]; //取位碼
DataPort=TempData[i]; //取顯示數據,段碼
LATCH1=1; //段鎖存
LATCH1=0;
Delay(200); // 掃描間隙延時,時間太長會閃爍,太短會造成重影
}
}
void main()
{
P2=0x00;
TMOD=TMOD|0x01;//選擇計數方式,定時計數器1
EA=1;
ET0=1;
TH0=0x00;
TL0=0x00;// 裝入計數初值,即為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) //超出測量范圍是顯示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) //超出測量范圍是顯示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) //超出測量范圍是顯示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)
……………………
…………限于本文篇幅 余下代碼請從51黑下載附件…………
復制代碼
所有資料51hei提供下載:
電容表仿真.zip
(105.29 KB, 下載次數: 61)
2018-2-10 13:39 上傳
點擊文件名下載附件
下載積分: 黑幣 -5
作者:
Highnose
時間:
2020-10-22 17:44
不知為什么,改變電容,每次顯示的還是60
歡迎光臨 (http://m.raoushi.com/bbs/)
Powered by Discuz! X3.1