51单片机控制舵机转角的C语言程序

51单片机控制舵机转角的C语言程序,第1张

定时器0表示的是脉冲总周期20ms,定时器1表示的是正脉冲宽度(如pwm_value = 1500时表示正缓简脉冲宽度为1.5ms), 而while循序只是为了改变正脉冲宽度。运行过程是:定时器0和定时器,1同时开启,此时pwm = 1,定时器1的时间到了之后pwm = 0,并关闭定时器1,等待脉冲总周期达到20ms即定时器0中断,在定时器0的中断服务中又将pwm赋值为1并开启定时器1……以这样的方式循环就可以控制舵机转动了芦哪竖陪大!

51单片机控制舵机程序

#include <reg52.h>

#define Stop 0 //宏定义,停止

#define Left 1 //宏核者定义,左转

#define Right 2 //宏定义,右转

sbit ControlPort = P2^0//舵机信号端慧烂口

sbit KeyLeft = P1^0//左转按键端口

sbit KeyRight = P1^1//右转按键端口

sbit KeyStop = P1^2//归位按键端口

unsigned char TimeOutCounter = 0,LeftOrRight = 0//TimeOutCounter:定时器溢出计数 LeftOrRight:舵机左右旋转标志

void InitialTimer ( void )

{

TMOD=0x10//定时/计数器1工作于方式1

TH1 = ( 65535 - 500 ) / 256//0.25ms

TL1 = ( 65535 - 500 ) % 256

EA=1//开总中断

ET1=1//允许定时/计数器1 中断

TR1=1//启动定时/计数器1 中断

}

void ControlLeftOrRight ( void ) //控制舵机函数

{

if( KeyStop == 0 )

{

//while ( !KeyStop )//使标志等于Stop(0),改碧薯在中断函数中将用到 LeftOrRight = Stop

}

if( KeyLeft == 0 )

{

//while ( !KeyLeft )//使标志等于Left(1),在中断函数中将用到 LeftOrRight = Left

}

if( KeyRight == 0 )

{

//while ( !KeyRight )//使标志等于Right(2),在中断函数中将用到 LeftOrRight = Right

}

#include<reg52.h>

#define uint unsigned int

#define uchar unsigned char

uchar k //k表示总时间 因为定时器中断要用到k,所以放在程序头

sbit PWM1=P1^0

sbit key1=P3^7 //舵机启动开关

void init()

{

TMOD=0X01

TH0=(65536-92)/256

TL0=(65536-92)%256

EA=1

ET0=1

TR0=1

}

void jiman20() //51模拟PWM波函数

{

static uchar flag=0,j=0 //flag当做PWM高电平变宽/变窄的标志;

//j表示高电平持续的时间;k表示总嫌备时间.因为重复调用该函数

if(k==200) //第一步:判断计时满20ms.

{

k=0 //k归零

if(flag==0) //标志为0时,高电平标志增加

j++

else //标志为1时,高电平标志减小

j--

if(j>=25) //当j=25时,高电平持续时间为2.5ms,此时角度为180.

flag=1 //必须改变宽/窄标志。

if(j<=0) //当j=0时,高电平持续时间为0ms,此时角度为0.

flag=0 //必须改变宽/窄标志。

}

if(k<j) //第二步:在20ms判春答断结束的基础上,输出PWM

PWM1=1 //因为每20ms,k就归0.所以能通过判断k<j,输出高电平

else PWM1=0

}

void main()

{

uint i=60000

init()

while(i--) //一芹森毁开机就让舵机有一个转动

{

jiman20()

}

while(1)

{

while(key1==0) //当开关打开,启动定时器,进入转动程序并循环

{

TR0=1

jiman20()

}

TR0=0 //当开关关闭,关闭定时器,舵机保持最末时刻状

}

}

void timer() interrupt 1 //定时器计时0.1ms,即模拟PWM是以0.1s为分度,

//高电平逐渐增加/减少

{

TR0=0

TH0=(65536-92)/256

TL0=(65536-92)%256

TR0=1

k++

}

实测能用,不谢!


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/12340353.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-24
下一篇 2023-05-24

发表评论

登录后才能评论

评论列表(0条)

保存