51单片机GPS+sim800c GSM定位短信LCD1602液晶显示 原理图+PCB+源码

本文主要是介绍51单片机GPS+sim800c GSM定位短信LCD1602液晶显示 原理图+PCB+源码,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

1、实物图

2、原理图 

​3、PCB​编辑

4、程序

资料下载地址:51单片机GPS+sim800c GSM定位短信LCD1602液晶显示 原理图+PCB+源码

1、实物图

2、原理图 

 3、PCB

4、程序

#include "common.h"
#include "uart.h"
#include "gps.h"
#include "gsm.h"#include "lcd.h"#define GPS_STR_LEN 48uchar ess_inc;//char xdata GPS_SEND_STR[GPS_STR_LEN];sbit key = P1^3;
sbit key1 = P1^4;
sbit GPS_EN=P3^4;
sbit led1 = P3^3;
#define   RMC_YES    led1 = 0
#define   RMC_NO     led1 = 1GPS_INFO   GPS;  //GPS信息结构体bit GPS_rx_flag = 0;
bit GPS_Have_flag = 0;#define SEND_NUMBER "AT+CMGS=\"13420106297\"\r\n"char xdata send_data[37]="N:     ',E:     ',2000-00-00,00:00\r\n";
unsigned char send_len= 0;bit dis_flag = 1;
bit sendflag=0;/****************************************
显示时间
/****************************************/
void GPS_DispTime(void)
{uchar i = 0;uchar ch;char time[5];Int_To_Str(GPS.D.year,time);//年LCD1602_Set_AC(0, 1);i = 0;send_len = 18;while(time[i] != '\0'){ch = time[i++];LCD1602_write_data(ch);send_data[send_len++] = ch;}LCD1602_write_data('-');Int_To_Str(GPS.D.month,time);//月LCD1602_Set_AC(5, 1);i = 0;send_len = 23;while(time[i] != '\0'){ch = time[i++];LCD1602_write_data(ch);send_data[send_len++] = ch;}LCD1602_write_data('-');Int_To_Str(GPS.D.day,time);//日LCD1602_Set_AC(8, 1);i = 0;send_len = 26;while(time[i] != '\0'){ch = time[i++];LCD1602_write_data(ch);send_data[send_len++] = ch;}LCD1602_write_data(',');Int_To_Str(GPS.D.hour,time);//时LCD1602_Set_AC(11, 1);i = 0;send_len = 29;while(time[i] != '\0'){ch = time[i++];LCD1602_write_data(ch);send_data[send_len++] = ch;}LCD1602_write_data(':');Int_To_Str(GPS.D.minute,time);//分LCD1602_Set_AC(14, 1);i = 0;send_len = 32;while(time[i] != '\0'){ch = time[i++];LCD1602_write_data(ch);send_data[send_len++] = ch;}
}void GPS_DisplayOne(void)
{uchar len,ch, i;char info[10];ess_inc = 0;
//    memset(GPS_SEND_STR, 0, GPS_STR_LEN);if (GPS.NS == 'N')              //判断是北纬还是南纬{if(dis_flag)LCD1602_DisplayChar(0, 0, 'N');elseLCD1602_DisplayChar(0, 0, ' ');
//        GPS_SEND_STR[ess_inc ++] = 'N';len = 0;Int_To_Str(GPS.latitude_Degree,info);  //纬度LCD1602_Set_AC(1, 0);i = 0;send_len = 2;while(info[i] != '\0'){ch = info[i++];if(dis_flag)LCD1602_write_data(ch);elseLCD1602_write_data(' ');send_data[send_len++] = ch;
//            GPS_SEND_STR[ess_inc ++] = ch;len ++;}send_data[send_len++] = 'd';if(dis_flag)LCD1602_write_data(0xDF);elseLCD1602_write_data(' ');
//        GPS_SEND_STR[ess_inc ++] = 'd';len ++;Int_To_Str(GPS.latitude_Cent,info);  //纬分i = 0;while(info[i] != '\0'){ch = info[i++];if(dis_flag)LCD1602_write_data(ch);elseLCD1602_write_data(' ');send_data[send_len++] = ch;
//            GPS_SEND_STR[ess_inc ++] = ch;len ++;}if(dis_flag)LCD1602_write_data(0x27);elseLCD1602_write_data(' ');
//        GPS_SEND_STR[ess_inc ++] = 'm';Int_To_Str(GPS.latitude_Second,info);  //纬秒i = 0;while(info[i] != '\0'){ch = info[i++];
//            GPS_SEND_STR[ess_inc ++] = ch;}
//        GPS_SEND_STR[ess_inc ++] = 's';len ++;while(7 - len){len ++;LCD1602_write_data(' ');}}//    GPS_SEND_STR[ess_inc] = ',';ess_inc += 1;if (GPS.EW == 'E')                                //判断是东经还是西经{if(dis_flag)LCD1602_DisplayChar(8, 0, 'E');elseLCD1602_write_data(' ');
//        GPS_SEND_STR[ess_inc ++] = 'E';len = 0;Int_To_Str(GPS.longitude_Degree,info);  //经度LCD1602_Set_AC(9, 0);i = 0;send_len = 11;while(info[i] != '\0'){ch = info[i++];if(dis_flag)LCD1602_write_data(ch);elseLCD1602_write_data(' ');send_data[send_len++] = ch;
//            GPS_SEND_STR[ess_inc ++] = ch;len ++;}send_data[send_len++] = 'd';if(dis_flag)LCD1602_write_data(0xDF);elseLCD1602_write_data(' ');
//        GPS_SEND_STR[ess_inc ++] = 'd';len ++;Int_To_Str(GPS.longitude_Cent,info);  //经分i = 0;while(info[i] != '\0'){ch = info[i++];if(dis_flag)LCD1602_write_data(ch);elseLCD1602_write_data(' ');send_data[send_len++] = ch;
//            GPS_SEND_STR[ess_inc ++] = ch;len ++;}if(dis_flag)LCD1602_write_data(0x27);elseLCD1602_write_data(' ');
//        GPS_SEND_STR[ess_inc ++] = 'm';Int_To_Str(GPS.longitude_Second,info);        //经秒i = 0;while(info[i] != '\0'){ch = info[i++];//            GPS_SEND_STR[ess_inc ++] = ch;}
//        GPS_SEND_STR[ess_inc ++] = 's';len ++;while(7 - len){len ++;LCD1602_write_data(' ');}}GPS_DispTime();//    GPS_SEND_STR[ess_inc] = ' ';ess_inc += 1;if(sendflag==1){                        sendflag = 0;gsm_send_englishmsg(SEND_NUMBER,send_data);//发送位置短信                                delay_ms(1000);delay_ms(1000);LCD1602_DisplayString(0,0,"    SEND OK     "); delay_ms(1000);LCD1602_DisplayString(0,0,"                "); }//    GPS_DispSpeed(GPS.speed, 10, 1);//    if (GPS.D.second == 0)
//    {
//        if (GPS_Have_flag)
//        {
//            gsm_send_englishmsg(phonenum,GPS_SEND_STR);//发送位置短信
//        }
//        else
//        {
//            //gsm_send_englishmsg(phonenum,"GPS No Signal");//发送短信
//        }
//    }
}void main(void)
{uchar error_num = 0;uint count = 0;GPS_EN = 0;GPS_rx_flag = 0;LCD1602_Initialize();//LCD1602显示屏初始化uart_init(UART_B9600);GPS_EN = 1;GPS_rx_flag = 1;BG = 0;LCD1602_DisplayString_Center(0,"GPS SCAN...");LCD1602_ClearLine(1);

 

这篇关于51单片机GPS+sim800c GSM定位短信LCD1602液晶显示 原理图+PCB+源码的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/988123

相关文章

无人叉车3d激光slam多房间建图定位异常处理方案-墙体画线地图切分方案

墙体画线地图切分方案 针对问题:墙体两侧特征混淆误匹配,导致建图和定位偏差,表现为过门跳变、外月台走歪等 ·解决思路:预期的根治方案IGICP需要较长时间完成上线,先使用切分地图的工程化方案,即墙体两侧切分为不同地图,在某一侧只使用该侧地图进行定位 方案思路 切分原理:切分地图基于关键帧位置,而非点云。 理论基础:光照是直线的,一帧点云必定只能照射到墙的一侧,无法同时照到两侧实践考虑:关

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟 开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚 第一站:海量资源,应有尽有 走进“智听

day-51 合并零之间的节点

思路 直接遍历链表即可,遇到val=0跳过,val非零则加在一起,最后返回即可 解题过程 返回链表可以有头结点,方便插入,返回head.next Code /*** Definition for singly-linked list.* public class ListNode {* int val;* ListNode next;* ListNode() {}*

Java ArrayList扩容机制 (源码解读)

结论:初始长度为10,若所需长度小于1.5倍原长度,则按照1.5倍扩容。若不够用则按照所需长度扩容。 一. 明确类内部重要变量含义         1:数组默认长度         2:这是一个共享的空数组实例,用于明确创建长度为0时的ArrayList ,比如通过 new ArrayList<>(0),ArrayList 内部的数组 elementData 会指向这个 EMPTY_EL

如何在Visual Studio中调试.NET源码

今天偶然在看别人代码时,发现在他的代码里使用了Any判断List<T>是否为空。 我一般的做法是先判断是否为null,再判断Count。 看了一下Count的源码如下: 1 [__DynamicallyInvokable]2 public int Count3 {4 [__DynamicallyInvokable]5 get

工厂ERP管理系统实现源码(JAVA)

工厂进销存管理系统是一个集采购管理、仓库管理、生产管理和销售管理于一体的综合解决方案。该系统旨在帮助企业优化流程、提高效率、降低成本,并实时掌握各环节的运营状况。 在采购管理方面,系统能够处理采购订单、供应商管理和采购入库等流程,确保采购过程的透明和高效。仓库管理方面,实现库存的精准管理,包括入库、出库、盘点等操作,确保库存数据的准确性和实时性。 生产管理模块则涵盖了生产计划制定、物料需求计划、

基于51单片机的自动转向修复系统的设计与实现

文章目录 前言资料获取设计介绍功能介绍设计清单具体实现截图参考文献设计获取 前言 💗博主介绍:✌全网粉丝10W+,CSDN特邀作者、博客专家、CSDN新星计划导师,一名热衷于单片机技术探索与分享的博主、专注于 精通51/STM32/MSP430/AVR等单片机设计 主要对象是咱们电子相关专业的大学生,希望您们都共创辉煌!✌💗 👇🏻 精彩专栏 推荐订阅👇🏻 单片机

Spring 源码解读:自定义实现Bean定义的注册与解析

引言 在Spring框架中,Bean的注册与解析是整个依赖注入流程的核心步骤。通过Bean定义,Spring容器知道如何创建、配置和管理每个Bean实例。本篇文章将通过实现一个简化版的Bean定义注册与解析机制,帮助你理解Spring框架背后的设计逻辑。我们还将对比Spring中的BeanDefinition和BeanDefinitionRegistry,以全面掌握Bean注册和解析的核心原理。

音视频入门基础:WAV专题(10)——FFmpeg源码中计算WAV音频文件每个packet的pts、dts的实现

一、引言 从文章《音视频入门基础:WAV专题(6)——通过FFprobe显示WAV音频文件每个数据包的信息》中我们可以知道,通过FFprobe命令可以打印WAV音频文件每个packet(也称为数据包或多媒体包)的信息,这些信息包含该packet的pts、dts: 打印出来的“pts”实际是AVPacket结构体中的成员变量pts,是以AVStream->time_base为单位的显

kubelet组件的启动流程源码分析

概述 摘要: 本文将总结kubelet的作用以及原理,在有一定基础认识的前提下,通过阅读kubelet源码,对kubelet组件的启动流程进行分析。 正文 kubelet的作用 这里对kubelet的作用做一个简单总结。 节点管理 节点的注册 节点状态更新 容器管理(pod生命周期管理) 监听apiserver的容器事件 容器的创建、删除(CRI) 容器的网络的创建与删除