久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

標題: 求大神把這兩個程序組合起來 [打印本頁]

作者: 一句話111    時間: 2017-6-6 17:23
標題: 求大神把這兩個程序組合起來
/*********************************************************************
    光電開關循跡程序
*********************************************************************/
#include<reg52.h>
#define uchar unsigned char
#define uint unsigned int
uchar x3,x4;
uint i;
sbit P20=P1^2;//L298N使能端ENA?
sbit P21=P1^5;//L298N使能端ENB?
sbit P22=P1^0;//左電機A1? IN1
sbit P23=P1^1;//左電機A2? IN2
sbit P24=P1^3;//右電機B1?  IN3
sbit P25=P1^4;//右電機B2?  IN4
sbit P10=P3^6;//右邊探頭?
sbit P12=P3^7;//左邊探頭?
void delay_us(unsigned int aa)
{
while(aa--);
}
void ds(uchar x1,uchar x2)
{
TMOD=0X01;//定時器0,工作方式1??
TH0=x1;//賦高8位初值
TL0=x2;//賦低8位初值??
x3=x1;
x4=x2;//保存計數初值
EA=1;ET0=1;//開總中斷,開定時器0中斷
TR0=1;//定時器0開始計數?
}

void xunji()
{
if(P10==0&&P12==0)//左、右探頭都檢測到黑色
{
P22=1;
//停止???
P23=0;

P24=1;

P25=0;
}
if((P10==1&&P12==1))//全檢測不到黑線,前進
{
//ds(0xff,0xff);
//計數初值65535????????
P22=0;
P23=0;//全速前進
P24=0;
P25=0;
for(i=0;i<100;i++)
{
delay_us(5);
P20=~P20;
P21=~P21;
}
}
if((P10==0&&P12==1))
//右邊探頭檢測到黑線
{
ds(0xff,0xe1);
//計數初值65505??
}
if((P10==1&&P12==0))//右邊探頭檢測到黑線或右、中探頭檢測到黑線
{
ds(0xff,0xe1);//計數初值65505??
}
}
void main()
{
while(1)
{
xunji();
P20=1;
P21=1;//ENA和ENB同時為高電平時,L298N芯片正常工作
P22=1;
P23=1;
P24=1;
P25=1;
}
}
void time0()interrupt 1
{
TH0=x3;
TL0=x4;//重新賦計數初值
if((P10==1&&P12==1))//全檢測不到黑線,前進
{
P22=0;
P23=0;//全速前進
P24=0;
P25=0;
}
if((P10==0&&P12==1))//右邊探頭檢測到黑線,小車左轉
{
P22=1;
P23=0;//小車左拐???
P24=0;
P25=0;
}
if((P10==1&&P12==0))//左邊探頭檢測到黑線,小車右轉
{
P22=0;
P23=0;//小車右拐??
P24=1;
P25=0;
}
}

/***************************************************************************
2.
     超聲波測距并用數碼管顯示程序
**********************************************************************/

#include <reg52.h>//器件配置文件
#include <intrins.h>
sbit RX=P1^1;//echo
sbit TX=P1^2;//trig
sbit DU= P2^6;//數碼管段選
sbit WE= P2^7;//數碼管位選
unsigned int time=0;
unsigned int timer=0;
unsigned char posit=0;
unsigned long S=0;
bit flag =0;
unsigned char const discode[] ={ 0x3F, 0x06, 0x5B, 0x4F, 0x66, 0x6D, 0x7D, 0x07, 0x7F,0x6F,0x40,0x00/*-*/};
unsigned char const positon[3]={ 0xfe,0xfd,0xfb};
unsigned char disbuff[4]={ 0,0,0,0,};
/********************************************************/
void Display(void)//掃描數碼管
{
DU = 0;
if(posit==0)
{P0=(discode[disbuff[posit]])|0x80;}
else
{P0=discode[disbuff[posit]];}
DU = 1;
DU = 0;
WE = 0;
P0=positon[posit];
WE=1;
WE=0;
if(++posit>=3)
posit=0;
}
/********************************************************/
void Conut(void)
{
time=TH0*256+TL0;
TH0=0;
TL0=0;
S=(time*1.7)/100;//算出來是CM
if((S>=700)||flag==1) //超出測量范圍顯示“-”
{
flag=0;
disbuff[0]=10;//“-”
disbuff[1]=10;//“-”
disbuff[2]=10;//“-”
}
else
{
disbuff[0]=S%1000/100;
disbuff[1]=S%1000%100/10;
disbuff[2]=S%1000%10 %10;
}
}
/********************************************************/
void zd0() interrupt 1//T0中斷用來計數器溢出,超過測距范圍
{
flag=1;//中斷溢出標志
}
/********************************************************/
void zd3() interrupt 3//T1中斷用來掃描數碼管和計800MS啟動模塊
{
TH1=0xf8;
TL1=0xcd;
Display();
timer++;
if(timer>=400)
{
timer=0;
TX=1;//800MS??啟動一次模塊
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
TX=0;
}
}
/*********************************************************/
void main(void)
{
TMOD=0x11;//設T0為方式1,GATE=1;
TH0=0;
TL0=0;
TH1=0xf8;//2MS定時
TL1=0xcd;
ET0=1; //允許T0中斷
ET1=1;//允許T1中斷
TR1=1;//開啟定時器
EA=1;//開啟總中斷
while(1)
{
while(!RX); //當RX為零時等待
TR0=1;//開啟計數
while(RX);//當RX為1計數并等待
TR0=0;//關閉計數
Conut();//計算
}
}

作者: zl2168    時間: 2017-6-6 21:45
這個程序是你自己寫的還是抄來的?若是你自己寫的,建議你再進一步學學;若是抄來的,就把這個程序槍斃了。因為這是一個爛程序,我還是第一次看到一個有連續21個NOP組成的程序。
作者: lingwise    時間: 2017-6-7 15:26
樓上真有雅興,那么耐心數得那么準確
作者: zl2168    時間: 2017-6-7 22:22
有10000個NOP組成的程序更好玩
作者: wangminfu    時間: 2017-6-9 03:06
左右手指相扣,就是兩個程序合并的結果。 #include 部分 先合并,接著是  SBIT  然后是 全局變量。 自定義函數,main 初始化部分  , while(1)內容。 也就是把程序看成六段組成,每段分別合并。最后是 整理變量名,函數名,端口和定時器,看看有沒有沖突。




歡迎光臨 (http://m.zg4o1577.cn/bbs/) Powered by Discuz! X3.1
主站蜘蛛池模板: 韩日欧美 | 国产日韩欧美一区 | 成人影 | 国产理论在线观看 | 国产一区二区三区精品视频 | av大片在线观看 | 超碰97免费 | 一级片大全 | 蜜桃成人av| 天堂一区二区三区 | 毛片网站免费 | 97国产精品人人爽人人做 | 在线观看日韩av | 欧美一区二区在线 | 亚洲视频在线播放 | 国产伦精品一区二区三区在线 | 午夜高清| 国产成人精品自拍 | 天堂资源av| 国产精品一品二区三区的使用体验 | 97精品超碰一区二区三区 | 性欧美8khd高清极品 | www精品 | 麻豆亚洲一区 | 久久国产精品一区二区 | 天天精品视频 | 日本精品在线观看 | 亚洲毛片在线 | 成人在线国产 | 国产成人精品一区二区 | 欧美福利一区 | 亚洲福利视频一区 | 精品国产乱码一区二区三 | 亚洲理论片 | 亚洲免费视频观看 | 精品久久网站 | 亚洲国产中文字幕 | 亚洲视频一区二区三区四区 | 免费看黄色大片 | 国产99页| 99在线免费观看视频 |