基于ATMega16单片机小车循迹程序_第1页
基于ATMega16单片机小车循迹程序_第2页
基于ATMega16单片机小车循迹程序_第3页
基于ATMega16单片机小车循迹程序_第4页
基于ATMega16单片机小车循迹程序_第5页
免费预览已结束,剩余1页可下载查看

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、#include <avr/io.h>#include <avr/interrupt.h>#include <avr/pgmspace.h>#include <util/delay.h>#include <avr/wdt.h>#define uchar unsigned char#define uint unsigned int#define deng (PINB&0x1F) uchar k,j,i,flag;uchar table=0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7F,0x

2、6f,0x77,0x7c,0x39,0x5e,0x79,0x71;uchar miao=0,fen=0;uchar data7=;void display( uchar n,uchar m)/数码管显示函数 DDRA|=0XFF; DDRD|=0X7F; PORTD&=0XF0; PORTA=tablen; switch(m) case 1:PORTD&=0XF7;break; case 2:PORTD&=0XFB;break; case 3:PORTD&=0XFD;break; case 4:PORTD&=0XFE;break; default :br

3、eak; _delay_ms(5); void motor_forward(void)/两轮前进 DDRD|=0X7F;DDRC|=0X03; TCCR1A=0Xa2;/14模式 TCCR1B=0X1b;/64分频 ICR1H=0X18; ICR1L=0X69;/20HZ PORTC|=0X00; OCR1A=1000; OCR1B=1000;void motor_turnleft(void) DDRD|=0X70;DDRC|=0X03; TCCR1A=0Xa2;/14模式 TCCR1B=0X1b;/64分频 ICR1H=0X18; ICR1L=0X69;/20HZ PORTC|=0X00;

4、OCR1A=1000; OCR1B=500;void motor_turnright(void) DDRD|=0X70;DDRC|=0X03; TCCR1A=0Xa2;/14模式 TCCR1B=0X1b;/64分频 ICR1H=0X18; ICR1L=0X69;/20HZ PORTC|=0X00; OCR1A=500; OCR1B=1000; void motor_turnback(void) DDRD|=0X70;DDRC|=0X03; TCCR1A=0Xa2;/14模式 TCCR1B=0X1b;/64分频 ICR1H=0X18; ICR1L=0X69;/20HZ PORTC|=0X03;

5、OCR1A=1000; OCR1B=1000;void motor_stop(void) DDRD|=0X70;DDRC|=0X03;PORTD&=0XCF; / TCCR1A=0Xa2;/14模式 / TCCR1B=0X1b;/64分频 / ICR1H=0X18; / ICR1L=0X69;/20HZ PORTC&=0XFC; / OCR1A=0; / OCR1B=0;/*void motor_speedup(void) DDRD|=0X70;DDRC|=0X03; TCCR1A=0Xa2;/14模式 TCCR1B=0X1b;/64分频 ICR1H=0X18; ICR1L=0

6、X69;/20HZPORTC&=0XFC; OCR1A=1000; OCR1B=1000; OCR1A+=20; OCR1B+=20;void motor_speeddown(void) DDRD|=0X70;DDRC|=0X03; TCCR1A=0Xa2;/14模式 TCCR1B=0X1b;/64分频 ICR1H=0X18; ICR1L=0X69;/20HZPORTC&=0XF5; OCR1A=1000; OCR1B=1000; OCR1A- OCR1B-=20;*/void motor_xunji(void)/循迹函数 DDRB&=0XE0 ; if(deng=0x

7、04) SREG|=0X80; motor_forward(); while(deng=0x04); if(deng=0x0c) motor_turnleft(); while(deng=0x0c) ; if(deng=0x08) motor_turnleft(); while(deng=0x08); if(deng=0x06) motor_turnright(); while(deng=0x06); if(deng=0x02) motor_turnright(); while(deng=0x02); if(deng=0x18) motor_turnleft(); while(deng=0x1

8、8); if(deng=0x03) motor_turnright(); while(deng=0x03); if(deng=0x01) motor_turnright(); while(deng=0x01); if(deng=0x10) motor_turnleft(); while(deng=0x10); if(deng=0x00) motor_stop(); while(deng=0x00); int main(void) TCCR0=0X04;/256分频 TCNT0=0X50;/10ms TIMSK=0X01; wdt_enable(WDTO_2S); SREG|=0X80; while(1) wdt_reset(); motor_xunji();_delay_ms(5); display(miao/10,2); _delay_ms(3); display(miao%10,1); _delay_ms(3); display(fen/10,4); _delay_ms(3

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

最新文档

评论

0/150

提交评论