K_A37_002 基于STC89C52RC驱动PCF8591模块 串口与OLED0.96双显示

请添加图片描述

所有资源导航

其他资料目录 直戳跳转

一、资源说明

单片机型号测试条件模块名称代码功能
STC89C52RC晶振11.0592MPCF8591模块STC89C52RC驱动PCF8591模块 串口与OLED0.96双显示

二、基本参数

参数

PCF8591 的操作电压范围 2.5V-6V
通过 I2C 总线串行输入/输出
PCF8591 通过 3 个硬件地址引脚寻址
PCF8591 的采样率由 I2C 总线速率决定
4 个模拟输入可编程为单端型或差分输入
自动增量频道选择
PCF8591 的模拟电压范围从 VSS 到 VDD
PCF8591 内置跟踪保持电路
8-bit 逐次逼近 A/D 转换器
通过 1 路模拟输出实现 DAC 增益

引脚说明

PCF8591模块引脚说明
VCC(+)正极 5V供电
GND(-)负极 接GND
SCLIIC 时钟接口
SDAIIC 数字接口

三、驱动说明

STC89C52RC无ADC所以需要借助外部ADC模块 此处用PCF8591模块进行采集

IIC地址/采集通道选择/时序

请添加图片描述
请添加图片描述
请添加图片描述

对应程序:

以51为例

/*******************************************************************
                     起动总线函数               
函数原型: void  Start_I2c();  
功能:     启动I2C总线,即发送I2C起始条件.  
********************************************************************/
void Start_I2c()
{
  PCF8591_SDA=1;         /*发送起始条件的数据信号*/
  PCF8591_SCL=1;
  IIC_Delay();
  PCF8591_SDA=0;         /*发送起始信号*/
  IIC_Delay();      
  PCF8591_SCL=0;       /*钳住I2C总线,准备发送或接收数据 */
  IIC_Delay();
}

/*******************************************************************
                      结束总线函数               
函数原型: void  Stop_I2c();  
功能:     结束I2C总线,即发送I2C结束条件.  
********************************************************************/
void Stop_I2c()
{
  PCF8591_SDA=0;      /*发送结束条件的数据信号*/
  PCF8591_SCL=1;      /*结束条件建立时间大于4μs*/
  IIC_Delay();
  PCF8591_SDA=1;      /*发送I2C总线结束信号*/
  IIC_Delay();
}

/*******************************************************************
                 字节数据发送函数               
函数原型: void  SendByte(UCHAR c);
功能:     将数据c发送出去,可以是地址,也可以是数据,发完后等待应答,并对
          此状态位进行操作.(不应答或非应答都使ack=0)     
           发送数据正常,ack=1; ack=0表示被控器无应答或损坏。
********************************************************************/
void SendByte(uint8_t  c)
{
 uint8_t  BitCnt;
 
 for(BitCnt=0;BitCnt<8;BitCnt++)  /*要传送的数据长度为8位*/
    {
	     if((c<<BitCnt)&0x80)PCF8591_SDA=1;   /*判断发送位*/
	     else  PCF8591_SDA=0;                
	
	     PCF8591_SCL=1;               /*置时钟线为高,通知被控器开始接收数据位*/
		 IIC_Delay();       
	     PCF8591_SCL=0; 
    }
    
    IIC_Delay();
    PCF8591_SDA=1;                /*8位发送完后释放数据线,准备接收应答位*/
    IIC_Delay();  
    PCF8591_SCL=1;
    IIC_Delay();
    if(PCF8591_SDA==1)ack=0;     
       else ack=1;        /*判断是否接收到应答信号*/
    PCF8591_SCL=0;
  IIC_Delay();
}

/*******************************************************************
                 字节数据接收函数               
函数原型: UCHAR  RcvByte();
功能:        用来接收从器件传来的数据,并判断总线错误(不发应答信号),
          发完后请用应答函数应答从机。  
********************************************************************/    
uint8_t RcvByte()
{
  uint8_t  retc;
  uint8_t  BitCnt;
  
  retc=0; 
  PCF8591_SDA=1;                     /*置数据线为输入方式*/
  for(BitCnt=0;BitCnt<8;BitCnt++)
  {
      
      PCF8591_SCL=0;                  /*置时钟线为低,准备接收数据位*/
	  IIC_Delay();
      PCF8591_SCL=1;                  /*置时钟线为高使数据线上数据有效*/
	  IIC_Delay();
      retc=retc<<1;
      if(PCF8591_SDA==1)retc=retc+1;  /*读数据位,接收的数据位放入retc中 */
		IIC_Delay();
    }
  		PCF8591_SCL=0;    
  		IIC_Delay();
  		return(retc);
}

/********************************************************************
                     应答子函数
函数原型:  void Ack_I2c(bit a);
功能:      主控器进行应答信号(可以是应答或非应答信号,由位参数a决定)
********************************************************************/
void Ack_I2c(uint8_t a)
{
  
  if(a==0)PCF8591_SDA=0;              /*在此发出应答或非应答信号 */
  else PCF8591_SDA=1;
  IIC_Delay();    
  PCF8591_SCL=1;
  IIC_Delay();
  PCF8591_SCL=0;                     /*清时钟线,钳住I2C总线以便继续接收*/
  IIC_Delay();  
}

采集通道选择:
ISendByte(PCF8591,0x42);

地址:
#define  PCF8591 0x90    //PCF8591 地址

四、部分代码说明

1、接线引脚定义

需要自定义引脚可在此处更改,STM32要自定义引脚的话也要注意引脚时钟使能的更改

1.1、STC89C52RC+PCF8591模块

sbit  PCF8591_SCL=P1^0;       //I2C  时钟 
sbit  PCF8591_SDA=P1^1;       //I2C  数据 
//OLED0.96模块引脚定义
sbit SCL=P1^2; //串行时钟
sbit SDA=P1^3; //串行数据

五、基础知识学习与相关资料下载

1、STC89C52RC程序下载 直戳跳转

2、STM32F103C8T6程序下载
(1)串口下载 直戳跳转
(2)ST-LINK下载 直戳跳转
(3)J-LINK下载 直戳跳转
(4)DAP-LINK下载 直戳跳转

3、OLED0.96程序说明 直戳跳转

4、串口助手下载与使用
(1)安信可调试助手使用 直戳跳转
(2) sscom33串口调试助手使用 直戳跳转
(3)STC-ISP串口调试助手使用 直戳跳转

六、视频效果展示与程序资料获取

视频连接 直戳跳转
资料获取 ( 滑到最后添加个人号)

七、注意事项

1、VCC GND请勿接反,接反易烧
2、OLED显示异常时,排除接线接触不良

八、接线说明

STC89C52RC

/************************************************************************************
//  功能描述   : PCF8591模块测试程序
//  测试条件   : STC89C52RC   晶振11.0592
接线

PCF8591--------------------------------STC89C52RC
VCC-- ---------------------------------5V
GND- ----------------------------------GND
SCL- ----------------------------------P1.0 //SCL
SDA- ----------------------------------P1.1 //SDA

OLED0.96(IIC) -------------------------STC89C52RC
VCC------------------------------------3.3V
GND------------------------------------GND
SCL------------------------------------P1^2
SDA------------------------------------P1^3
*************************************************************************************/
  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
在 STM32 上实现 GATT 协议,可以使用蓝牙模块和相关的库。下面是一个简单的步骤: 1. 确定使用的蓝牙模块,并选择适合该模块的库进行开发。 2. 初始化蓝牙模块,并设置广播数据和服务信息。 3. 创建 GATT 服务和特征,定义特征的 UUID 和属性。 4. 实现 GATT 的回调函数,在收到数据时进行处理,并发送响应。 下面是一个示例代码,演示了如何发送数字信号 raw_data: ```c #include "stm32f1xx_hal.h" #include "bluetooth.h" #include "gatt_server.h" #define RAW_DATA_CHAR_UUID "00002A37-0000-1000-8000-00805F9B34FB" uint8_t raw_data_value[4] = {0, 0, 0, 0}; static void raw_data_write_callback(uint16_t conn_handle, uint16_t attr_handle, const uint8_t *data, uint16_t len) { if (len != sizeof(raw_data_value)) { return; } // 处理接收到的 raw_data 数据 memcpy(raw_data_value, data, sizeof(raw_data_value)); } void gatt_server_init(void) { // 创建 GATT 服务 gatt_service_t *raw_data_service = gatt_service_create("Raw Data"); // 创建 GATT 特征 gatt_char_props_t raw_data_char_props = GATT_CHAR_PROP_WRITE; gatt_char_t *raw_data_char = gatt_char_create(raw_data_service, RAW_DATA_CHAR_UUID, &raw_data_char_props, raw_data_value, sizeof(raw_data_value)); // 设置 GATT 特征的回调函数 gatt_char_set_write_cb(raw_data_char, raw_data_write_callback); } void bluetooth_init(void) { // 初始化蓝牙模块 ble_driver_init(); // 设置广播信息和服务信息 ble_set_device_name("My Device"); ble_set_adv_data("Raw Data"); // 初始化 GATT 服务 gatt_server_init(); // 启动蓝牙广播 ble_adv_start(); } ``` 在这个示例代码中,我们创建了一个名为 "Raw Data" 的 GATT 服务,并在其中创建了一个 UUID 为 "00002A37-0000-1000-8000-00805F9B34FB" 的特征,该特征是可写的。当收到写入请求时,我们将接收到的数据复制到 raw_data_value 数组中。 注意,这只是一个简单的示例代码,实际情况可能更复杂,需要根据具体的需求进行修改和调整。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值