微波EDA网,见证研发工程师的成长!
首页 > 硬件设计 > 嵌入式设计 > 基于有方GPRS的智能电梯控制系统

基于有方GPRS的智能电梯控制系统

时间:11-20 来源:互联网 点击:
(uchar ch); //向串口发送单个字符void send_AT_IPR(void); //设置模块的波特率为9600bpsvoid send_AT_CMGF(void); //设置发短信为文本模式void send_AT_CSCS(void); //发送TE的字符集为GSMvoid send_AT_CNMI(void); //设置短信的提示信息void send_AT_CMGR(); //发送读取命令void send_AT_CMGS(uchar *phone_num); //选择发送目的手机号void send_text(uchar *text); //发送短信文本void init_GPRS(void); //初始化GPRS模块sbit dula=P2^6;sbit wela=P2^7;sbit rs=P3^5;sbit lcden=P3^4;sbit s1=P2^0;sbit s2=P2^1;sbit s3=P2^2;sbit s4=P2^3;sbit rd=P3^7;sbit dscs=P1^4;sbit dsas=P1^5;sbit dsrw=P1^6;sbit dsds=P1^7;sbit dsirq=P3^3;uchar count,s1num,flag,flag1;uchar miao,shi,fen;uchar code table[]=" 2012-10-15 MON";uchar code table1[]=" 00:00:00";uchar code floor[]="FLOOR: 1";uchar code state[]="STATE: IDLE";uchar code welcome[]="WELCOME TO USE!";uchar code up[]="UP ";uchar code down[]="DOWN";uchar code idle[]="IDLE";void write_date(uchar);void write_ds(uchar,uchar);uchar read_ds(uchar); //从ds187读取时间void init();void keyscan();void write_sfm(uchar add,uchar date);uchar code *AT_CMGF = "AT+CMGF=1"; //发送AT+CMGF=1,设置文本模式uchar code *AT_CSCS = "AT+CSCS="; //选择TE的字符集(默认是GSM),M580返回数据时缓冲数组是OKuchar code *AT_IPR = "AT+IPR=9600"; //设置波特率为9600bpsuchar code *AT_CNMI ="AT+CNMI=2,1,0,0,0" ; //设置收到新短信存于SIM卡中并发CMTI通知uchar code *AT_CMGR="AT+CMGR="; //发送读取短信的命令uchar code *AT_CMGS="AT+CMGS=";uchar xdata buffer[100]={0}; //单片机用于接收短信的缓冲uchar code tab[]={0xff,0xfe,0xfd,0xfb,0xf7,0xef,0xdf,0xbf,0x7f};//流水灯的状态uchar code message0[] = "Sorry ,it is busy now ";uchar code message1[] = "Sorry , we can only reach to ";//指明可以到达的终点uchar code message2[] = "and now we are moving to ";//指明将要到达的楼层uchar code message3[] = "Ok , we have accepted your request !";//接受请求后发送的消息/\*名称:test(char* )*功能:判断电梯的此刻状态\/uint test(uchar * floor){uint i;for (i = 1 ; i < FLOOR ; i++)//从一楼开始判断{if(floor[i]){if(i < Con_Floor)return 1;//表示电梯正在下降else return 0;//表示电梯正在上升}}return 2;//表示此时电梯为空}/\*名称:up_down_logic()*功能:电梯的升降逻辑\/void up_down_logic(){uchar floor_data [FLOOR]={0};//判断执行方向uchar buf[FLOOR]={0};uchar tel[13] ;uchar temp;uint i=0;uchar temp1 ;while(1){miao=read_ds(0); //没有响应时,时间可以正确的运行,但是一旦有请求,时间便会出现跳跃情况fen=read_ds(2);shi=read_ds(4);write_sfm(10,miao);write_sfm(7,fen);write_sfm(4,shi);delayms(100);while(checkinfo()){/* i = 0;while(tel[i]){tel[i] = 0 ;i++;}*/temp=ReceiveData(&temp1,tel);//temp 表示起点,temp1表示终点EA=0;//关中断//以下是将缓冲区清空i=0;while(buffer[i]){buffer[i]=0;i++;}com_dat=0;if (test(floor_data)==1&&temp-0>=1&&Con_Floor>=1)//在下降{if(temp -0 < Con_Floor&&!floor_data[temp-0])//8点之前为上楼的高峰,所以下楼的请求(在7点半以前)不予响应,电梯直接到达一楼{if(temp1-0 < temp - 0 && temp1 - 0 >= low&&(read_ds(4)>8))//希望到楼下去,即temp1 < temp的且此时电梯所能到的最低点比temp1还小{floor_data[temp-0]=1;buf[temp-0] = temp1-0;send_AT_CMGS(tel);//先发号码delayms(500);send_text(message3);send_text(message2);send_uart(Con_Floor-1+0);delayms(10);send_uart(0x1a);delayms(10);}else if (temp1 - 0 < temp - 0 && temp1 - 0 < low &&(read_ds(4)>8))//希望到楼下去,即temp1 < temp的且此时电梯所能到的最低点比temp1大{if (buf[low] < low)//如果在电梯所能到的最低点处就没有请求了或有向下的请求{floor_data[temp-0]=1;buf[temp-0] = temp1-0;send_AT_CMGS(tel);//先发号码delayms(500);send_text(message3);send_text(message2);send_uart(Con_Floor-1+0);delayms(10);send_uart(0x1a);delayms(10);}else{send_AT_CMGS(tel);//先发号码delayms(500);send_text(message1);send_uart(low+0);delayms(10);send_text(message2);send_uart(Con_Floor-1+0);delayms(10);send_uart(0x1a);delayms(10);}}else if(temp1 - 0 < temp - 0 && temp1 - 0 < low &&(read_ds(4)<8)){send_AT_CMGS(tel);//先发号码delayms(500);send_text(message0);send_uart(low+0);delayms(10);send_text(message2);send_uart(Con_Floor-1+0);delayms(10);send_uart(0x1a);delayms(10);}else if (temp1 - 0 > temp - 0&& temp - 0 < low)//如果希望到楼上去,则仅当到最低点处没有请求或请求到达的地方小于temp后才可以{if ((buf[low] == 0||(buf[low] > temp - 0 && buf[low] < low))&&(read_ds(4)<5))//确保电梯到low层后无请求或有向下的但大于temp的请求{floor_data[temp - 0] = 1 ;buf[temp - 0] = temp1 - 0 ;high = temp1 - 0 ;//在电梯向上运行时所能到达的最高点low = temp - 0 ;send_AT_CMGS(tel);//先发号码delayms(500);send_text(message3);send_text(message2);send_uart(Con_Floor+1+0);delayms(10);send_uart(0x1a);delayms(10);}else if(buf[low] > low &&(read_ds(4)<5)){send_AT_CMGS(tel);//先发号码delayms(500);send_text(message1);send_uart(low+0);delayms(10);send_text(message2);send_uart(Con_Floor-1+0);delayms(10);send_uart(0x1a);delayms(10);}else if(buf[low] < temp - 0 &&(read_ds(4)<5)){send_AT_CMGS(tel);//先发号码delayms(500);send_text(message1);send_uart(buf[low]+0);delayms(10);send_text(message2);send_uart(Con_Floor-1+0);delayms(10);send_uart(0x1a);delayms(10);}else//不响应会执行下面的语句{send_AT_CMGS(tel);//先发号码delayms(500);send_text(message0);send_uart(buf[low]+0);delayms(10);send_text(message2);send_uart(Con_Floor+1+0);delayms(10);send_uart(0x1a);delayms(10);}}}}else if (!test(floor_data)&&temp-0>=1&&Con_Floor>=1)//在上升{if(temp-0 > Con_Floor&&!floor_data[temp-0]){if(temp1-0 > temp - 0 && temp1 - 0 <= high &&(read_ds(4)<5))//请求者希望到楼上去,且此时电梯所能到达的最高点比请求temp1还大{floor_data[temp-0]=1;buf[temp-0] = temp1-0;send_AT_CMGS(tel);//先发号码delayms(500);send_text(message3);send_text(message2);send_uart(Con_Floor+1+0);delayms(10);send_uart(0x1a);delayms(10);}else if (temp1 - 0 > temp - 0 && temp1 - 0 > high &&(read_ds(4)<5))//请求者希望到楼上去,且此时请求的目的地已经超过了电梯所能到达的最高点{if (buf[high] > high || buf[high] == 0)//如果电梯到了最高点处还有向上的请求或者到了最高点处就没有请求了{floor_data[temp-0]=1;buf[temp-0] = temp1-0;send_AT_CMGS(tel);//先发号码delayms(500);send_text(message3);send_text(message2);send_uart(Con_Floor+1+0);delayms(10);send_uart(0x1a);delayms(10);}else if (buf[high] < high){send_AT_CMGS(tel);//先发号码delayms(500);send_text(message1);send_uart(high+0);delayms(10);send_text(message2);send_uart(Con_Floor+1+0);delayms(10);send_uart(0x1a);delayms(10);}}else if(temp1 - 0 > temp - 0 && temp1 - 0 > high &&(read_ds(4)>5))//不响应时执行{send_AT_CMGS(tel);//先发号码delayms(500);send_text(message0);send_uart(buf[low]+0);delayms(10);send_text(message2);send_uart(Con_Floor+1+0);delayms(10);send_uart(0x1a);delayms(10);}else if (temp1 - 0 < temp - 0 && temp - 0 > high )//请求者希望到楼下去{if ((buf[high] == 0||(buf[high] < temp - 0&&buf[high] > high))&&(read_ds(4)>8))//要确保电梯到达high层后没有请求或有向上的小于temp的请求{floor_data[temp - 0] = 1 ;buf[temp-0] = temp1 - 0;low = temp1 - 0;high = temp - 0;send_AT_CMGS(tel);//先发号码delayms(500);send_text(message3);send_text(message2);send_uart(Con_Floor+1+0);delayms(10);send_uart(0x1a);delayms(10);}else if (buf[high] < high &&(read_ds(4)>8)){send_AT_CMGS(tel);//先发号码delayms(500);send_text(message1);send_uart(high+0);delayms(10);send_text(message2);send_uart(Con_Floor+1+0);delayms(10);send_uart(0x1a);delayms(10);}else if (buf[high] > temp - 0&&(read_ds(4)>8)){send_AT_CMGS(tel);//先发号码delayms(500);send_text(message1);send_uart(buf[high]+0);delayms(10);send_text(message2);send_uart(Con_Floor+1+0);delayms(10);send_uart(0x1a);delayms(10);}else{send_AT_CMGS(tel);//先发号码delayms(500);send_text(message0);send_uart(low+0);delayms(10);send_text(message2);send_uart(Con_Floor-1+0);delayms(10);send_uart(0x1a);delayms(10);}}}}else if (test(floor_data)==2&&temp-0!=Con_Floor&&temp-0>=1&&Con_Floor>=1)//电梯未被请求,则响应,但是请求的楼层数就是本层楼则不予响应{if (temp - 0 > temp1 - 0&&(read_ds(4)>8)){low = temp1 - 0;buf[temp - 0] = temp1 - 0;floor_data[temp-0]=1;send_AT_CMGS(tel);//先发号码delayms(500);send_text(message3);send_text(message2);if(temp-0>Con_Floor)send_uart(Con_Floor+1+0);elsesend_uart(Con_Floor-1+0);delayms(10);send_uart(0x1a);delayms(10);}else if(temp - 0 > temp1 - 0&&(read_ds(4)<8)){send_AT_CMGS(tel);//先发号码delayms(500);send_text(message0);send_uart(low+0);delayms(10);send_text(message2);send_uart(Con_Floor+0);delayms(10);send_uart(0x1a);delayms(10);}else if(temp - 0 < temp1 - 0&&(read_ds(4)<5)){high = temp1 - 0;buf[temp - 0] = temp1 - 0 ;send_AT_CMGS(tel);//先发号码floor_data[temp-0]=1;delayms(500);send_text(message3);send_text(message2);if(temp-0 > Con_Floor)send_uart(Con_Floor+1+0);elsesend_uart(Con_Floor-1+0);delayms(10);send_uart(0x1a);delayms(10);}else if(temp - 0 < temp1 - 0&&(read_ds(4)>5))//不响应时执行{send_AT_CMGS(tel);//先发号码delayms(500);send_text(message0);send_uart(buf[low]+0);delayms(10);send_text(message2);send_uart(Con_Floor+1+0);delayms(10);send_uart(0x1a);delayms(10);}}}if(test(floor_data)==1)//下降{writefloor(Con_Floor);writestate(1);delayms(3000);Con_Floor--;}else if(!test(floor_data))//上升{writefloor(Con_Floor);writestate(0);delayms(3000);Con_Floor++;}else if (test(floor_data) == 2)//处于空闲状态{writefloor(Con_Floor);writestate(2);high = 9;low = 1 ;}if(floor_data[Con_Floor])//如果之前被请求过,则响应{P1=tab[Con_Floor];delayms(3000);if (buf[Con_Floor]!=0){floor_data[buf[Con_Floor]] = 1 ;buf[Con_Floor] = 0;}P1=0xff;floor_data[Con_Floor] = 0 ;}EA = 1 ;//开中断}}void delay(uint z){uint x,y;for(x=z;x>0;x--)for(y=110;y>0;y--);}void write_com(uchar com){rs=0;lcden=0;P0=com;delay(5);lcden=1;delay(5);lcden=0; }void write_date(uchar date){rs=1;lcden=0;P0=date;delay(5);lcden=1;delay(5);lcden=0; }void init(){uchar num;EA=1;EX0=1;IT0=1;dula=0;wela=0;lcden=0;write_ds(0x0B,0x26);read_ds(0x0c);write_com(0x38);write_com(0x0c);write_com(0x06);write_com(0x01);write_com(0x80);//for(num=0;num<15;num++){write_date(table[num]);delay(5);}write_com(0x80+0x40);for(num=0;num<12;num++){write_date(table1[num]);delay(5);}//miao=read_ds(0); fen=read_ds(2);shi=read_ds(4);write_sfm(10,miao);write_sfm(7,fen);write_sfm(4,shi);delayms(5000);write_com(0x80);write_com(0x01);//for(num=0;num<15;num++){write_date(welcome[num]);delay(20);}delay(3000);write_com(0x01);write_com(0x80+0x10);for(num=0;num<8;num++){write_date(floor[num]);delay(20);}write_com(0x80+0x50);for(num=0;num<11;num++){write_date(state[num]);delay(20);}for(num=0;num<16;num++){write_com(0x18);delay(50);}}void writefloor(int i){write_com(0x80+0x17);write_date(0x30+i);}void writestate(int flaggg){uint i ;write_com(0x80+0x57);if(flaggg==1){for(i=0;i0;i--)for(j=113;j>0;j--);}/* end function delayms *//\* 名称: com_int()* 功能: 串口中断子函数* 输入: 无* 输出: 无\/void com_int(void)

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top