使用stm32并使用hal库编写程序时,怎么是0.96寸的oled屏显示变量,请给出相关函数代码以及实例代码

时间: 2023-05-15 16:06:40 浏览: 191
可以使用HAL库中的SSD1306驱动来控制0.96寸的OLED屏幕显示变量。以下是相关函数代码和实例代码: 函数代码: void OLED_Init(void) { HAL_Delay(100); OLED_Write_Command(0xAE);//--display off OLED_Write_Command(0x00);//---set low column address OLED_Write_Command(0x10);//---set high column address OLED_Write_Command(0x40);//--set start line address Set Mapping RAM Display Start Line (0x00~0x3F) OLED_Write_Command(0x81);//--set contrast control register OLED_Write_Command(0xCF); // Set SEG Output Current Brightness OLED_Write_Command(0xA1);//--Set SEG/Column Mapping 0xa0左右反置 0xa1正常 OLED_Write_Command(0xC8);//Set COM/Row Scan Direction 0xc0上下反置 0xc8正常 OLED_Write_Command(0xA6);//--set normal display OLED_Write_Command(0xA8);//--set multiplex ratio(1 to 64) OLED_Write_Command(0x3f);//--1/64 duty OLED_Write_Command(0xD3);//-set display offset Shift Mapping RAM Counter (0x00~0x3F) OLED_Write_Command(0x00);//-not offset OLED_Write_Command(0xd5);//--set display clock divide ratio/oscillator frequency OLED_Write_Command(0x80);//--set divide ratio, Set Clock as 100 Frames/Sec OLED_Write_Command(0xD9);//--set pre-charge period OLED_Write_Command(0xF1);//Set Pre-Charge as 15 Clocks & Discharge as 1 Clock OLED_Write_Command(0xDA);//--set com pins hardware configuration OLED_Write_Command(0x12); OLED_Write_Command(0xDB);//--set vcomh OLED_Write_Command(0x40);//Set VCOM Deselect Level OLED_Write_Command(0x20);//-Set Page Addressing Mode (0x00/0x01/0x02) OLED_Write_Command(0x02);// OLED_Write_Command(0x8D);//--set Charge Pump enable/disable OLED_Write_Command(0x14);//--set(0x10) disable OLED_Write_Command(0xA4);// Disable Entire Display On (0xa4/0xa5) OLED_Write_Command(0xA6);// Disable Inverse Display On (0xa6/a7) OLED_Write_Command(0xAF);//--turn on oled panel } void OLED_Write_Command(uint8_t cmd) { HAL_I2C_Mem_Write(&hi2c1, OLED_ADDR, 0x00, 1, &cmd, 1, 100); } void OLED_Write_Data(uint8_t data) { HAL_I2C_Mem_Write(&hi2c1, OLED_ADDR, 0x40, 1, &data, 1, 100); } void OLED_Clear_Screen(void) { uint8_t i,j; for(i=0;i<8;i++) { OLED_Write_Command(0xb0+i); OLED_Write_Command(0x00); OLED_Write_Command(0x10); for(j=0;j<128;j++) { OLED_Write_Data(0x00); } } } void OLED_Show_String(uint8_t x,uint8_t y,char *str) { uint8_t i=0,j=0; while(str[i]!='\0') { j=str[i]-32; if(x>120) { x=0;y++; } OLED_Show_Char(x,y,j); x+=6; i++; } } void OLED_Show_Char(uint8_t x,uint8_t y,uint8_t chr) { uint8_t i,j; uint8_t temp; chr=chr-' '; OLED_Write_Command(0xb0+y); OLED_Write_Command(((x&0xf0)>>4)|0x10); OLED_Write_Command(x&0x0f); for(i=0;i<6;i++) { temp=asc2_1206[chr][i]; for(j=0;j<8;j++) { if(temp&0x01) { OLED_Write_Data(0xff); } else { OLED_Write_Data(0x00); } temp>>=1; } } } 实例代码: #include "stm32f1xx_hal.h" #include "oled.h" I2C_HandleTypeDef hi2c1; int main(void) { HAL_Init(); SystemClock_Config(); MX_GPIO_Init(); MX_I2C1_Init(); OLED_Init(); OLED_Clear_Screen(); OLED_Show_String(0,0,"Hello World!"); while (1) { } } 注意:以上代码仅供参考,具体实现需要根据具体的硬件和软件环境进行调整。

相关推荐

最新推荐

recommend-type

使用HAL新库编写简单stm32程序总结

使用hal库进行简单的stm32程序编写,以及对各种实现方法的总结,包含点亮led灯、外部中断、定时器、DMA串口通讯等简单功能的实现。
recommend-type

STM32的使用之SPI通信DMA模式

MCU:STM32F303VC,在SPI通信中,可以同时开启发送和接收DMA请求,自动数据的发送和接收,完成数据的交换。
recommend-type

STM32不完全手册_HAL库版本_V1.0.pdf

2,软件篇,主要介绍 STM32 开发软件的使用以及一些下载调试的技巧,并详细介绍了几个常用的系统文件(程序);3,实战篇,主要通过 38 个实例(绝大部分是直接操作 HAL 库完成的)带领大家一步步深入 STM32 的学习...
recommend-type

STM32 SPI DMA 的使用

一是想总结一下SPI总线的特点与注意点,二是总结一下SPI DMA的使用。
recommend-type

基于SpringBoot框架的中小企业完全开源的ERP.zip

基于springboot的java毕业&课程设计
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

SQL怎么实现 数据透视表

SQL可以通过使用聚合函数和GROUP BY子句来实现数据透视表。 例如,假设有一个销售记录表,其中包含产品名称、销售日期、销售数量和销售额等信息。要创建一个按照产品名称、销售日期和销售额进行汇总的数据透视表,可以使用以下SQL语句: ``` SELECT ProductName, SaleDate, SUM(SaleQuantity) AS TotalQuantity, SUM(SaleAmount) AS TotalAmount FROM Sales GROUP BY ProductName, SaleDate; ``` 该语句将Sales表按照ProductName和SaleDat
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。