|
本帖最后由 anan111 于 2019-6-19 16:58 編輯
這是我自己做的超聲波避障小車。
1.51單片機
2.L298N驅動板
3.電機2
4.差速輪2,萬向輪1
enA,enB可不接
#include<reg52.h>
//定義L298N端口
sbit in1 = P0^0;
sbit in2 = P0^1;
sbit in3 = P0^2;
sbit in4 = P0^3;
sbit enA = P0^4;
sbit enB = P0^5;
//定義超聲波模塊端口
sbit Trig = P1^2;
sbit Echo = P1^3;
unsigned int distance_cm = 0; //距離
unsigned int overflow_count = 0; //溢出計數
unsigned int status = 0; //超聲波模塊狀態
unsigned int dis_count = 0; //計數
unsigned char tmp, dat, flat;
unsigned int num, model, c=0;
unsigned int speed = 100;
void chaoshengbo_init(void);
void GetDistance(void);
void delay(unsigned int z)
{
unsigned int x, y;
for(x = z; x > 0 ; x--)
for(y=110;y>0;y--)
;
}
void delay_us(unsigned int aa)
{
while(aa--);
}
//小車右轉
void right(unsigned char pwm)
{
enA = 1;
in1 = 0;
in2 = 1;
in3 = 0;
in4 = 0;
delay_us( pwm );
enA = 1;
in1 = 0;
in2 = 0;
in3 = 0;
in4 = 0;
delay_us( 100 - pwm );
}
void r(void)
{
enA = 1;
in1 = 0;
in2 = 1;
in3 = 0;
in4 = 0;
}
//小車左轉
void left(unsigned char pwm)
{
enA = 1;
in1 = 0;
in2 = 0;
in3 = 1;
in4 = 0;
delay_us( pwm );
enA = 1;
in1 = 0;
in2 = 0;
in3 = 0;
in4 = 0;
delay_us( 100 - pwm );
}
void l(void)
{
enA = 1;
in1 = 0;
in2 = 0;
in3 = 1;
in4 = 0;
}
//小車后退
void back(unsigned char pwm)
{
enA = 1;
enB = 1;
in1 = 1;
in2 = 0;
in3 = 1;
in4 = 0;
delay_us( pwm );
enA = 1;
in1 = 0;
in2 = 0;
in3 = 0;
in4 = 0;
delay_us( 100 - pwm );
}
void b(void)
{
enA = 1;
enB = 1;
in1 = 1;
in2 = 0;
in3 = 1;
in4 = 0;
}
//小車前進
void forward(unsigned char pwm)
{
enA = 1;
enB = 1;
in1 = 0;
in2 = 1;
in3 = 0;
in4 = 1;
delay_us( pwm );
enA = 1;
in1 = 0;
in2 = 0;
in3 = 0;
in4 = 0;
delay_us( 100 - pwm );
}
void f(void)
{
enA = 1;
enB = 1;
in1 = 0;
in2 = 1;
in3 = 0;
in4 = 1;
}
//小車停止
void stop(void)
{
enB = 1;
in1 = 0;
in2 = 0;
in3 = 0;
in4 = 0;
}
void main(void)
{
chaoshengbo_init();
while(1)
{
b();
GetDistance();
if(distance_cm > 0 && distance_cm <= 15)
{
f();
delay(1000);
r();
delay(1000);
}
}
}
//超聲波模塊初始化
void chaoshengbo_init(void)
{
Trig = 0;
//TH2 = RCAP2H = 0;
//TL2 = RCAP2L = 0;
TH0 = TL0 = 0;
TR0 = 0; //關閉定時器2
ET0 = 1; //允許T2中斷
}
//超聲波模塊獲取距離
void GetDistance(void)
{
Trig = 1; //發送觸發信號
status = 1; //status狀態默認位1
TH0 = 0;
TL0 = 0;
TR0 = 1; //打開定時器2
while(TL0 < 42) //產生超過10us的脈沖
;
status = 2; //狀態設為2
Trig = 0;
TR0 = 0;
TH0 = 0;
TL0 = 0;
overflow_count = 0;
TR0 = 1; //打開定時器2
while(Echo == 0) //當無信號返回時
{
if(status == 5)
{
status = 0;
distance_cm = 0;
break ; //失敗
}
}
TR0 = 0; //清空計數
TH0 = 0;
TL0 = 0;
overflow_count = 0;
TR0 = 1;
while(Echo == 1) //有信號返回時,開始計算長度
{
if(status == 5) //status為5時失敗
{
status = 0;
distance_cm = 0;
TR0 = 0;
break ;
}
}
dis_count = overflow_count * 65536 + TH0 * 256 + TL0;
TR0 = 0;
distance_cm = (unsigned int)( (long)(dis_count) * 34 / 10000);
status = 0 ; //準備下次發送
}
//定時器2中斷
void Timer0Int() interrupt 1
{
TF0 = 0;
overflow_count++;
TH0 = 0;
TL0 = 0;
if(overflow_count == 2)
{
status = 5; //超時
}
}
|
|