2019-03-24 17:17发布
dong2213dong 发表于 2016-8-31 17:13 你这样写是不对的,数组的内容就不对,你对unicode码的理解是不对的,另外你把Uart1Sends()函数的写法 ...
王绍霖 发表于 2016-8-31 20:52 这就尴尬了,刚入门而且没接触过这个感觉好难,弄了半个月了没弄懂,不然我把整个短信模块的代码 ...
最多设置5个标签!
这就尴尬了,刚入门而且没接触过这个感觉好难,弄了半个月了没弄懂,不然我把整个短信模块的代码给你看看,然后帮我写这两句写出来可好,我给你发红包。方便的话加个QQ说的比较清楚点,我的QQ819554687
呵呵,红包就不用了,我先帮你看看吧,要是不复杂就帮你写一写,发短信的这块弄过,也算复习一下
#include <REG51.H>
#define uchar unsigned char
#define uint unsigned int
//以下是你的51单片机的晶振大小
#define FOSC_110592M
//#define FOSC_12M
//以下是开机后发送到手机的内容,发送的号码在程序中修改。
uchar sms_text[] = "abc123";
uchar p_num[]="xxxxxxxxxxx";
//注意,无论接收到信号还是发送完信号,都会进中断服务程序的
/*初始化程序(必须使用,否则无法收发),次程序将会使用定时器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=1;//打开定时器
SM0=0;//设置串行通讯工作模式,(10为一部发送,波特率可变,由定时器1的溢出率控制)
SM1=1;//(同上)在此模式下,定时器溢出一次就发送一个位的数据
REN=1;//串行接收允许位(要先设置sm0sm1再开串行允许)
EA=1;//开总中断
ES=1;//开串行口中断
}
/*串行通讯中断,收发完成将进入该中断*/
void Serial_interrupt() interrupt 4
{
// a=SBUF;
P2=SBUF;
RI=0;//接收中断信号清零,表示将继续接收
// flag=1;//进入中断的标志符号
}
void Uart1Send(uchar c)
{
SBUF=c;
while(!TI);//等待发送完成信号(TI=1)出现
TI=0;
}
//串行口连续发送char型数组,遇到终止号/0将停止
void Uart1Sends(uchar *str)
{
while(*str!=' ')
{
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<65535; j++)
{
}
}
}
void main()
{
uchar i = 0;
SerialInti();
while(1)
{
Uart1Sends("AT+CSCS="GSM" ");
DelaySec(3);//延时3秒
Uart1Sends("AT+CMGF=1 ");
DelaySec(3);//延时3秒
Uart1Sends("AT+CMGS="");
for(j=0;j<11;j++)
{
SBUF=p_num[j];
while(TI==0);
TI=0; }
Uart1Sends("" ");
DelaySec(5);//延时3秒
Uart1Sends(sms_text);//修改短信内容
Uart1Send(0x1a);
DelaySec(15);//延时20秒
}
}
一周热门 更多>