// Header: tc35 *** 作函数
// File Name: TC35.C
// Author: 兴创科技
#include "hardware.h"
#include "SMS.h"
extern uchar numbuff[]
void delay(uint m) //延时m*0.2ms
{
uchar n
for(m>0m--)
for(n=100n>0n--)
}
void Sendcmd(uchar *p) //发送AT命令
{
while(*p)
{
SBUF=*(p++)
while(TI==0)
TI=0
}
}
void Sendchar(uchar c) /伍橘拍/发送一个字符
{
TI=0
SBUF=c
while(TI==0)
TI=0
}
void Init_tc35(void) //判断是否连接TC35
{
uint i=0xffff
rcount=0
receive_ok=0
Sendcmd("AT\r\n")
while(receive_ok==0)
{
i--
if(i==0) //超时还未响应则返回
{
rcount=0
receive_ok=0
return
}
}
receive_ok=0
rcount=0
delay(4000)
i=0xffff
Sendcmd("AT&F\r\n") //初始化
while(receive_ok==0)
{
i--
if(i==0) //超时还未响应则返回
{
rcount=0
receive_ok=0
return
}
}
receive_ok=0
rcount=0
delay(4000)
i=0xffff
Sendcmd("AT+IPR=4800\r\n") //设置波特率
while(receive_ok==0)
{
i--
if(i==0) //超时还未响应则返回
{
rcount=0
receive_ok=0
return
}
}
receive_ok=0
rcount=0
delay(4000)
i=0xffff
Sendcmd("AT+CMGF=1\r\n") //设置短消息格式
while(receive_ok==0)
{
i--
if(i==0) //超时还未响应则返回
{
rcount=0
receive_ok=0
return
}
}
receive_ok=0
rcount=0
delay(4000)
i=0xffff
Sendcmd("AT+CSCS=") //设置字符集为“GSM”
Sendchar('"')
Sendcmd("GSM")
Sendchar('"')
Sendchar(0x0D)
Sendchar(0x0A)
while(receive_ok==0)
{
i--
if(i==0) //超伍洞时还未响应腔羡则返回
{
rcount=0
receive_ok=0
return
}
}
receive_ok=0
rcount=0
tc35_init_ok=1 //全部初始化完毕置标志
}
void Sendsms(uchar *q) //向指定的号码发送短消息
{
ulong i=0x1ffff
rcount=0 //数据缓冲区指针回0
Sendcmd("AT+CMGS=")
Sendchar('"')
Sendcmd(numbuff)
Sendchar('"')
Sendchar(0x0D)
Sendchar(0x0A)
while(rbuff[rcount-2]!='>')
{
i--
if(i==0)
{
rcount=0
receive_ok=0
return //超时返回
}
}
Sendcmd(q)
Sendchar(0x1A)//发送短信
Sendchar(0x0D)
Sendchar(0x0A)
receive_ok=0
i=0x5fffff //发送短消息超时处理发送等待5s比较安全
while(receive_ok==0)
{
i--
if(i==0) //超时还未响应则返回
{
rcount=0
receive_ok=0
return
}
}
receive_ok=0
rcount=0
}
smc.h
// Header: tc35头文件
// File Name: SMS.H
// Author: Yoran
// Date: 2008/05/12
#ifndef __SMS_H__
#define __SMS_H__
#include <reg52.H>
#include <hardware.H>
extern uchar idata rbuff[]
extern uchar data databuff[]
extern uchar rcount
extern bit tc35_init_ok
extern bit receive_ok
extern bit new_sms
void Init_tc35(void) //判断是否连接TC35
void Sendcmd(uchar *cmd) //发送AT命令
void Sendchar(uchar c) //发送一个字符
void Sendsms(uchar *q) //向指定的号码发送短消息
#endif
main.c
// Header: XC-TC35短信猫测试程序
// File Name: 发送英文短信.C
// Author: 兴创科技
// P2^4---//发短信
#include <reg52.h>
#include <string.h>
#include "hardware.h"
#include "sms.h"
#include "sms.c"
//LCD Start
uchar code table[]="Welcome...."
uchar code table1[]="No:1 is ON"
uchar code table2[]="No:2 is ON"
uchar code table3[]="No:1 2 are ON"
uchar i
//以下三个是定义LCD的引脚
sbit lcden=P2^2 //6
sbit lcdwrite=P2^1//5
sbit lcdrs=P2^0//4
//lcd的写指令
void write_com(uchar com)
{
lcdrs=0
lcden=0
P0=com
delay(5)
lcden=1
delay(5)
lcden=0
}
//lcd的写数据
void write_data(uchar da)
{
lcdrs=1
lcden=0
P0=da
delay(5)
lcden=1
delay(5)
lcden=0
}
//初始化
void init()
{
lcdwrite=0
lcden=0
write_com(0x38)//16*2显示,5*7点阵,8位数据
write_com(0x0c)//显示开,关光标
write_com(0x06)//移动光标
write_com(0x01)//清除LCD的显示内容
}
//LCD END
uchar idata rbuff[110] //串口接收数据缓存区
uchar numbuff[]="13217832221" //此处修改为需要接收短信的手机号码,注意要定义为字符串(\0)
uchar databuff[]="000000" //数据缓存区,注意要定义为字符串(\0)
uchar rcount //串口接收数据指针
bit tc35_init_ok //TC35注册成功初始化完成标志
bit receive_ok //收到模块“ok”标志
bit send_error
bit send_ok
void initUart(void)
{ // RXD=1
//TXD=1
TMOD=0x20 //T1工作方式2,8位自动重装
SCON=0x40 //串行口工作方式1,8位UTRA
TH1=0xfa
TL1=0xfa //波特率发生器,波特率为4800
REN=1 //允许串行接收
TR1=1 //开波特率发生器T1
ES=1 //开串行口中断
EA=1 //开总中断
// R=1
// T=1
}
void RECEIVE_DATA(void) interrupt 4 //接收tC35发送的数据并缓存
{
ES=0
if(RI)
{
rbuff[rcount++]=SBUF
RI=0
}
//判断是否接收完毕
if((rbuff[rcount-1]==0x0a)&&(rbuff[rcount-2]==0x0d)&&(rbuff[rcount-3]==0x4b)&&(rbuff[rcount-4]==0x4f))
{ //换行 //回车
receive_ok=1
}
//判断是否为新短消息指示
if((rbuff[rcount-14]=='C')&&(rbuff[rcount-13]=='M')&&(rbuff[rcount-12]=='T')&&(rbuff[rcount-11]=='I'))
{ //换行
new_sms=1
}
else new_sms=0
if(((rbuff[rcount-17]=='C')&&(rbuff[rcount-16]=='M')&&(rbuff[rcount-15]=='G')&&(rbuff[rcount-14]=='S')&&(rbuff[rcount-4]==0x4f)&&(rbuff[rcount-3]==0x4b)&&(rbuff[rcount-2]==0x0d)&&(rbuff[rcount-1]==0x0a))|((rbuff[rcount-16]=='C')&&(rbuff[rcount-15]=='M')&&(rbuff[rcount-14]=='G')&&(rbuff[rcount-13]=='S')&&(rbuff[rcount-4]==0x4f)&&(rbuff[rcount-3]==0x4b)&&(rbuff[rcount-2]==0x0d)&&(rbuff[rcount-1]==0x0a)))
{ //换行
send_ok=1
}
else send_ok=0
if((rbuff[rcount-7]=='E')&&(rbuff[rcount-6]=='R')&&(rbuff[rcount-5]=='R')&&(rbuff[rcount-4]=='O')&&(rbuff[rcount-3]=='R'))
{ //换行
send_error=1
}
else send_error=0
if(rcount>109)rcount=0
ES=1
}
void keyboard()
{
if(!(K1&K2&K3&K4))
{
delay(10)
if(!(K1&K2&K3&K4))
{
if(K1==0)
{
Sendcmd("ATD13217832221\r\n") //按键1拨打电话测试语音通话
}
if(K3==0&&K4==0)
{
Sendsms("The Light No:1 and 2 are ON!") //发送英文短信
write_com(0x01)
delay(30)
for(i=0i<13i++)write_data(table3[i])
delay(2000)delay(2000)delay(2000)delay(2000)delay(2000)
while(K3==0&&K4==0)
}
if(K3==0)
{
Sendsms("The Light No:1 is ON!") //发送英文短信
write_com(0x01)
delay(30)
for(i=0i<10i++)write_data(table1[i])
delay(2000)delay(2000)delay(2000)delay(2000)delay(2000)
while(K3==0)
}
if(K4==0)
{
Sendsms("The Light No:2 is ON!") //发送英文短信
write_com(0x01)
delay(30)
for(i=0i<10i++)write_data(table2[i])
delay(2000)delay(2000)delay(2000)delay(2000)delay(2000)
while(K4==0)
}
write_com(0x01)
write_com(0x80+1)
for(i=0i<11i++)write_data(table[i])
rcount=0
while(!(K1&K2&K3&K4)) //按键释放
}
}
}
void main(void)
{
uchar times=0
uchar m=0
tc35_init_ok=0
init()//LCD
write_com(0x80+1)
for(i=0i<11i++)write_data(table[i])
initUart() //初始化串口
Init_tc35() //开启TC35
delay(5000)
delay(5000)
delay(5000)
delay(5000)
while(tc35_init_ok==0) //初始化TC35
{
Init_tc35()
delay(4000)
times++
if(times>15)
{
times=0
delay(1000)
delay(500)
delay(1000)
delay(4000)delay(4000)delay(4000)
}
}
if(tc35_init_ok)
{
BEEP=0 //初始化成功鸣叫一声
delay(2000)
BEEP=1
delay(2000)
BEEP=0
}
while(1)
{
keyboard()
}
}
这个可以通过Windows API实现。BOOL PostMessage(
HWND hWnd, // handle to destination window
UINT Msg, // message
WPARAM wParam, // first message parameter
LPARAM lParam // second message parameter
)
第一个参数是消息目的窗口的句柄;
第二个参数是消息类型;
第三个和第四个参数是两个消息参数,具体取决于你的消息类型。
当然,你也可以使用枝携SendMessage来给目标窗口发送消息。
但那是同步方式,而PostMessage是异步方式。
也就历搭乎是说,PostMessage只是把消息发送到目标窗口的消息队列中就立即返回了,而SendMessage是要等到目标窗口的窗口处理函数从消息队列中将消息取出来之后才会返回肢悉的。至于你使用哪个API要看你程序的需要而定。
time_t tstruct tm *ti
char buffer[1048], input[1024]
time(&t) //获取时间戳
ti = localtime(&t) //转成详细时间信息
//格式化时间字行厅符串
sprintf(buffer, "%04d/%02d/%02d %02d:%02d:%02d ",
ti->tm_year + 缺弯1900,
ti->tm_mon + 1,
ti->tm_mday,
伏带闷 ti->tm_hour,
ti->tm_min,
ti->tm_sec)
fgets(input, 1024, stdin)
strcat(buffer, input) //连接两个字符串
printf("%s", buffer)
send(sockfd,buffer,strlen(buffer),0)
//望采纳
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)