039——解决室内不能使用GPS问题

2024-05-13 04:04

本文主要是介绍039——解决室内不能使用GPS问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

引入

GUI整改

client添加GPS分析

完善服务器网络通讯部分代码

添加GPS的BSW层

GPS操作部分代码(相当于驱动)

效果展示

项目管理操作


引入

        最近在写论文加上出去玩了一圈所以停更了一段时间。上次咱们GPS有个室内用不了的问题,咱们看看咋解决一下。

GUI整改

'''
fuction : 客户端界面
author  : 辛天宇
date    : 2024-4-12
-------------------------------
author  date     modify
辛天宇 2024-4-12 引入大小控制全局设置功能'''
import PySimpleGUI as sg
import tool
import global_var# 调用显示框架
def show_window(theme):# 是否使用自定义标题栏use_custom_titlebar = False# 设置主题sg.theme(theme)# 创建菜单Menu = sg.Menu# 左部layoutlayout_l =  [[tool.name('NetWork'), sg.Button('Connect', key='Connect', font=global_var.GLOBAL_FONT)],[tool.name('NetWork'), sg.Button('Disconnect', key='Disconnect', font=global_var.GLOBAL_FONT)],[tool.name('NetWork'), sg.Output(size=(32, 1), key='IP', font=global_var.GLOBAL_FONT)],[sg.Checkbox('Input', use_custom_titlebar, enable_events=True, key='input', font=global_var.GLOBAL_FONT)],[sg.InputText(disabled=True, key='txbuff', font=global_var.GLOBAL_FONT), sg.Button('SEND', key='send', font=global_var.GLOBAL_FONT)],[sg.Slider(range=(0, 100), orientation='h', size=(57, 40), default_value=0, key='DAC', enable_events=True, font=global_var.GLOBAL_FONT), sg.Text('DAC', size=(5,2), justification='c',pad=(0,(20,0)), font=global_var.GLOBAL_FONT)],[sg.InputText(key='AT24C02_I', default_text='', font=global_var.GLOBAL_FONT), sg.Button('AT24C02 WRITE', key='AT24C02_W', font=global_var.GLOBAL_FONT)],]# 右部layoutlayout_r  = [[sg.Output(size=(global_var.OUTPUT_X, global_var.OUTPUT_Y), key='LED_O', font=global_var.GLOBAL_FONT), sg.Button('LED', key='LED', font=global_var.GLOBAL_FONT)],[sg.Output(size=(global_var.OUTPUT_X, global_var.OUTPUT_Y), key='SR501_O', font=global_var.GLOBAL_FONT), sg.Button('SR501', key='SR501', font=global_var.GLOBAL_FONT)],[sg.Output(size=(global_var.OUTPUT_X, global_var.OUTPUT_Y), key='SR04_O', font=global_var.GLOBAL_FONT), sg.Button('SR04', key='SR04', font=global_var.GLOBAL_FONT)],[sg.Output(size=(global_var.OUTPUT_X, global_var.OUTPUT_Y), key='IRDA_O', font=global_var.GLOBAL_FONT), sg.Button('IRDA', key='IRDA', font=global_var.GLOBAL_FONT)],[sg.Output(size=(global_var.OUTPUT_X, global_var.OUTPUT_Y), key='DHT11_O', font=global_var.GLOBAL_FONT), sg.Button('DHT11', key='dht11', font=global_var.GLOBAL_FONT)],[sg.Output(size=(global_var.OUTPUT_X, global_var.OUTPUT_Y), key='DS18B20_O', font=global_var.GLOBAL_FONT), sg.Button('DS18B20', key='ds18b20', font=global_var.GLOBAL_FONT)],[sg.Output(size=(global_var.OUTPUT_X, global_var.OUTPUT_Y), key='GPS_O', font=global_var.GLOBAL_FONT), sg.Button('DIRECT', key='GPS_direct', font=global_var.GLOBAL_FONT), sg.Button('MEMORY', key='GPS_memory', font=global_var.GLOBAL_FONT)],[sg.Output(size=(global_var.OUTPUT_X, global_var.OUTPUT_Y), key='AT24C02_O', font=global_var.GLOBAL_FONT), sg.Button('AT24C02 READ', key='AT24C02_R', font=global_var.GLOBAL_FONT)],#[tool.name('Text'), sg.Button('IIC', key='IIC')],]# 修饰topic = tool.add_stars_to_string(global_var.TOPIC, 10)# 整体layoutlayout = [[sg.T(topic, text_color='blue', justification='c', font=global_var.topic_font)],[sg.Col(layout_l), sg.Col(layout_r)],[sg.Text('Output:', size=(7,1), justification='r',pad=(0,0), font=global_var.GLOBAL_FONT),],[sg.Output(size=(120, 16), key='Output', font=global_var.GLOBAL_FONT)],[sg.Button('Clean', key='Clean'), sg.Button('Quit', key='Quit')]]window = sg.Window('The PySimpleGUI Element List', layout, finalize=True, keep_on_top=True)return window# 处理事件
def event_handle():window = show_window('DefaultNoMoreNagging')# 事件循环  while True:  try:event, values = window.read()if event == 'Exit':  breakif event == 'dht11':message = f"{global_var.TEM}°C   {global_var.HUM}%"window['Getvalue'].update(message)if event == 'ds18b20':message = f"{global_var.TEM}°C"window['Getvalue'].update(message)if event == 'input': print(f"INPUT-----------------") elif event == 'Quit':  print(f"See you.............")break# elif event == 'Connect':#     global_var.SERVER_IP = "192.168.5.10"#     window['IP'].update(global_var.SERVER_IP)# elif event == 'Disconnect':  #     global_var.SERVER_IP = "connectionless network service"#     window['IP'].update(global_var.SERVER_IP)elif event is None:print(f"xxxxxxxxxxxxxxxxxxxx")breakelif event == 'LED':  print(f"LED-----------------") # 处理其他事件...except Exception as e:window.close()print(f"An error occurred: {e}")return 0window.close()return 0  def main():# theme参考/client/READMEevent_handle()if __name__ == '__main__':main()

        之前给老师看了下ui,老师说字太小了所以这次我优化了一下可以通过全局变量控制。

这次够大了吧

这里可以控制大小设定了

client添加GPS分析

        接收到的数据只有成功和失败两种,但是发送的话我设置了两种模式direct和memory。

         direct:    这种模式是直接启动GPS读取实际的数据,但是我们室内肯定用不了GPS哇。于是就加个读取存储器的默认值。

         memory:这个模式就是直接读取存储器的默认值

GPS的命令不多所以两种模式共用一个设备号

完善服务器网络通讯部分代码

        这块就比较简单了,基本和以前的没啥区别。后面这里要整合一下抽象出一个函数来。可以缩小代码体积。

添加GPS的BSW层

/*
* func        : Handle dac Settings
* return      : error code
* input       : <cmd> (GPS cmd)
* output      :<data> (longitude and latitude)
* author      date     modify
--------------------------------xintianyu  2024-5-11  create
*/
int gps_handle(GPS_CMD cmd, char *data)
{char *device = "/dev/ttymxc5";int fd;int iRet;char *memory = usth;char buf[1000];char time[100];char Lat[100]; char ns[100]; char Lng[100]; char ew[100];float fLat, fLng;/* 1. open *//* 2. setup * 115200,8N1* RAW mode* return data immediately*//* 3. write and read */if (cmd_direct == cmd){fd = open_port(device);if (fd < 0){printf("open %s err!\n", device);return -1;}iRet = set_uart(fd, 9600, 8, 'N', 1);if (iRet){printf("set port err!\n");return iRet;}/* eg. $GPGGA,082559.00,4005.22599,N,11632.58234,E,1,04,3.08,14.6,M,-5.6,M,,*76"<CR><LF>*//* read line */iRet = read_gps_raw_data(fd, buf);/* parse line */if (iRet == 0){iRet = parse_gps_raw_data(buf, time, Lat, ns, Lng, ew);}/* printf */if (iRet == 0){printf("Time : %s\n", time);printf("ns   : %s\n", ns);printf("ew   : %s\n", ew);printf("Lat  : %s\n", Lat);printf("Lng  : %s\n", Lng);/* 纬度格式: ddmm.mmmm */sscanf(Lat+2, "%f", &fLat);fLat = fLat / 60;fLat += (Lat[0] - '0')*10 + (Lat[1] - '0');/* 经度格式: dddmm.mmmm */sscanf(Lng+3, "%f", &fLng);fLng = fLng / 60;fLng += (Lng[0] - '0')*100 + (Lng[1] - '0')*10 + (Lng[2] - '0');printf("Lng,Lat: %.06f,%.06f\n", fLng, fLat);sprintf(data,"@009s%s%s", Lng, Lat);}else{sprintf(data,"@009e");}}else if(cmd_memory == cmd){sprintf(data,"@009s%s", memory);}else{sprintf(data,"@009e");}return 0;
}

大部分内容沿用了韦东山老师的代码,在外层封装了个任务判断而已。

GPS操作部分代码(相当于驱动)

/*
* func        : set uart
* return      : err code
* input       : <fd> (uart device) <Speed> (speed) <Bits> (bits) <Event> (event) <Stop> (stop bit)
* output      :NULL
* author      date     modify
--------------------------------weidongshan  2024-5-11  create
*/
int set_uart(int fd, int Speed, int Bits, char Event, int Stop)
{struct termios newtio,oldtio;if ( tcgetattr( fd,&oldtio) != 0) { perror("SetupSerial 1");return -1;}bzero( &newtio, sizeof( newtio ) );newtio.c_cflag |= CLOCAL | CREAD; newtio.c_cflag &= ~CSIZE; newtio.c_lflag  &= ~(ICANON | ECHO | ECHOE | ISIG);  /*Input*/newtio.c_oflag  &= ~OPOST;   /*Output*/switch( Bits ){case 7:newtio.c_cflag |= CS7;break;case 8:newtio.c_cflag |= CS8;break;}switch( Event ){case 'O':newtio.c_cflag |= PARENB;newtio.c_cflag |= PARODD;newtio.c_iflag |= (INPCK | ISTRIP);break;case 'E': newtio.c_iflag |= (INPCK | ISTRIP);newtio.c_cflag |= PARENB;newtio.c_cflag &= ~PARODD;break;case 'N': newtio.c_cflag &= ~PARENB;break;}switch( Speed ){case 2400:cfsetispeed(&newtio, B2400);cfsetospeed(&newtio, B2400);break;case 4800:cfsetispeed(&newtio, B4800);cfsetospeed(&newtio, B4800);break;case 9600:cfsetispeed(&newtio, B9600);cfsetospeed(&newtio, B9600);break;case 115200:cfsetispeed(&newtio, B115200);cfsetospeed(&newtio, B115200);break;default:cfsetispeed(&newtio, B9600);cfsetospeed(&newtio, B9600);break;}if( Stop == 1 )newtio.c_cflag &= ~CSTOPB;else if ( Stop == 2 )newtio.c_cflag |= CSTOPB;newtio.c_cc[VMIN]  = 1;  /* 读数据时的最小字节数: 没读到这些数据我就不返回! */newtio.c_cc[VTIME] = 0; /* 等待第1个数据的时间: * 比如VMIN设为10表示至少读到10个数据才返回,* 但是没有数据总不能一直等吧? 可以设置VTIME(单位是10秒)* 假设VTIME=1,表示: *    10秒内一个数据都没有的话就返回*    如果10秒内至少读到了1个字节,那就继续等待,完全读到VMIN个数据再返回*/tcflush(fd,TCIFLUSH);if((tcsetattr(fd,TCSANOW,&newtio))!=0){perror("com set error");return -1;}//printf("set done!\n");return 0;
}/*
* func        : set uart
* return      : err code
* input       : <com> (uart id)
* output      :NULL
* author      date     modify
--------------------------------weidongshan  2024-5-11  create
*/
int open_port(char *com)
{int fd;//fd = open(com, O_RDWR|O_NOCTTY|O_NDELAY);fd = open(com, O_RDWR|O_NOCTTY);if (-1 == fd){return(-1);}if(fcntl(fd, F_SETFL, 0)<0) /* 设置串口为阻塞状态*/{printf("fcntl failed!\n");return -1;}return fd;
}/*
* func        : read gps values
* return      : err code
* input       : <fd> (device id) <buf> (values)
* output      :NULL
* author      date     modify
--------------------------------weidongshan  2024-5-11  create
*/
int read_gps_raw_data(int fd, char *buf)
{int i = 0;int iRet;char c;int start = 0;while (1){iRet = read(fd, &c, 1);if (iRet == 1){if (c == '$')start = 1;if (start){buf[i++] = c;}if (c == '\n' || c == '\r')return 0;}else{return -1;}}
}/*
* func        : gps values handle
* return      : err code
* input       : <buf> (values) <time> (time) <ns> (Northern and southern hemispheres) <ew> (Eastern and western hemispheres)
*             : <lat> (latitude) <lng> (longitude)
* output      :NULL
* author      date     modify
--------------------------------weidongshan  2024-5-11  create
*/
/* eg. $GPGGA,082559.00,4005.22599,N,11632.58234,E,1,04,3.08,14.6,M,-5.6,M,,*76"<CR><LF> */
int parse_gps_raw_data(char *buf, char *time, char *lat, char *ns, char *lng, char *ew)
{char tmp[10];if (buf[0] != '$')return -1;else if (strncmp(buf+3, "GGA", 3) != 0)return -1;else if (strstr(buf, ",,,,,")){printf("Place the GPS to open area\n");return -1;}else {//printf("raw data: %s\n", buf);sscanf(buf, "%[^,],%[^,],%[^,],%[^,],%[^,],%[^,]", tmp, time, lat, ns, lng, ew);return 0;}
}

        我直接拿韦东山老师的代码过来用了,这些代码都比较简单,就是打开串口设置串口读取数据和数据处理。严格来说韦东山老师也是仿照linux源码的驱动程序写的。在国外引用思想也要表明。但是国内版权意识比较差这里也没要求。如果严格实施的话估计全世界都成为GPL的天下了哈哈。

效果展示

项目管理操作

这篇关于039——解决室内不能使用GPS问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

中文分词jieba库的使用与实景应用(一)

知识星球:https://articles.zsxq.com/id_fxvgc803qmr2.html 目录 一.定义: 精确模式(默认模式): 全模式: 搜索引擎模式: paddle 模式(基于深度学习的分词模式): 二 自定义词典 三.文本解析   调整词出现的频率 四. 关键词提取 A. 基于TF-IDF算法的关键词提取 B. 基于TextRank算法的关键词提取

使用SecondaryNameNode恢复NameNode的数据

1)需求: NameNode进程挂了并且存储的数据也丢失了,如何恢复NameNode 此种方式恢复的数据可能存在小部分数据的丢失。 2)故障模拟 (1)kill -9 NameNode进程 [lytfly@hadoop102 current]$ kill -9 19886 (2)删除NameNode存储的数据(/opt/module/hadoop-3.1.4/data/tmp/dfs/na

Hadoop数据压缩使用介绍

一、压缩原则 (1)运算密集型的Job,少用压缩 (2)IO密集型的Job,多用压缩 二、压缩算法比较 三、压缩位置选择 四、压缩参数配置 1)为了支持多种压缩/解压缩算法,Hadoop引入了编码/解码器 2)要在Hadoop中启用压缩,可以配置如下参数

Makefile简明使用教程

文章目录 规则makefile文件的基本语法:加在命令前的特殊符号:.PHONY伪目标: Makefilev1 直观写法v2 加上中间过程v3 伪目标v4 变量 make 选项-f-n-C Make 是一种流行的构建工具,常用于将源代码转换成可执行文件或者其他形式的输出文件(如库文件、文档等)。Make 可以自动化地执行编译、链接等一系列操作。 规则 makefile文件

好题——hdu2522(小数问题:求1/n的第一个循环节)

好喜欢这题,第一次做小数问题,一开始真心没思路,然后参考了网上的一些资料。 知识点***********************************无限不循环小数即无理数,不能写作两整数之比*****************************(一开始没想到,小学没学好) 此题1/n肯定是一个有限循环小数,了解这些后就能做此题了。 按照除法的机制,用一个函数表示出来就可以了,代码如下

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

使用opencv优化图片(画面变清晰)

文章目录 需求影响照片清晰度的因素 实现降噪测试代码 锐化空间锐化Unsharp Masking频率域锐化对比测试 对比度增强常用算法对比测试 需求 对图像进行优化,使其看起来更清晰,同时保持尺寸不变,通常涉及到图像处理技术如锐化、降噪、对比度增强等 影响照片清晰度的因素 影响照片清晰度的因素有很多,主要可以从以下几个方面来分析 1. 拍摄设备 相机传感器:相机传

如何解决线上平台抽佣高 线下门店客流少的痛点!

目前,许多传统零售店铺正遭遇客源下降的难题。尽管广告推广能带来一定的客流,但其费用昂贵。鉴于此,众多零售商纷纷选择加入像美团、饿了么和抖音这样的大型在线平台,但这些平台的高佣金率导致了利润的大幅缩水。在这样的市场环境下,商家之间的合作网络逐渐成为一种有效的解决方案,通过资源和客户基础的共享,实现共同的利益增长。 以最近在上海兴起的一个跨行业合作平台为例,该平台融合了环保消费积分系统,在短

pdfmake生成pdf的使用

实际项目中有时会有根据填写的表单数据或者其他格式的数据,将数据自动填充到pdf文件中根据固定模板生成pdf文件的需求 文章目录 利用pdfmake生成pdf文件1.下载安装pdfmake第三方包2.封装生成pdf文件的共用配置3.生成pdf文件的文件模板内容4.调用方法生成pdf 利用pdfmake生成pdf文件 1.下载安装pdfmake第三方包 npm i pdfma

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]