TI电赛开发板驱动0.91寸OLED屏(SSD1306)移植实战:从引脚配置到显示验证
TI电赛开发板驱动0.91寸OLED屏SSD1306移植实战从引脚配置到显示验证最近在准备电赛项目需要给TI的开发板比如TMS320F28P550加个小屏幕显示数据0.91寸的OLED屏是个不错的选择体积小、功耗低、显示清晰。但网上的例程大多是针对STM32的直接搬到TI的C2000平台上总会出现各种问题。今天我就把整个移植过程从硬件连接到代码修改再到最终显示验证一步步拆开讲清楚保证你跟着做就能点亮屏幕。这块屏用的是SSD1306驱动芯片通过IIC接口通信分辨率是128x32像素。移植的核心工作就是把别人写好的、可能基于其他芯片的驱动代码适配到咱们的TI开发板上主要就是改引脚配置和调整一下时序。1. 准备工作认识你的屏幕和获取资料在动手写代码之前咱们得先把硬件和资料准备好。1.1 屏幕规格与硬件连接我用的这块0.91寸OLED屏关键参数如下参数规格工作电压3.3V - 5V通信接口IIC (I2C)驱动芯片SSD1306分辨率128 (水平) x 32 (垂直) 像素屏幕尺寸12mm x 38mm注意一定要确认你手里的屏幕是IIC接口的还有一种是SPI接口接线和驱动方式完全不同。屏幕通常有4个引脚我们需要将其连接到开发板屏幕引脚功能连接至开发板GND电源地任意GND引脚VCC电源正 (3.3V)3.3V电源引脚SCLIIC时钟线GPIO51 (可配置为其他GPIO)SDAIIC数据线GPIO50 (可配置为其他GPIO)这里我选择了GPIO51和GPIO50你可以根据自己板子的空闲情况选择任意两个GPIO因为我们将使用“软件模拟IIC”的方式不依赖芯片特定的硬件IIC外设这样更灵活。1.2 获取驱动源码移植离不开原始驱动代码。你可以通过提供的链接下载厂家资料包提取码1111。资料包里通常会有针对其他平台如STM32的示例工程。我们需要的就是其中的OLED文件夹里面包含了oled.c和oled.h这两个核心文件以及字库文件oledfont.h。把整个OLED文件夹复制到你自己的CCS工程目录下。接下来咱们就在这个基础上进行修改。2. 工程配置与文件导入首先在CCS中打开你的工程。将刚才复制的OLED文件夹中的.c和.h文件添加到工程里。具体操作是在项目浏览器中右键点击工程名选择“Add Files...”然后定位到OLED文件夹添加oled.c。头文件路径也需要添加确保编译器能找到它们。添加完后先编译一下很可能会报错。别慌这是正常现象因为原来的代码是为别的芯片写的。我们主要需要修改两个地方修改头文件引用打开oled.h文件你会发现它可能包含了#include sys.h这样的语句。这个sys.h是原平台的定义文件。在我们的TI开发板工程中通常有一个集中管理引脚和初始化的头文件比如tjx_init.h根据你的工程实际情况也可能是board.h或device.h。我们需要把sys.h替换成我们这个工程对应的主头文件。// 在 oled.h 中将原来的 // #include sys.h // 修改为 #include tjx_init.h // 或者你的工程主头文件处理延时函数原来的oled.c里可能包含了#include delay.h并使用了里面的毫秒/微秒延时函数。如果我们的工程里没有完全相同的延时函数一个简单的办法是先注释掉这行我们稍后会处理延时问题。// 在 oled.c 顶部可以暂时注释掉 // #include delay.h3. 核心移植引脚与时序配置这是移植最关键的一步决定了屏幕能不能“听”到开发板发出的指令。3.1 配置GPIO引脚使用SysConfig图形化工具TI的C2000系列现在推荐使用SysConfig图形化工具来配置引脚非常方便。在你的CCS工程中找到c2000.syscfg文件并双击打开。在打开的界面中找到添加GPIO配置的地方点击ADD。我们需要添加两个GPIO配置分别对应SCL时钟和SDA数据。根据之前的规划我们使用GPIO50和GPIO51。将这两个GPIO配置为输出模式。因为软件模拟IIC需要我们手动控制引脚的高低电平来模拟时钟和数据信号。配置完成后记得按Ctrl S保存。然后按Ctrl B编译一次。这个编译过程会生成或更新board.h等文件里面就包含了类似SCREEN_SDA和SCREEN_SCL这样的宏定义它们对应着我们刚刚配置的GPIO50和GPIO51。提示编译时可能会有些警告只要不是错误可以先忽略。关键是确保board.h中正确生成了我们需要的引脚定义。3.2 修改驱动代码中的引脚控制宏现在我们需要告诉OLED驱动代码具体操作哪个物理引脚。打开oled.h文件找到引脚定义的部分。原来的代码可能是针对STM32的GPIO_SetBits这类函数。我们需要将其修改为TI开发板对应的GPIO控制函数。根据提供的原始代码修改如下//-----------------OLED端口定义---------------- // 假设 board.h 中已定义 SCREEN_SCL 为 GPIO51SCREEN_SDA 为 GPIO50 #define OLED_SCL_Clr() GPIO_writePin(SCREEN_SCL, 0) // SCL线拉低 #define OLED_SCL_Set() GPIO_writePin(SCREEN_SCL, 1) // SCL线拉高 #define OLED_SDA_Clr() GPIO_writePin(SCREEN_SDA, 0) // SDA线拉低 #define OLED_SDA_Set() GPIO_writePin(SCREEN_SDA, 1) // SDA线拉高GPIO_writePin(pin, value)是TI DriverLib库中用于设置GPIO输出电平的函数value为0输出低电平为1输出高电平。3.3 调整IIC通信延时IIC通信对时序有要求SCL时钟的高低电平需要保持一定时间。原来的oled.c文件中有一个IIC_delay()函数它内部可能调用了一个delay_us(2)来产生2微秒的延时。void IIC_delay(void) { delay_us(2); // 确保你的工程中有 delay_us 这个函数 }这里有个坑要注意你必须确认你的工程里有一个可用的微秒级延时函数delay_us()。如果没有你需要自己实现一个或者使用TI库中的DEVICE_DELAY_US()函数具体函数名请查看你的工程或C2000Ware库。延时时间可以根据实际情况微调2-5微秒通常都可以。4. 编写测试程序点亮屏幕移植完成后就该写个主程序来测试了。在你的主文件例如main.c中需要包含必要的头文件并调用初始化与显示函数。下面是一个完整的测试例程它会循环显示图片、汉字、英文、数字和滚动效果非常适合验证所有基础功能是否正常。#include driverlib.h #include device.h #include board.h // 确保包含了board.h它定义了SCREEN_SCL等 #include oled.h // OLED驱动头文件 #include bmp.h // 假设你有存放图片数组的头文件 void main(void) { // 1. 芯片基础初始化通常由CCS自动生成 Device_init(); Device_initGPIO(); Interrupt_initModule(); Interrupt_initVectorTable(); Board_init(); // 初始化板级外设包括我们配置的GPIO EINT; // 开启全局中断 ERTM; // 2. 初始化OLED屏幕 OLED_Init(); // 3. 设置显示模式正常显示不旋转 OLED_ColorTurn(0); // 0:正常颜色1:反色 OLED_DisplayTurn(0); // 0:正常方向1:旋转180度 u8 ascii_char ; // 用于显示变化的ASCII字符 while(1) { // 场景1显示一张图片128x32 OLED_ShowPicture(0, 0, 128, 32, BMP1, 1); OLED_Refresh(); // 将显存数据发送到屏幕 delay_ms(1000); // 延时1秒 OLED_Clear(); // 清屏 // 场景2显示汉字和英文字符串 OLED_ShowChinese(0, 0, 0, 16, 1); // 在(0,0)显示字库中第0个汉字16x16大小正常模式 OLED_ShowChinese(18, 0, 1, 16, 1); // 显示下一个汉字 // ... 可以继续显示更多汉字 OLED_ShowString(8, 16, Hello, OLED!, 16, 1); // 在(8,16)显示英文字符串 OLED_Refresh(); delay_ms(1000); OLED_Clear(); // 场景3显示格式化的数字和变化的ASCII码 OLED_ShowString(20, 0, Voltage:, 16, 1); OLED_ShowNum(80, 0, 330, 3, 16, 1); // 显示数字330长度为3位 OLED_ShowString(0, 16, ASCII:, 16, 1); OLED_ShowChar(48, 16, ascii_char, 16, 1); // 显示一个ASCII字符 ascii_char; if(ascii_char ~) ascii_char ; // 循环显示可打印字符 OLED_ShowString(63, 16, CODE:, 16, 1); OLED_ShowNum(103, 16, ascii_char, 3, 16, 1); // 显示该字符的ASCII码值 OLED_Refresh(); delay_ms(500); OLED_Clear(); // 场景4显示不同大小的字体 OLED_ShowString(0, 0, Small:8, 8, 1); OLED_ShowString(0, 10, Mid:16, 16, 1); OLED_ShowString(0, 30, Large:24, 24, 1); OLED_Refresh(); delay_ms(1000); OLED_Clear(); // 场景5测试滚动显示功能如果需要 // OLED_ScrollDisplay(10, 4, 1); // 滚动显示10个汉字间隔4像素 } }将代码编译后下载到开发板如果一切顺利你应该能看到OLED屏幕开始循环显示不同的内容。5. 常见问题与调试心得屏幕不亮全黑或全白检查电源和接线这是最常出问题的地方务必确认VCC接3.3VGND接好SCL和SDA线没有接反或接触不良。检查初始化序列OLED_Init()函数里有一长串SSD1306的初始化命令这些命令是驱动芯片工作所必须的。确保这个函数被正确调用且没有在调用前就被硬件复位等因素打断。显示乱码或错位检查通信时序重点检查IIC_delay()函数。如果延时太短MCU操作太快屏幕可能反应不过来延时太长则会影响刷新率。可以尝试将delay_us(2)调整为delay_us(5)或delay_us(10)试试。确认IIC地址SSD1306的IIC地址通常是0x78写地址或0x7A。在OLED_WR_Byte函数里可以看到Send_Byte(0x78);这一行。如果你的屏幕规格特殊可能需要修改这个地址但大部分0.91寸屏都是0x78。编译报错delay_us未定义你需要在自己的工程中实现一个微秒延时函数。一个简单但不精确的方法是用空循环实现。更推荐使用TI芯片的系统定时器例如利用C2000的CPUdelay函数或配置一个高精度定时器来实现精确延时。显示内容刷新不正常有残影在每次更新显示内容前可以尝试先调用OLED_Clear()清空显存再画新图最后调用OLED_Refresh()。确保OLED_Refresh()函数正确地将整个显存OLED_GRAM的数据发送到了屏幕。移植成功的关键就是耐心和细心对照着引脚和时序一点点调整。一旦第一次成功点亮这块屏幕就能在你的电赛项目里大显身手了用来显示传感器数据、系统状态或者简单的菜单界面都非常方便。
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2419264.html
如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!