玩转车联网3---通讯方式和通讯协议

2023-10-23 07:20

本文主要是介绍玩转车联网3---通讯方式和通讯协议,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

阅读下文前,建议对OBD有初步了解,可阅读下面两篇:

玩转车联网1---初识OBD和行车助手

玩转车联网2--汽车内部通讯和车联网整体架构

上一篇博文提到了汽车内部的通讯方式,但是我们的程序是如何与OBD之间进行通讯的呢?

这里就涉及到两个问题:通讯方式和通讯协议。先上一张OBD安装在蒙迪欧致胜上的效果图:

1. 通讯方式

对于大多数的OBD硬件来说,多采用蓝牙、WIFI、串口等几种方式。

下面看看几种模式在实际使用场景中,对于普通消费者的优缺点:

 优点缺点
蓝牙可与智能手机连接,不占用智能手机网络信道因为大部分用户的蓝牙功能是关闭的,用户可能会上车后可能忘记打开蓝牙
WIFI可与智能手机连接,用户一般情况下会打开手机WIFI功能由于智能手机连接OBD后,相当于构成个车内局域网,因此占用手机网络信道,不能上外网
串口非常稳定, 适合作为检测设备不可与智能手机连接

  

  根据利弊分析,作为消费级的产品,采用串口作为通讯方式肯定是不行的。蓝牙和WIFI相比较,蓝牙模块的成本更低,更加稳定,因此优先选择蓝牙模块。我相信这也是为什么大多数的可穿戴设备选择蓝牙的原因。当然,在软件设计上,可以将蓝牙和WIFI虚拟成一个ICommunication接口,方便程序的扩展。本文不作重点讲述,以后会在Android蓝牙自动重连章节着重展开。

2. 市面上的OBD

  上文中对于OBD的通讯方式有了简要介绍,再进行通讯协议之前,我们先说说市面上的OBD吧。

  

      市面上有众多OBD产品,最常用的是Elm327(便宜,淘宝上40几块,蓝牙的),当然还有EST527, XTool,国外还有好多,从几十到上千不等。为什么会有价格差别?

1.产品质量,所谓一分价钱一分货

2.软件支持,其他厂商的可以配合他们自己的硬件实现特有的软件服务,例如将OBD同保险和汽车维修服务挂钩。

3.硬件支持,其他厂商会增加GPS/GPRS/3G等模块,不需要智能手机,可以通过OBD硬件直接将数据传到后台。

      但是我想做的是一个相对通用的开发者平台,尽量支持市面上的OBD硬件。一个厂商或者一个开发者的能力是有限的,降低开发门槛,提供最基础的SDK服务,发挥广大人民的想象力,开发出更多更实用的应用。

      那么是否有这种可能性呢?答案是可能的。因为大部分的硬件厂商都是在Elm327上进行扩展,我们只要把Elm327吃透,支持一种新的设备也是很迅速的事情。

 

3. 通讯协议

回归正题,那么OBD的通讯协议时怎样的呢,这里只做简单介绍。

3.1 OBD能提供的服务

OBD主要有下面九种服务,每一种服务都可以延伸很多东西,我们先着重关注服务1(Mode1)。

Mode 1: 请求动力系当前数据(发动机转速、速度、水温、油耗等数据)
Mode 2: 请求冻结祯数据
Mode 3: 请求排放相关的动力系诊断故障码
Mode 4: 清除/复位排放相关的诊断信息
Mode 5: 请求氧传感器监测测试结果
Mode 6: 请求非连续监测系统OBD测试结果
Mode 7: 请求连续监测系统OBD测试结果
Mode 8: 请求控制车载系统,测试或者部件(中国市场开发的OBD系统不支持该模式)
Mode 9: 读车辆和标定识别号

即使Mode1下真正能读取的数据远远不止下面这些,暂且说几个最常用的吧。

      油耗系:读取动力系数据(瞬时油耗、当前油量)

      引擎类(速度、发动机转速)

      温度系(水温等数据)

      故障码类(故障码个数,故障码详细,清除故障码等)。

 

3.2. OBD数据协议格式

   这里是基础的基础,我们以CAN总线的OBD数据格式为例,其中ELM327也是采用这种数据格式。

       ID表示CAN总线的ID;

       PCI表示协议控制的信息数;

       7 data bytes非常关键,表示Mode+PID,例如,如果是车速,那么这里就应该是01(Mode1) + 0D(车速)

       Checksum:校验码

 

3.3. 最简单的OBD消息交互---获取水温

       以获取水温为例:

       发送:>01 05 (Mode1:01 动力系, PID:05 水温)

       返回:41 05 7B  

       下面是返回的解释:

       41=40+01,具体40是什么有点忘了,表示是从01 <Mode1返回的,05表示是PID05

       7B转换成10进制为7*16 + 11 = 123 (华氏温度),

       即123-40 = 83摄氏度

 

哎哎,终于写完了,比较讨厌写这种纯技术类的文章,好累。

最后发一张正在开发的Android车机界面原型图,鼓励自己.

 

 

 

 

转载于:https://www.cnblogs.com/enjoyeclipse/p/3456460.html

这篇关于玩转车联网3---通讯方式和通讯协议的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Debezium 与 Apache Kafka 的集成方式步骤详解

《Debezium与ApacheKafka的集成方式步骤详解》本文详细介绍了如何将Debezium与ApacheKafka集成,包括集成概述、步骤、注意事项等,通过KafkaConnect,D... 目录一、集成概述二、集成步骤1. 准备 Kafka 环境2. 配置 Kafka Connect3. 安装 D

Springboot中分析SQL性能的两种方式详解

《Springboot中分析SQL性能的两种方式详解》文章介绍了SQL性能分析的两种方式:MyBatis-Plus性能分析插件和p6spy框架,MyBatis-Plus插件配置简单,适用于开发和测试环... 目录SQL性能分析的两种方式:功能介绍实现方式:实现步骤:SQL性能分析的两种方式:功能介绍记录

SQL 中多表查询的常见连接方式详解

《SQL中多表查询的常见连接方式详解》本文介绍SQL中多表查询的常见连接方式,包括内连接(INNERJOIN)、左连接(LEFTJOIN)、右连接(RIGHTJOIN)、全外连接(FULLOUTER... 目录一、连接类型图表(ASCII 形式)二、前置代码(创建示例表)三、连接方式代码示例1. 内连接(I

Android里面的Service种类以及启动方式

《Android里面的Service种类以及启动方式》Android中的Service分为前台服务和后台服务,前台服务需要亮身份牌并显示通知,后台服务则有启动方式选择,包括startService和b... 目录一句话总结:一、Service 的两种类型:1. 前台服务(必须亮身份牌)2. 后台服务(偷偷干

Java深度学习库DJL实现Python的NumPy方式

《Java深度学习库DJL实现Python的NumPy方式》本文介绍了DJL库的背景和基本功能,包括NDArray的创建、数学运算、数据获取和设置等,同时,还展示了如何使用NDArray进行数据预处理... 目录1 NDArray 的背景介绍1.1 架构2 JavaDJL使用2.1 安装DJL2.2 基本操

最长公共子序列问题的深度分析与Java实现方式

《最长公共子序列问题的深度分析与Java实现方式》本文详细介绍了最长公共子序列(LCS)问题,包括其概念、暴力解法、动态规划解法,并提供了Java代码实现,暴力解法虽然简单,但在大数据处理中效率较低,... 目录最长公共子序列问题概述问题理解与示例分析暴力解法思路与示例代码动态规划解法DP 表的构建与意义动

JS 实现复制到剪贴板的几种方式小结

《JS实现复制到剪贴板的几种方式小结》本文主要介绍了JS实现复制到剪贴板的几种方式小结,包括ClipboardAPI和document.execCommand这两种方法,具有一定的参考价值,感兴趣的... 目录一、Clipboard API相关属性方法二、document.execCommand优点:缺点:

Python创建Excel的4种方式小结

《Python创建Excel的4种方式小结》这篇文章主要为大家详细介绍了Python中创建Excel的4种常见方式,文中的示例代码简洁易懂,具有一定的参考价值,感兴趣的小伙伴可以学习一下... 目录库的安装代码1——pandas代码2——openpyxl代码3——xlsxwriterwww.cppcns.c

Deepseek使用指南与提问优化策略方式

《Deepseek使用指南与提问优化策略方式》本文介绍了DeepSeek语义搜索引擎的核心功能、集成方法及优化提问策略,通过自然语言处理和机器学习提供精准搜索结果,适用于智能客服、知识库检索等领域... 目录序言1. DeepSeek 概述2. DeepSeek 的集成与使用2.1 DeepSeek API

CSS弹性布局常用设置方式

《CSS弹性布局常用设置方式》文章总结了CSS布局与样式的常用属性和技巧,包括视口单位、弹性盒子布局、浮动元素、背景和边框样式、文本和阴影效果、溢出隐藏、定位以及背景渐变等,通过这些技巧,可以实现复杂... 一、单位元素vm 1vm 为视口的1%vh 视口高的1%vmin 参照长边vmax 参照长边re