单片机控制两个步进电机画圆_单片机控制的步进电机程序框图

发表于:2007/3/23 8:03:00

#4楼

这个是我实验程序。希望可以给些帮助。

#include

#define uchar  unsigned char

#define uint   unsigned int

#define ulong  unsigned long

__CONFIG(XT&UNPROTECT&PWRTEN&BORDIS&WDTEN);

//asm("FILL  (GOTO   $),(0x0FFF-$)");

union {

struct {

unsigned b0:1;

unsigned b1:1;

unsigned b2:1;

unsigned b3:1;

unsigned b4:1;

unsigned b5:1;

unsigned b6:1;

unsigned b7:1;

}tpBit;

unsigned char tpBits;

} tp;

#define bj0  tp.tpBit.b0

#define bj1  tp.tpBit.b1

#define bj   tp.tpBits

const  unsigned char table[]={ 0x60,0x30,0x90,0x0C0, };

const  unsigned char tablef[]={0x0C0,0x90,0x30,0x060, };

uchar  i;

///AD 延时子程序

void  ADdelay (uchar i)

{

while(i--) ;

}

/// 延时子程序

void delay(uint i)

{

while(i--)

{

uchar a=127;

while(a--);

}

}

系统 各I/O初始化子程序

void  initial (void)

{   TRISB=0;

//TRISC=0;

TRISA=0x0ff;

}

///A/D转换初始化子程序/

void  adinitial()

{

ADCON1=0;//;设置RA为A/D甬道模拟输入

//;RC时钟。打开A/D转换器。先中通道0

ADCON0=0x0c1;// B'11000001'   // ;A/D时钟为RC。RA0作A/D输入等

// ADIE=1; //时。开放中断

ADIF=0; //清/AD中断标志位   PIR1,

//  PEIE=1; //开放外围部件中断INTCON,

// GIE=1;   //开放总中断   INTCON,

TRISA0=1;

TRISA1=1;

}

//A/D转换/

void  AD_ad()

{

ADCON0=0x0c1;   // B'11001001'   // ;A/D时钟为RC。RA0作A/D输入等

ADdelay(3);//采样时间30us

ADGO=1;      //启动A/D转换 ADCON0,

while(ADGO); //等待

}

主程序///

void main()

{

initial ();  //系统 各I/O初始化子程序

adinitial();  //A/D转换初始化子程序

i=250;

while(1)

{

unsigned char   c;

for(c=0;c<4;c++)

{

if(bj0)PORTB=table[ c] ;

else   PORTB=tablef[ c] ;

CLRWDT();

AD_ad();

delay(ADRES );

}

i--;

while(i==0)

{

i=250;bj0=!bj0;

}

}

}

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
一次控制两个电机#include #define GPIO_MOTOR P1 sbit K1=P3^6; sbit K2=P3^5; sbit K3=P3^4; sbit K4=P3^3; unsigned char code ZHENG1 [8]={0xf1,0xf3,0xf2,0xf6,0xf4,0xfc,0xf8,0xf9}; //正转顺序编码 unsigned char code FAN1 [8]={0xf9,0xf8,0xfc,0xf4,0xf6,0xf2,0xf3,0xf1}; //反转顺序编码 unsigned char code ZHENG2 [8]={0x1f,0x3f,0x2f,0x6f,0x4f,0xcf,0x8f,0x9f}; //正转顺序编码 unsigned char code FAN2 [8]={0x9f,0x8f,0xcf,0x4f,0x6f,0x2f,0x3f,0x1f}; //反转顺序编码 char Motor1_Step,Motor2_Step,Speed,Speed2; void Delay(unsigned int t); void Motor1_zheng(); void Motor1_fan(); void Motor2_zheng(); void Motor2_fan(); void main() { unsigned int i; Motor1_Step=1; Motor2_Step=3; Speed=10; Speed2=40; while(1) { while(K1==0) { for(i=0;i<10;i++) { Motor1_zheng(); } } while(K2==0) { for(i=0;i<10;i++) { Motor1_fan(); } } while(K3==0) { for(i=0;i<10;i++) { Motor2_zheng(); } } while(K4==0) { for(i=0;i<10;i++) { Motor2_fan(); } } } } void Motor1_fan() { unsigned int i; for(i=0;i<8;i++) { //GPIO_MOTOR = FFW[i]&0x1f; //取数据 GPIO_MOTOR = FAN1[i]; Delay(Speed); //调节转速 } } void Motor1_zheng() { unsigned int i; for(i=0;i<8;i++) { //GPIO_MOTOR = FFZ[i]&0x1f; GPIO_MOTOR = ZHENG1[i]; Delay(Speed); //调节转速 } } void Motor2_fan() { unsigned int i; if(Motor1_Step==0) { for(i=0;i<8;i++) { //GPIO_MOTOR = FFW2[i]&0xf1; //取数据 GPIO_MOTOR = FAN2[i]; Delay(Speed2); //调节转速 } } Motor1_Step=1; } void Motor2_zheng() { unsigned int i; if(Motor1_Step==1) { for(i=0;i<8;i++) { //GPIO_MOTOR = FFZ2[i]&0xf1; GPIO_MOTOR = ZHENG2[i]; Delay(Speed2); //调节转速 } } Motor1_Step=0; } void Delay(unsigned int t) { unsigned int k; while(t--) { for(k=0; k<80; k++) { } } }

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值