当前位置: 首页 > news >正文

BU9792驱动段式LCD

1、C文件,需要自己添加软件iic或硬件iic驱动,该驱动在我的别的文章内有。亲测bu9792是正常驱动的(只用到了前14个SEG),说实话有点懵了。后面的ICSET有个P2根据不同的SEG地址要置1或0,读的时候最高位也是0?读命令寄存器的时候是1。手册里读都是1啊

 至于为什么地址乘2,因为我有数码管,需要把两个SEG组成一个,一对对操作。

#include "bu9792.h"
#include "drv_soft_i2c.h"
#include "stdbool.h"uint8_t bu9792_init(void)// 
{uint8_t buf[7] = {0};I2C_INIT();// 初始化iic总线// 上电 DelayMs(100); // 上电延时100msI2C_STOP();I2C_START();// 初始化芯片配置I2C_WRITE(BU9792_W_ADD);if(I2C_WAIT_ACK() != 0){PRINT("IIC ERROR\r\n"); // iic初始化成功I2C_STOP();return 1;}I2C_WRITE(0xEA); // 软复位I2C_WAIT_ACK();I2C_WRITE(0xA2);I2C_WAIT_ACK();I2C_WRITE(0xB6);// 设置功耗模式I2C_WAIT_ACK();I2C_WRITE(0xF0); // 设置不闪烁I2C_WAIT_ACK();I2C_WRITE(0xFC); // RAM控制显示I2C_WAIT_ACK();I2C_WRITE(0xC8); // 1/3bias 开启显示I2C_WAIT_ACK();I2C_STOP(); // 停止信号bu9792_write_display_data(0, buf, 7); //清空显示return 0;
}uint8_t bu9792_write_display_data(uint8_t reg_addr, uint8_t* databuf, uint8_t len) {if (reg_addr > 0x23 || len == 0) return 1; // 地址范围校验(0~35)reg_addr *= 2;I2C_START();I2C_WRITE(BU9792_W_ADD); // 写模式地址if (I2C_WAIT_ACK()) return 1;// 发送ADSET命令设置地址(无需0xE8/0xEC切换)I2C_WRITE(0x00 | reg_addr); // 地址低5位(0x00~0x23)if (I2C_WAIT_ACK()) return 1;// 写入数据for (; len > 0; len--, databuf++) {I2C_WRITE(*databuf);if (I2C_WAIT_ACK()) return 1;}I2C_STOP();return 0;
}// 从指定DDRAM地址读取长度为len的显示数据(每个地址对应4个SEG)
// 参数:reg_addr: DDRAM起始地址(0x00~0x23),databuf: 读取数据缓冲区,len: 读取地址数量
// 返回:0-成功,1-失败
uint8_t bu9792_read_display_data(uint8_t reg_addr, uint8_t* databuf, uint8_t len) {// 地址范围校验:0x00~0x23(36个地址)if (reg_addr > 0x23 || len == 0) {return 1;}reg_addr *= 2;// 步骤1:写模式设置DDRAM地址(ADSET命令)I2C_START();I2C_WRITE(BU9792_W_ADD); // 写模式从机地址(如0x7C)if (I2C_WAIT_ACK() != 0) {I2C_STOP();return 1;}// 发送ADSET命令:直接设置地址低5位(无需0xE8/0xEC切换)I2C_WRITE(0x00 | reg_addr); // 地址低5位(0x00~0x23)if (I2C_WAIT_ACK() != 0) {I2C_STOP();return 1;}// 步骤2:发送重复起始条件(Re-START)切换读模式I2C_START();I2C_WRITE(BU9792_R_ADD); // 读模式从机地址(如0x7D,最高位为1)if (I2C_WAIT_ACK() != 0) {I2C_STOP();return 1;}// 步骤3:读取数据(连续读取len个字节)for (uint8_t i = 0; i < len; i++) {databuf[i] = I2C_READ(i == (len - 1)); // 最后一个字节发送NACK,其余发送ACK}// 步骤4:发送STOP条件结束通信I2C_STOP();return 0;
}uint8_t bu9792_read_cmd_reg(uint8_t* reg_value) {// 步骤1:发送起始条件 + 写模式从机地址I2C_START();I2C_WRITE(BU9792_W_ADD); // 写模式从机地址(如0x7C)if (I2C_WAIT_ACK() != 0) {I2C_STOP();return 1;}// 步骤2:设置要读取的寄存器地址(ADSET命令)// REG1_ADDR 的高3位为100(文档第10页地址映射)I2C_WRITE(0x10 | ((REG1_ADDR >> 4) & 0x0F)); // ADSET命令高3位为100,低4位为地址高4位(0x24 → 0010 0100 → 高4位0010 → 0x02)if (I2C_WAIT_ACK() != 0) {I2C_STOP();return 1;}I2C_WRITE(REG1_ADDR & 0x0F); // 地址低4位(0x24 → 0100)if (I2C_WAIT_ACK() != 0) {I2C_STOP();return 1;}// 步骤3:发送重复起始条件(Re-START)切换读模式I2C_START();I2C_WRITE(BU9792_R_ADD); // 读模式从机地址(如0x7D)if (I2C_WAIT_ACK() != 0) {I2C_STOP();return 1;}// 步骤4:读取寄存器数据(先REG1,后REG2)*reg_value = I2C_READ(0); // 读取REG1,发送ACK(继续读取下一个寄存器)reg_value++;*reg_value = I2C_READ(1); // 读取REG2,发送NACK(停止读取)// 步骤5:发送停止条件I2C_STOP();return 0;
}static uint8_t bu9792_apctl_on(uint8_t mode)// 0关闭 1开启
{I2C_START();// 初始化芯片配置I2C_WRITE(BU9792_W_ADD);if(I2C_WAIT_ACK() != 0){PRINT("IIC ERROR\r\n");I2C_STOP();return 1;}mode > 0 ? I2C_WRITE(0xFE) : I2C_WRITE(0xFD);I2C_STOP();return 0;
}#ifdef DEBUG_BU9792
void bu9792_test(void)
{uint8_t cmd[2] = {0, 0};static uint8_t buf[] = {0xf5, 0x05, 0xd3, 0x97, 0, 0, 0};uint8_t buf1 = 0x97;uint8_t buf2[8] = {0};bu9792_read_cmd_reg(cmd);PRINT("%d %d\r\n", cmd[0], cmd[1]);PRINT("IIC TEST\r\n");bu9792_write_display_data(0, &buf[0], 1);bu9792_write_display_data(1, &buf[1], 1);bu9792_write_display_data(2, &buf[2], 1);bu9792_write_display_data(3, &buf[3], 1);DelayMs(1000);bu9792_read_display_data(0, buf2, 7);PRINT("read buf2 is %x  %x %x %x %x %x %x \r\n", buf2[0], buf2[1], buf2[2], buf2[3], buf2[4], buf2[5], buf2[6]);bu9792_apctl_on(1);DelayMs(10000);
}
#endif

2、头文件

#ifndef __BU9792_H
#define __BU9792_H
#include "CH58x_common.h"
#define BU9792_W_ADD 0x7C
#define BU9792_R_ADD  0x7D
// 寄存器地址定义(文档第10页)
#define REG1_ADDR 0x24  // 偏压设置、时钟模式等
#define REG2_ADDR 0x25  // 帧频、功耗模式等
#define DEBUG_BU9792extern void bu9792_open_power(void);
extern void bu9792_close_power(void);
extern uint8_t bu9792_init(void);// 
extern uint8_t bu9792_write_display_data(uint8_t reg_addr, uint8_t* databuf, uint8_t len) ;
extern uint8_t bu9792_read_display_data(uint8_t reg_addr, uint8_t* databuf, uint8_t len);
extern uint8_t bu9792_read_cmd_reg(uint8_t* reg_value);
#ifdef DEBUG_BU9792
extern void bu9792_test(void);
#endif#endif

http://www.xdnf.cn/news/616285.html

相关文章:

  • C++:无序容器
  • 第十四届蓝桥杯国赛PythonA题解
  • Ubuntu系统下,使用system函数运行终端指令,如何避免输入密码的方法
  • 大数据任务调度实战:DolphinScheduler 与 Airflow 深度解析与最佳实践
  • DAX权威指南4:时间智能计算
  • C++ 结构体封装模式与 Promise 链式调用:设计思想的异曲同工
  • 广东省省考备考(第十八天5.23)—言语:语句填空题(听课后强化训练)
  • Calculix,基于有限元法 (fem) 的免费工具
  • AdGuard解锁高级版(Nightly)_v4.10.36 安卓去除手机APP广告
  • 双均线量化交易策略指南
  • Redis-基础-总结
  • day27- 系统编程之 进程
  • springboot配置redis lettuce连接池,以及连接池参数解释
  • 多语种多场景的的分页详解
  • 哪家的电能质量分析仪最好?
  • 解锁C++递归算法:从原理到实战
  • RAG 和 Fine-Tuning
  • 保持元素的宽高比
  • 【复杂网络分析】社区发现(Community Detection)算法简介
  • Spring Bean的作用域
  • SpringBoot3引入knife4j和knife4j文档请求异常
  • 生产者和消费者问题
  • C++可变参数宏定义语法笔记
  • 【数据架构01】数据技术架构篇
  • Dify聊天系统SSE响应和聊天树数据结构图解
  • Spring的组成部分
  • Linux 的OTA升级学习1:Linux OTA升级方案_SWupdate
  • 聚焦 Microsoft Fabric,释放数据潜力
  • 篇一:重新学习的碎碎记
  • 【Web前端】JavaScript入门与基础(二)