1.ADS1115中文资料:https://wenku.baidu.com/view/8bab101feef9aef8941ea76e58fafab069dc44e7.html?rec_flag=default&sxts=1557987780920

2.IIC协议程序

IIC协议是大多数传感的通信协议,每个嵌入式工程师都要有自己的IIC底层协议

IIC可细分为7个函数

1.开始

2.读取

3.发送

4.结束

5.主机检测从机应答

6. 主机应答

7. 主机不应答

/*******************************************************************************
*
*
* Protocol Part
*
*
****************************************************************************** */ /*******************************************************************************
* Function Name : vIIC_Start_Signal
* Description : Master Send Start Signal
* Input : None
* Output : None
* Return : None
****************************************************************************** */
void vIIC_Start_Signal(IIC_HandleTypedef * hIICx)
{ IIC_SDA_1 (hIICx); //拉高数据线
IIC_SCL_1 (hIICx); //拉高时钟线
vIIC_Delay_2us ( ); //延时
IIC_SDA_0 (hIICx); //拉低数据线
vIIC_Delay_2us ( ); //延时
IIC_SCL_0 (hIICx); //拉低时钟线
vIIC_Delay_2us ( ); //延时
} /*******************************************************************************
* Function Name : vIIC_SendByte
* Description : Master Send a Byte to Slave
* Input : Will Send Date
* Output : None
* Return : None
****************************************************************************** */
void vIIC_SendByte(IIC_HandleTypedef * hIICx,uint8_t uSendByte)
{ uint8_t i; for (i=; i<; i++)
{
if(uSendByte & 0X80)
IIC_SDA_1 (hIICx);
else
IIC_SDA_0 (hIICx);
uSendByte <<= ;
vIIC_Delay_1us ( );
IIC_SCL_1 (hIICx);
vIIC_Delay_2us ( );
IIC_SCL_0 (hIICx);
vIIC_Delay_1us ( ); } } /*******************************************************************************
* Function Name : uIIC_RecvByte
* Description : Master Reserive a Byte From Slave
* Input : None
* Output : None
* Return : Date From Slave
****************************************************************************** */
uint8_t uIIC_RecvByte(IIC_HandleTypedef * hIICx)
{
uint8_t i,uReceiveByte = ; IIC_GPIO_MODE_Ipt (hIICx);
IIC_SDA_1 (hIICx);
for(i=;i<;i++)
{
uReceiveByte <<= ; vIIC_Delay_1us ( );
IIC_SCL_1 (hIICx);
vIIC_Delay_1us ( ); if(IIC_SDA_R (hIICx))
{
uReceiveByte |=0x01;
} vIIC_Delay_1us ( );
IIC_SCL_0 (hIICx);
vIIC_Delay_1us ( );
}
IIC_GPIO_MODE_Opt (hIICx); return uReceiveByte; } /*******************************************************************************
* Function Name : vIIC_Ack
* Description : Master Send Acknowledge Single
* Input : None
* Output : None
* Return : None
****************************************************************************** */
void vIIC_Ack(IIC_HandleTypedef * hIICx)
{ IIC_SDA_0 (hIICx); //拉低数据位
vIIC_Delay_1us ( ); //延时
IIC_SCL_1 (hIICx); //拉高时钟位
vIIC_Delay_2us ( ); //延时
IIC_SCL_0 (hIICx); //拉低时钟位
vIIC_Delay_1us ( ); //延时 } /*******************************************************************************
* Function Name : vProto_IIC_NAck
* Description :
* Input : None
* Output : None
* Return : None
****************************************************************************** */
void vIIC_NAck(IIC_HandleTypedef * hIICx)
{ IIC_SDA_1 (hIICx); //SDA拉高 不应答对方
vIIC_Delay_1us ( );
IIC_SCL_1 (hIICx);
vIIC_Delay_2us ( );
IIC_SCL_0 (hIICx);
vIIC_Delay_1us ( ); } /*******************************************************************************
* Function Name : bIIC_ReadACK
* Description : Master Reserive Slave Acknowledge Single
* Input : None
* Output : None
* Return : None
****************************************************************************** */
bool bIIC_ReadACK(IIC_HandleTypedef * hIICx) //返回为:=1有ACK,=0无ACK
{
IIC_GPIO_MODE_Ipt (hIICx);
IIC_SDA_1 (hIICx); //拉高数据线
vIIC_Delay_1us ( ); //延时
IIC_SCL_1 (hIICx); //拉高时钟线
vIIC_Delay_2us ( ); //延时 if(IIC_SDA_R(hIICx))
{
vIIC_Delay_1us( );
IIC_SCL_0 (hIICx);
vIIC_Delay_1us( );
IIC_GPIO_MODE_Opt(hIICx);
return FALSE; // 没有应答
}
else
{
vIIC_Delay_1us( );
IIC_SCL_0 (hIICx);
vIIC_Delay_1us( );
IIC_GPIO_MODE_Opt(hIICx);
return TRUE;
} } /*******************************************************************************
* Function Name : vIIC_Stop_Signal
* Description : Master Send Stop Signal
* Input : None
* Output : None
* Return : None
****************************************************************************** */
void vIIC_Stop_Signal(IIC_HandleTypedef * hIICx)
{ IIC_SDA_0 (hIICx); //拉低数据线
vIIC_Delay_2us ( ); //延时
IIC_SCL_1 (hIICx); //拉高时钟线
vIIC_Delay_2us ( ); //延时
IIC_SDA_1 (hIICx); //拉高数据线
vIIC_Delay_2us ( ); //延时 }

3.寄存器操作

ADS1115的ADDR引脚接地,则寄存器地址为0x90

ADS1115的操作只有3步

1.向配置寄存器0x01写入配置,先写高8位,再写低8位

void uSen_ADS1115_Confight(IIC_HandleTypedef * iicHandle)
{
vIIC_Start_Signal(iicHandle); //1. IIC_Start ; 起始信号
vIIC_SendByte(iicHandle, Slave_Address); //2. IIC_Send Device Address(W); 发送设备地址 0x90 bIIC_ReadACK(iicHandle); vIIC_SendByte(iicHandle, 0x01); //发送寄存器地址 0x01
bIIC_ReadACK(iicHandle);
vIIC_SendByte(iicHandle, 0xc0); //具体如何配置看手册
bIIC_ReadACK(iicHandle);
vIIC_SendByte(iicHandle, 0x83);
bIIC_ReadACK(iicHandle);
vIIC_Stop_Signal(iicHandle); }

2. 写入指针寄存器0x00,准备读取电压

void uSen_ADS1115_PointRegister(IIC_HandleTypedef * iicHandle, uint8_t Register_Address)
{
vIIC_Start_Signal(iicHandle); //1. IIC_Start ; 起始信号
vIIC_SendByte(iicHandle, Slave_Address); //2. IIC_Send Device Address(W); 发送设备地址 0x90 vIIC_Ack(iicHandle); vIIC_SendByte(iicHandle, 0x00); //4. IIC_Send Register Address ; 发送要操作的寄存器地址
vIIC_NAck(iicHandle); vIIC_Stop_Signal(iicHandle); //9. IIC_Stop ; 结束信号
}

3.读取电压数据

float uSen_ADS1115_Read_Date(IIC_HandleTypedef * iicHandle)
{
uint8_t uRev_Register_Data_H = 0x00,uRev_Register_Data_L = 0x00;
float uRev_Register_Data = 0x00; vIIC_Start_Signal(iicHandle); //1. IIC_Start ; 起始信号
vIIC_SendByte(iicHandle,0x91); //7. I2C_Send Device Address(R); 发送设备地址+1 准备读取
vIIC_Ack(iicHandle); //8. I2C_Ack ; 等待应答
uRev_Register_Data_H = uIIC_RecvByte(iicHandle); //9. I2C_ReadByte ; 读取高位数据
vIIC_Ack(iicHandle);
uRev_Register_Data_L = uIIC_RecvByte(iicHandle); //9. I2C_ReadByte ; 读取低位数据
vIIC_NAck(iicHandle); //数据处理
vIIC_Stop_Signal(iicHandle);
uRev_Register_Data=uRev_Register_Data_H*+uRev_Register_Data_L; //合取为16位数据 if(uRev_Register_Data>=0x8000)
uRev_Register_Data=((float)(0xffff-uRev_Register_Data)/32767.0)*4.096;
else
uRev_Register_Data=((float)uRev_Register_Data/32768.0)*4.096;
; return uRev_Register_Data; }

4. 数据处理

(16位数据/2的15次方)*量程

即(uRev_Register_Data/32768)*4.096

注意有电压有正负

5.量程范围

VCC+/-量程

比如 0v+/-4.096

基于STM32F429的ADS1115驱动程序的更多相关文章

  1. 基于STM32F429和Cube的主从定时器多通道输出固定个数的PWM波形

    主从定时器的原理已在上篇博文: 基于STM32F429+HAL库编写的定时器主从门控模式级联输出固定个数PWM脉冲的程序 讲解了,这篇重点就讲如何实现多通道的PWM级联输出. 1.软件环境 Keil5 ...

  2. 基于STM32F429和Cube的ov2640程序

    1.ov2640和DCMI介绍 OV2640 是 OV(OmniVision)公司生产的一颗 1/4 寸的 CMOS UXGA(1632*1232)图 像传感器.该传感器体积小.工作电压低,提供单片 ...

  3. 基于STM32F429的TFT0.96屏幕驱动

    1.介绍TFT 2.Cube配置  该屏幕是用SPI通信的,但没有MISO引脚,意思是说该屏幕只能接收数据,但无法读取里面的数据,理论上说四线就能启动,但我弄不出,只能用六线. 在Cube上只要开启六 ...

  4. 基于STM32F429的内存管理

    1.内存管理介绍 内存管理,是指软件运行时对计算机内存资源的分配和使用的技术.其最主要的目的是如何高效,快速的分配,并且在适当的时候释放和回收内存资源. 内存管理的实现方法有很多种,他们其实最终都是要 ...

  5. 基于STM32F429+HAL库编写的定时器主从门控模式级联输出固定个数PWM脉冲的程序

    硬件设备   42步进电机,步进电机驱动器,正点原子F429开发板 开发软件    keil5,Cube 综述   一般要精准的控制电机,就要控制单片机的引脚输出指定个数的PWM波,有多种可实现的方法 ...

  6. 基于STM32F429和HAL库的CAN收发例程

    1.CAN协议介绍 CAN 是 Controller Area Network 的缩写(以下称为 CAN),是 ISO 国际标准化的串行通信协议.在当前的汽车产业中,出于对安全性.舒适性.方便性.低公 ...

  7. 基于STM32F429,Cubemx的SAI音频播放实验

    书接上文:https://www.cnblogs.com/feiniaoliangtiangao/p/11060674.html 和 https://www.cnblogs.com/feiniaoli ...

  8. 基于STM32F429,Cubemx的SDHC卡的基本Fatfs文件移植

    本博文要求各位初步了解Fatfs文件系统 友情提示Fatfs官网:http://elm-chan.org/fsw/ff/00index_e.html 1.开发软件 keil5,Cube5.21 2.实 ...

  9. 基于WDF的PCI/PCIe接口卡Windows驱动程序(3)- 驱动程序代码(头文件)

    原文出处:http://www.cnblogs.com/jacklu/p/4679304.html 在WDF的PCIe驱动程序中,共有四个.h文件(Public.h  Driver.h  Device ...

随机推荐

  1. 两个div,都设置未inline-block,可是在IE出现错位问题

    [实现要求] 红色的和黄色的内容撑开,蓝色包住红黄,不定框居中显示 [遇到问题] chrome显示正常,但是在IE上红黄框会出现错位的问题 [如何解决]  给红色框添加一个overflow:hidde ...

  2. 【Java必修课】好用的Arrays.asList也有这三个坑

    好用的asList 在开发或写测试用例的过程中,经常会用到Arrays.asList()这个方法,可以快速方便地将数组转化成一个List.例如: List<String> list = A ...

  3. cuckoo沙箱技术分析全景图

    从事信息安全技术行业的小伙伴们都知道沙箱技术(有些也称沙盒),用来判断一个程序或者文件是否是恶意的病毒.木马.漏洞攻击exp或其他恶意软件.其原理简单来说就是提供了一个虚拟的环境,把分析目标放到这个虚 ...

  4. Spire.Cloud 在线编辑

    简介 Spire.Cloud在线编辑器是一款基于网页的 Office 文件编辑工具,支持在网页中打开.编辑.打印 Word.Excel.PPT 文件,支持将文档保存到私有云盘.支持 IE.Chrome ...

  5. C#线程学习笔记三:线程池中的I/O线程

    本笔记摘抄自:https://www.cnblogs.com/zhili/archive/2012/07/20/MultiThreads.html,记录一下学习过程以备后续查用.     一.I/O线 ...

  6. 通过ADB获取Android手机信息

    原文:https://blog.csdn.net/fasfaf454/article/details/51438743 1.获取手机系统信息( CPU,厂商名称等)adb shell "ca ...

  7. Java面试题_第二阶段(Servlet、HTTP、Session、JSP、 Ajax、Filter、JDBC、Mysql、Spring)

    1.1. 描述Servlet调用过程? 答案: (1)在浏览器输入地址,浏览器先去查找hosts文件,将主机名翻译为ip地址,如果找不到就再去查询dns服务器将主机名翻译成ip地址. (2)浏览器根据 ...

  8. 看懂 游戏《Minecraft》的崩溃报告 服务端/客户端

    如何看懂Minecraft报错的关键信息. 让你如何看懂Minecraft报错 前言 一些俏皮话 寻找崩溃日志 打开崩溃日志 重要的事说三遍 下载文本编辑器 开始分析 深度分析 得出结论 修复报错 解 ...

  9. Flutter - flutter desktop embedding / flutter 桌面支持

    2019年5月9日,随着谷歌在IO19宣布Flutter支持Web平台,就标志着Flutter已经全面支持所有平台(移动.网页.桌面.嵌入式). 现编一个跨平台小段子: 微软Xarmarin:喵喵喵? ...

  10. javascript中的slice()方法

    JavaScript中的Array对象提供了一个slice()方法,用于从已有的数组中返回选定的元素. arrayObject.slice(start, end) 参数说明 start 必需(否则没有 ...