OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 4188|回复: 1

关于51使用SIM900A以及舵机的问题

[复制链接]

1

主题

2

帖子

0

精华

新手上路

积分
28
金钱
28
注册时间
2017-3-14
在线时间
4 小时
发表于 2017-3-14 17:20:28 | 显示全部楼层 |阅读模式
1金钱
#include <REGX51.H>
#include <string.H>
#include <intrins.h>
#define uchar unsigned char
#define uint unsigned int  
unsigned int  rec_data_len_uart=0;    //标记Buffer_Uart0接收数组
unsigned char idata Buffer_Uart0_Rec[100];                 //Uart0中断接收数组   
#define V_TH0  0XFF                  
#define V_TL0  0XA4                           
#define V_TMOD 0X01   
sbit LED=P1^0;       
sbit DOUT=P2^0;                        
sbit P14=P1^4;
sbit P13=P1^3;
sbit LED8=P1^7;
unsigned int ZKB1=5,ZKB2;

void init_sys(void)            
{

  TMOD=V_TMOD;
  TH0=V_TH0;
  TL0=V_TL0;
  TF0 = 0;
  TR0=0;
  ET0=1;
  EA=1;
}



void Delay5Ms(void)
{
unsigned int TempCyc = 1000;
while(TempCyc--);
}
void delay(void)
{
uchar m,n,s;
for(m=20;m>0;m--)
for(n=20;n>0;n--)
for(s=248;s>0;s--);
}       



  
//注意,无论接收到信号还是发送完信号,都会进中断服务程序的
/*初始化程序(必须使用,否则无法收发),次程序将会使用定时器1*/
void SerialInti()//初始化程序(必须使用,否则无法收发)
{
        TMOD=0x20;//定时器1操作模式2:8位自动重载定时器

#ifdef FOSC_12M                   //在这里根据晶振大小设置不同的数值初始化串口
        TH1=0xf3;//装入初值,波特率2400
        TL1=0xf3;       
#else        
        TH1=0xfd;//装入初值,波特率9600
        TL1=0xfd;
#endif //end of SOC_12M
       
        TR1=0;//打开定时器
        SM0=0;//设置串行通讯工作模式,(10为一部发送,波特率可变,由定时器1的溢出率控制)
        SM1=1;//(同上)在此模式下,定时器溢出一次就发送一个位的数据
        REN=1;//串行接收允许位(要先设置sm0sm1再开串行允许)
        EA=1;//开总中断
        ES=1;//开串行口中断       
}
unsigned char hand(unsigned char *ptr)
{
        if(strstr(Buffer_Uart0_Rec,ptr)!=NULL)
                return 1;
        else
                return 0;
}
void clear_rec_data()
{
        uchar i,temp_len;
        temp_len=strlen(Buffer_Uart0_Rec);
        if(temp_len>100)
        {
                temp_len=100;
        }
        for(i=0;i<temp_len;i++)
        {
                Buffer_Uart0_Rec[i]='\0';       
        }
        rec_data_len_uart=0;
}


void Uart1Send(uchar c)
{
        SBUF=c;
        while(!TI);//等待发送完成信号(TI=1)出现
        TI=0;       
}
//串行口连续发送char型数组,遇到终止号/0将停止
void Uart1Sends(uchar *str)
{
        while(*str!='\0')
        {
                SBUF=*str;
                while(!TI)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     ;//等待发送完成信号(TI=1)出现
                TI=0;
                str++;
        }
}
//延时函数大概是1s钟,不过延时大的话不准...
void DelaySec(int sec)
{
        uint i , j= 0;
        for(i=0; i<sec; i++)
        {
                for(j=0; j<40000; j++)
                {       
                }
        }
}
void meiqi1()
{
                       
            delay();
                        if(1)
                    {
                        // LED=0;
                         ZKB1=14;
                        // TF0 = 0;                                                                                                                                                                                                                                                                                                                                                                                                             
                         TR0=1;
                         DelaySec(2);
                         TR0=0;
                  
                         LED = 1;
//                    SerialInti();
//                         LED8=0;
//                         TR1=1;
//            DelaySec(5);//延时约15秒,此处延时,是为了让模块有足够的时间注册到网络,
//        //    P14=1;                 //提示开始发送指令,开始发送指令时,务必确认模块上的LED 已经慢闪,即模块已经注册到网络
//        //----------------为什么是下面这些AT指令呢,请看群共享文件SIM900A重要的短信指令文件------------
//               
//            Uart1Sends("ATD15380718408;\r\n");//打电话指令,注意指令后面的分号不能少
//                LED8=1;
//            DelaySec(15);//延时大约3秒
//            Uart1Sends("ATH\r\n");        //关断电话


void main (void)
{
        unsigned int  i = 0;
          init_sys();
   
          DelaySec(2);
          LED  = 0;
          ZKB1 = 5;
      TR0=1;                                    
        DelaySec(2);
        LED = 1;
        TR0 = 0;
while(1)
  {
  meiqi1();
  }
}

void timer0(void) interrupt 1
{
static int click=0;         
TH0=V_TH0;                             
TL0=V_TL0;
click++;
if (click>=200) click=0;

if (click<=ZKB1)     
  P1_1=1;
else
  P1_1=0;
}
void Serial_interrupt() interrupt 4
{
        unsigned char temp_rec_data_uart0;       
        temp_rec_data_uart0 = SBUF;//读取接收数据                                               
        Buffer_Uart0_Rec[rec_data_len_uart]=temp_rec_data_uart0;        //接收数据
        rec_data_len_uart++;
        if(rec_data_len_uart>=100)
        {
                rec_data_len_uart=0;         //从头开始接收数据
        }
        else;
        RI=0;//接收中断信号清零,表示将继续接收       
}


舵机在ZKB1 = 5时转0°,ZKB1 = 14时转90°
在meiqi()函数里不把打电话的那段程序注释掉,程序在打完电话后,电机还会转回0°。把打电话的那段程序注释掉后程序就在while(1)里死循环,电机不会转回0°。
求解怎样才能让电机在打完电话后不转回0°         

正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

1

主题

2

帖子

0

精华

新手上路

积分
28
金钱
28
注册时间
2017-3-14
在线时间
4 小时
 楼主| 发表于 2017-3-19 15:37:40 | 显示全部楼层
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2024-11-23 22:05

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表