久久久久久久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在线免费观看视频
|