stm32f103c8t6控制4针0.96寸oled显示屏

时间: 2023-07-21 08:01:56 浏览: 121
### 回答1: 要控制STM32F103C8T6开发板上的0.96寸OLED显示屏,我们可以按照以下步骤进行: 1. 硬件接线:将OLED显示屏的VCC引脚连接到3.3V电源,将GND引脚连接到GND,将SCL引脚连接到STM32的SCL引脚(GPIOB6),将SDA引脚连接到STM32的SDA引脚(GPIOB7)。 2. 初始化I2C总线:在STM32上初始化I2C总线,设置I2C的时钟速率和其他参数。将SCL和SDA引脚配置为I2C外设模式。 3. 设置OLED显示屏参数:根据OLED显示屏的数据手册,设置OLED的显示模式、显示区域、亮度等参数。写入对应的命令和数据到OLED显示屏上,通过I2C总线发送给OLED。 4. 编写显示函数:编写函数来显示信息在OLED屏幕上。可以使用图形库或者自行编写代码来绘制字符、图形和图像。 5. 主程序:在主程序中调用初始化函数和显示函数。在需要显示的地方调用显示函数,将需要显示的内容传递给显示函数,显示在OLED屏幕上。 需要注意以下几点: - 在编写代码时,根据OLED显示屏的数据手册和STM32的开发板手册,了解并正确设置相关的寄存器和地址。 - 在使用I2C总线时要保证正确的时序和地址,防止通讯出错。 - 在编写显示函数时,要注意字库的使用和显示位置的计算,确保显示的内容能够正确显示在OLED屏幕上。 ### 回答2: 要使用stm32f103c8t6控制4针0.96寸OLED显示屏,可以按照以下步骤进行: 1. 了解OLED显示屏的工作原理和通信接口方式。0.96寸OLED显示屏通常采用四线串行通信方式,需要了解其通信协议和相应的驱动芯片。 2. 在stm32f103c8t6上配置相应的引脚。为了控制OLED显示屏,需要配置几个引脚用于数据和控制信号的传输。根据OLED显示屏的通信协议,选择合适的引脚并进行配置。 3. 编写驱动程序。使用C语言编写驱动程序,通过STM32的GPIO库函数来控制引脚的输出和状态变化。根据OLED显示屏的通信协议,编写相应的数据传输函数,实现与OLED显示屏的通信。 4. 初始化OLED显示屏。在主程序中调用相应的初始化函数,对OLED显示屏进行初始化设置,包括屏幕分辨率、亮度、字体等参数的设置。 5. 编写显示程序。使用驱动程序提供的API函数,编写显示程序来显示需要的图形、文本等内容。通过驱动程序传输相应的数据到OLED显示屏上,实现所需的显示效果。 6. 调试和测试。将程序烧录到stm32f103c8t6上,连接OLED显示屏并调试程序,观察是否能正常显示所需的内容。如果出现问题,可以使用串口调试工具进行调试,查找并解决问题。 综上所述,使用stm32f103c8t6控制4针0.96寸OLED显示屏需要进行引脚配置、驱动程序编写和显示程序编写,通过调试和测试来实现所需的显示效果。 ### 回答3: STM32F103C8T6 是一款基于ARM Cortex-M3内核的微控制器芯片,常用于嵌入式系统开发。它具有丰富的外设接口和强大的计算能力,适合于控制各种外围设备,如显示屏。 针对使用该芯片控制4针0.96寸OLED显示屏的情况,我们可以通过以下步骤进行操作: 1. 引脚连接:首先,要通过跳线将STM32F103C8T6与OLED显示屏连接起来。使用4根导线,分别连接芯片的GPIO引脚(如PA0、PA1、PA2和PA3)与显示屏的控制针(如SCL、SDA、RES和DC)。 2. 驱动程序:我们需要在STM32的开发环境中编写一个驱动程序,用来控制OLED显示屏的初始化和数据传输。可以使用STM32的标准外设库或者其他第三方库来简化开发过程。 3. 初始化:在程序中,我们需要首先对OLED显示屏进行初始化设置。这包括设置通信协议(如I2C或SPI)、屏幕分辨率和亮度等参数。 4. 数据传输:一旦初始化完成,就可以通过发送特定的命令和数据来控制OLED显示屏的内容。例如,可以发送文字、图像、图标等数据到显示屏上。 5. 循环更新:为了实现动态显示,我们需要在主循环中不断更新OLED显示屏的内容。可以通过读取传感器数据、计算结果等方式更新显示内容。 总结起来,通过连接和编程,我们可以使用STM32F103C8T6控制4针0.96寸OLED显示屏。这样我们可以实现各种应用场景下的信息展示,提升系统的用户交互性和可视化效果。

相关推荐

### 回答1: 在使用STM32F103C8T6硬件IIC控制4针0.96寸OLED显示屏时,我们需要了解IIC总线的基本原理和OLED显示屏的接口及控制方式。 IIC总线是一种串行通信协议,它由两根信号线组成,分别是时钟线(SCL)和数据线(SDA)。IIC通信中,数据从一个设备流向另一个设备,通过设备地址进行寻址和选择。而OLED显示屏则是一种可以直接输出图像的静电显示器件,需要通过IIC总线进行控制。 通常,我们会使用STM32F103C8T6的GPIO引脚连接OLED显示屏的时钟线和数据线。在程序中,我们需要设置STM32F103C8T6的GPIO引脚为IIC模式,并且按照IIC协议的流程来进行数据的发送和接收。对于不同的OLED显示屏,其IIC地址可能不一样,我们需要在程序中进行指定。 在显示实际内容时,我们可以通过对OLED显示屏内部的寄存器进行设置来显示所需的图像和文字。需要注意的是,OLED显示屏的控制方式和寄存器的设置可能与其他显示屏不同,我们需要查阅相关的资料才能正确地进行设置。 通过STM32F103C8T6硬件IIC控制4针0.96寸OLED显示屏,我们可以实现对各种图像和文字内容的显示,是嵌入式开发中常用的一种显示方式。 ### 回答2: 首先,stm32f103c8t6是一款运行速度快、性能稳定的工业级微控制器。该微控制器内置硬件IIC接口,可直接用于控制OLED显示屏。 0.96寸OLED显示屏通常具有128x64的分辨率,并且有四个引脚:电源、地、SCL和SDA。连接硬件IIC接口和OLED显示屏的时候,需要将SCL引脚连接到stm32f103c8t6的PB6引脚,将SDA引脚连接到stm32f103c8t6的PB7引脚。 对于代码编写,我们可以使用STM32CubeMX和Keil uVision等工具来生成初始化代码,具体步骤如下: 1. 在STM32CubeMX中选择对应的微控制器型号和工程,然后进入"Pinout & Configuration"页面,找到PB6和PB7引脚,将其配置为I2C1_SCL和I2C1_SDA。 2. 进入"Project Manager"页面,在Code Generator一栏中选择"Generate peripheral initialization as a pair of '.c/.h' files per peripheral",然后点击"Generate Code"按钮。 3. 在Keil uVision中创建一个新工程,将CubeMX生成的.c和.h文件添加到工程中。然后在main函数中调用HAL_I2C_Init函数初始化IIC接口,并使用oled_init函数初始化OLED屏。 4. 编写显示函数,例如oled_show_char等,通过IIC接口向OLED屏发送显示数据即可。 需要注意的是,OLED屏显存为8页,每页包含8个字节,因此需要在显示函数中进行相应的位移计算,以保证数据正确展示在OLED屏上。 综上所述,stm32f103c8t6硬件IIC控制0.96寸OLED显示屏的方式比较简单,只需以下几个步骤:连接SCL和SDA引脚、生成初始化代码、初始化IIC接口和OLED屏、编写显示函数,并处理相关的位移计算。 ### 回答3: STM32F103C8T6是一种强大的微控制器,也是目前广泛应用于嵌入式系统中的芯片之一。它拥有强大的处理器能力和大量的电子模块,并且可以方便地进行编程,具有广泛的应用领域。而硬件IIC控制的4针0.96寸OLED显示屏则是智能硬件设备中非常重要的一部分,可以用于显示各种数据、文本和图形等。 在将STM32F103C8T6微控制器连接到4针0.96寸OLED显示屏之前,我们需要了解一些基本知识。其中,硬件IIC (Inter-Integrated Circuit)是一种用于实现芯片之间通信的协议,它可以实现高速和双向传输。硬件IIC总线有两个线路:SDA和SCL,其中SDA是数据线,而SCL是时钟线。因此,在使用IIC控制4针0.96寸OLED显示屏时,需要将SDA和SCL引脚连接到相应的STM32F103C8T6引脚上。 为了开始使用硬件IIC控制4针0.96寸OLED显示屏,我们需要在STM32F103C8T6上初始化IIC控制器并打开IIC通讯。在初步准备工作完成后,我们可以开始使用C语言程序将相应的数据传输到OLED显示屏上,以便实现图形和文本输出等功能。OLED显示屏有两种驱动方式:点阵和字符。每种驱动方式都有其自己的优势和劣势。 点阵驱动方式发送的数据可能更加精细和清晰,而字符驱动方式可以输出文本等更具分析性的数据。因此,在使用硬件IIC控制4针0.96寸OLED显示屏时,需要选择适当的驱动方式来实现所需的功能。 除此之外,硬件IIC控制4针0.96寸OLED显示屏还涉及到电源管理、数据缓存和错误检测等方面的操作,需要进行适当的设置和调整。只有在正确的设置和调整下才能实现良好的显示效果。 总而言之,硬件IIC控制4针0.96寸OLED显示屏在STM32F103C8T6上的应用是非常重要的,需要熟悉IIC协议、OLED显示屏驱动和字符集库等相关技术知识,并进行适当的调整和设置才能实现理想的显示效果。
下面是STM32F103C8T6通过I2C接口控制0.96寸OLED的按键切换代码示例。 首先,需要在STM32CubeMX中配置I2C接口和GPIO口,具体步骤如下: 1. 打开STM32CubeMX软件,选择对应的芯片型号。 2. 在Pinout选项卡中,将SCL和SDA引脚配置为I2C接口。 3. 在Configuration选项卡中,配置I2C接口的速度、地址等参数。 4. 配置按键所需的GPIO口,设置为输入模式。 5. 生成代码并导入到Keil中。 接下来,可以使用以下代码实现按键切换OLED显示内容: c /* I2C相关定义 */ #define I2C_SCL_Pin GPIO_PIN_6 #define I2C_SCL_GPIO_Port GPIOB #define I2C_SDA_Pin GPIO_PIN_7 #define I2C_SDA_GPIO_Port GPIOB #define OLED_I2C_ADDR 0x78 /* 按键相关定义 */ #define KEY1_Pin GPIO_PIN_13 #define KEY1_GPIO_Port GPIOC #define KEY2_Pin GPIO_PIN_14 #define KEY2_GPIO_Port GPIOC /* OLED相关定义 */ #define OLED_WIDTH 128 #define OLED_HEIGHT 64 #define OLED_CMD 0x00 #define OLED_DAT 0x40 /* OLED初始化命令 */ const uint8_t InitCmd[] = { 0xAE, // 关闭显示 0xD5, 0x80, // 设置时钟分频因子,震荡频率 0xA8, 0x3F, // 设置驱动路数 0xD3, 0x00, // 设置显示偏移 0x40, // 设置起始行 0x8D, 0x14, // 设置电荷泵 0x20, 0x00, // 设置地址模式,水平寻址模式 0xA0, // 设置段重定义 0xC8, // 设置COM扫描方向 0xDA, 0x12, // 设置COM硬件引脚配置 0x81, 0xCF, // 设置对比度 0xD9, 0xF1, // 设置预充电周期 0xDB, 0x40, // 设置VCOMH 0xA4, // 全局显示开启 0xA6, // 设置正反显示 0xAF, // 打开显示 }; /* OLED清屏命令 */ const uint8_t ClearCmd[] = { 0x00, 0x10, // 设置列起始地址 0x00, 0x7F, // 设置列结束地址 0xB0, // 设置页地址 }; /* OLED显示内容 */ const uint8_t Logo[] = { 0xFF, 0x81, 0x81, 0x81, 0x81, 0x81, 0x81, 0xFF, 0xFF, 0x81, 0x81, 0x81, 0x81, 0x81, 0x81, 0xFF, 0xFF, 0xC3, 0xC3, 0xC3, 0xC3, 0xC3, 0xC3, 0xFF, 0xFF, 0xE7, 0xE7, 0xE7, 0xE7, 0xE7, 0xE7, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, }; /* I2C初始化函数 */ void I2C_Init(void) { GPIO_InitTypeDef GPIO_InitStruct = {0}; __HAL_RCC_GPIOB_CLK_ENABLE(); __HAL_RCC_I2C1_CLK_ENABLE(); HAL_NVIC_SetPriority(I2C1_EV_IRQn, 0, 1); HAL_NVIC_EnableIRQ(I2C1_EV_IRQn); /* 配置SCL和SDA引脚 */ GPIO_InitStruct.Pin = I2C_SCL_Pin | I2C_SDA_Pin; GPIO_InitStruct.Mode = GPIO_MODE_AF_OD; GPIO_InitStruct.Pull = GPIO_PULLUP; GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH; GPIO_InitStruct.Alternate = GPIO_AF4_I2C1; HAL_GPIO_Init(GPIOB, &GPIO_InitStruct); /* 配置I2C1 */ I2C_HandleTypeDef hi2c1 = {0}; hi2c1.Instance = I2C1; hi2c1.Init.ClockSpeed = 400000; hi2c1.Init.DutyCycle = I2C_DUTYCYCLE_2; hi2c1.Init.OwnAddress1 = 0; hi2c1.Init.AddressingMode = I2C_ADDRESSINGMODE_7BIT; hi2c1.Init.DualAddressMode = I2C_DUALADDRESS_DISABLE; hi2c1.Init.OwnAddress2 = 0; hi2c1.Init.GeneralCallMode = I2C_GENERALCALL_DISABLE; hi2c1.Init.NoStretchMode = I2C_NOSTRETCH_DISABLE; HAL_I2C_Init(&hi2c1); } /* I2C发送数据函数 */ void I2C_SendData(uint8_t addr, uint8_t *data, uint16_t len) { HAL_I2C_Master_Transmit_IT(&hi2c1, addr, data, len); while (HAL_I2C_GetState(&hi2c1) != HAL_I2C_STATE_READY); } /* OLED写命令函数 */ void OLED_WriteCmd(uint8_t cmd) { uint8_t data[] = {OLED_CMD, cmd}; I2C_SendData(OLED_I2C_ADDR, data, sizeof(data)); } /* OLED写数据函数 */ void OLED_WriteDat(uint8_t dat) { uint8_t data[] = {OLED_DAT, dat}; I2C_SendData(OLED_I2C_ADDR, data, sizeof(data)); } /* OLED初始化函数 */ void OLED_Init(void) { for (uint16_t i = 0; i < sizeof(InitCmd); i++) { OLED_WriteCmd(InitCmd[i]); } } /* OLED清屏函数 */ void OLED_Clear(void) { OLED_WriteCmd(ClearCmd[0]); OLED_WriteCmd(ClearCmd[1]); OLED_WriteCmd(ClearCmd[2]); for (uint16_t i = 0; i < OLED_HEIGHT / 8; i++) { OLED_WriteCmd(0xB0 + i); OLED_WriteCmd(0x00); OLED_WriteCmd(0x10); for (uint16_t j = 0; j < OLED_WIDTH; j++) { OLED_WriteDat(0x00); } } } /* OLED显示函数 */ void OLED_Show(uint8_t *data) { OLED_WriteCmd(0x00); OLED_WriteCmd(0x10); for (uint16_t i = 0; i < OLED_HEIGHT / 8; i++) { OLED_WriteCmd(0xB0 + i); OLED_WriteCmd(0x00); OLED_WriteCmd(0x10); for (uint16_t j = 0; j < OLED_WIDTH; j++) { OLED_WriteDat(data[i * OLED_WIDTH + j]); } } } /* 按键扫描函数 */ uint8_t KEY_Scan(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin) { static uint8_t key_up = 1; if (key_up && HAL_GPIO_ReadPin(GPIOx, GPIO_Pin) == GPIO_PIN_RESET) { HAL_Delay(10); key_up = 0; if (HAL_GPIO_ReadPin(GPIOx, GPIO_Pin) == GPIO_PIN_RESET) { return 1; } } else if (HAL_GPIO_ReadPin(GPIOx, GPIO_Pin) == GPIO_PIN_SET) { key_up = 1; } return 0; } int main(void) { HAL_Init(); I2C_Init(); OLED_Init(); uint8_t show_logo = 1; while (1) { if (KEY_Scan(KEY1_GPIO_Port, KEY1_Pin)) { show_logo = !show_logo; } if (KEY_Scan(KEY2_GPIO_Port, KEY2_Pin)) { OLED_Clear(); } if (show_logo) { OLED_Show((uint8_t *)Logo); } else { OLED_Clear(); } HAL_Delay(10); } } 在上述代码中,首先定义了I2C相关的引脚和OLED的I2C地址,以及按键和OLED的分辨率等参数。 然后,通过I2C_Init函数初始化I2C接口,并实现了I2C_SendData、OLED_WriteCmd、OLED_WriteDat等函数用于控制OLED的显示和清屏操作。 最后,在主函数中使用KEY_Scan函数对按键进行扫描,根据按键状态切换OLED显示内容或清屏,并通过OLED_Show函数将数据发送给OLED进行显示。 需要注意的是,本例中使用了HAL库进行操作,如果使用其他库或裸机编程,可能需要做出一些修改。
以下是使用STM32F103C8T6控制0.96寸4针OLED显示屏的代码示例: #include "stm32f10x.h" #include "stm32f10x_spi.h" #include "stm32f10x_gpio.h" #define OLED_DC_PIN GPIO_Pin_5 #define OLED_DC_PORT GPIOB #define OLED_RST_PIN GPIO_Pin_6 #define OLED_RST_PORT GPIOB #define OLED_CS_PIN GPIO_Pin_7 #define OLED_CS_PORT GPIOB void OLED_Init(void); void OLED_Write_Command(uint8_t cmd); void OLED_Write_Data(uint8_t data); void OLED_Set_Pos(uint8_t x, uint8_t y); void OLED_Fill_Screen(uint8_t data); void OLED_Show_String(uint8_t x, uint8_t y, uint8_t *str); void delay_ms(uint16_t n); int main(void) { OLED_Init(); while(1) { OLED_Fill_Screen(0x00); OLED_Show_String(0, 0, "Hello World!"); delay_ms(1000); } } void OLED_Init(void) { GPIO_InitTypeDef GPIO_InitStructure; SPI_InitTypeDef SPI_InitStructure; RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB | RCC_APB2Periph_SPI1, ENABLE); GPIO_InitStructure.GPIO_Pin = OLED_DC_PIN | OLED_RST_PIN | OLED_CS_PIN; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP; GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; GPIO_Init(OLED_DC_PORT, &GPIO_InitStructure); GPIO_SetBits(OLED_DC_PORT, OLED_CS_PIN | OLED_DC_PIN | OLED_RST_PIN); delay_ms(100); GPIO_ResetBits(OLED_RST_PORT, OLED_RST_PIN); delay_ms(20); GPIO_SetBits(OLED_RST_PORT, OLED_RST_PIN); delay_ms(100); SPI_InitStructure.SPI_Mode = SPI_Mode_Master; SPI_InitStructure.SPI_Direction = SPI_Direction_1Line_Tx; SPI_InitStructure.SPI_DataSize = SPI_DataSize_8b; SPI_InitStructure.SPI_CPOL = SPI_CPOL_Low; SPI_InitStructure.SPI_CPHA = SPI_CPHA_1Edge; SPI_InitStructure.SPI_NSS = SPI_NSS_Soft; SPI_InitStructure.SPI_BaudRatePrescaler = SPI_BaudRatePrescaler_2; SPI_InitStructure.SPI_FirstBit = SPI_FirstBit_MSB; SPI_Init(SPI1, &SPI_InitStructure); SPI_Cmd(SPI1, ENABLE); OLED_Write_Command(0xAE); //display off OLED_Write_Command(0x20); //Set Memory Addressing Mode OLED_Write_Command(0x10); //00,Horizontal Addressing Mode;01,Vertical Addressing Mode;10,Page Addressing Mode (RESET);11,Invalid OLED_Write_Command(0xB0); //Set Page Start Address for Page Addressing Mode,0-7 OLED_Write_Command(0xC8); //Set COM Output Scan Direction OLED_Write_Command(0x00); //---set low column address OLED_Write_Command(0x10); //---set high column address OLED_Write_Command(0x40); //--set start line address OLED_Write_Command(0x81); //--set contrast control register OLED_Write_Command(0xFF); OLED_Write_Command(0xA1); //--set segment re-map 0 to 127 OLED_Write_Command(0xA6); //--set normal display OLED_Write_Command(0xA8); //--set multiplex ratio(1 to 64) OLED_Write_Command(0x3F); // OLED_Write_Command(0xA4); //0xa4,Output follows RAM content;0xa5,Output ignores RAM content OLED_Write_Command(0xD3); //-set display offset OLED_Write_Command(0x00); //-not offset OLED_Write_Command(0xD5); //--set display clock divide ratio/oscillator frequency OLED_Write_Command(0xF0); //--set divide ratio OLED_Write_Command(0xD9); //--set pre-charge period OLED_Write_Command(0x22); // OLED_Write_Command(0xDA); //--set com pins hardware configuration OLED_Write_Command(0x12); OLED_Write_Command(0xDB); //--set vcomh OLED_Write_Command(0x20); //0x20,0.77xVcc OLED_Write_Command(0x8D); //--set DC-DC enable OLED_Write_Command(0x14); // OLED_Write_Command(0xAF); //--turn on oled panel } void OLED_Write_Command(uint8_t cmd) { GPIO_ResetBits(OLED_DC_PORT, OLED_DC_PIN); GPIO_ResetBits(OLED_CS_PORT, OLED_CS_PIN); SPI_I2S_SendData(SPI1, cmd); while (SPI_I2S_GetFlagStatus(SPI1, SPI_I2S_FLAG_BSY) == SET); GPIO_SetBits(OLED_CS_PORT, OLED_CS_PIN); } void OLED_Write_Data(uint8_t data) { GPIO_SetBits(OLED_DC_PORT, OLED_DC_PIN); GPIO_ResetBits(OLED_CS_PORT, OLED_CS_PIN); SPI_I2S_SendData(SPI1, data); while (SPI_I2S_GetFlagStatus(SPI1, SPI_I2S_FLAG_BSY) == SET); GPIO_SetBits(OLED_CS_PORT, OLED_CS_PIN); } void OLED_Set_Pos(uint8_t x, uint8_t y) { OLED_Write_Command(0xB0 + y); OLED_Write_Command(((x & 0xF0) >> 4) | 0x10); OLED_Write_Command(x & 0x0F); } void OLED_Fill_Screen(uint8_t data) { 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(data); } } } void OLED_Show_String(uint8_t x, uint8_t y, uint8_t *str) { while (*str != '\0') { OLED_Set_Pos(x, y); uint8_t i; for (i = 0; i < 8; i++) { OLED_Write_Data(FONT8x8[(*str)][i]); } x += 8; str++; } } void delay_ms(uint16_t n) { uint16_t i, j; for (i = 0; i < n; i++) { for (j = 0; j < 1141; j++); } } 其中,OLED_Init()进行OLED屏幕初始化,OLED_Write_Command()和OLED_Write_Data()用于向OLED屏幕写入指令和数据,OLED_Set_Pos()用于设置OLED屏幕显示位置,OLED_Fill_Screen()用于填充整个OLED屏幕,OLED_Show_String()用于在指定位置显示字符串。注意,此代码中使用的是8x8大小的字体,需要提供相应的字体库。
以下是使用STM32F103C8T6驱动0.96寸4针IIC OLED屏幕的完整代码: c #include "stm32f10x.h" #include "stm32f10x_i2c.h" #include "stm32f10x_gpio.h" #include "stm32f10x_rcc.h" #include "delay.h" #define OLED_ADDRESS 0x78 // OLED屏幕地址 // 定义IIC相关引脚 #define OLED_SCL_PIN GPIO_Pin_6 #define OLED_SDA_PIN GPIO_Pin_7 #define OLED_SCL_PORT GPIOB #define OLED_SDA_PORT GPIOB // 定义OLED指令宏 #define OLED_CMD_MODE 0x00 // 指令模式 #define OLED_DATA_MODE 0x40 // 数据模式 #define OLED_SET_CONTRAST_CONTROL 0x81 // 设置对比度控制 #define OLED_DISPLAY_ALL_ON_RESUME 0xA4 // 全局显示开启; 常规显示模式 #define OLED_DISPLAY_ALL_ON 0xA5 // 全局显示开启; 全部显示模式 #define OLED_NORMAL_DISPLAY 0xA6 // 常规显示模式; 反相显示 #define OLED_INVERSE_DISPLAY 0xA7 // 反相显示模式 #define OLED_DISPLAY_OFF 0xAE // OLED关闭显示 #define OLED_DISPLAY_ON 0xAF // OLED开启显示 #define OLED_SET_DISPLAY_OFFSET 0xD3 // 设置显示偏移 #define OLED_SET_COM_PINS 0xDA // 设置COM硬件引脚配置 #define OLED_SET_VCOM_DETECT 0xDB // 设置VCOMH电压倍增比 #define OLED_SET_DISPLAY_CLOCK_DIV_RATIO 0xD5 // 设置显示时钟分频比; 频率 #define OLED_SET_PRECHARGE_PERIOD 0xD9 // 设置预充电周期 #define OLED_SET_MULTIPLEX_RATIO 0xA8 // 设置驱动路数 #define OLED_SET_LOW_COLUMN 0x00 // 设置列低地址 #define OLED_SET_HIGH_COLUMN 0x10 // 设置列高地址 #define OLED_SET_START_LINE 0x40 // 设置起始行 #define OLED_MEMORY_MODE 0x20 // 内存地址模式 #define OLED_COLUMN_ADDR 0x21 // 列地址 #define OLED_PAGE_ADDR 0x22 // 页面地址 #define OLED_COM_SCAN_INC 0xC0 // 从COM0到COM[N-1];输出扫描 #define OLED_COM_SCAN_DEC 0xC8 // 从COM[N-1]到COM0;输出扫描 #define OLED_SEG_REMAP 0xA0 // 列地址0映射到SEG0 #define OLED_CHARGE_PUMP 0x8D // 电荷泵设置 // IIC初始化函数 void IIC_Init(void) { GPIO_InitTypeDef GPIO_InitStructure; I2C_InitTypeDef I2C_InitStructure; // 开启GPIOB时钟 RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB, ENABLE); // 配置GPIOB6和GPIOB7为开漏输出, IIC总线需要 GPIO_InitStructure.GPIO_Pin = OLED_SCL_PIN | OLED_SDA_PIN; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_OD; // 开漏输出 GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; GPIO_Init(OLED_SCL_PORT, &GPIO_InitStructure); // 开启I2C1时钟 RCC_APB1PeriphClockCmd(RCC_APB1Periph_I2C1, ENABLE); // 配置I2C1参数 I2C_InitStructure.I2C_Mode = I2C_Mode_I2C; // I2C模式 I2C_InitStructure.I2C_DutyCycle = I2C_DutyCycle_2; // 占空比 I2C_InitStructure.I2C_OwnAddress1 = 0x00; // 本机地址 I2C_InitStructure.I2C_Ack = I2C_Ack_Enable; // 允许应答 I2C_InitStructure.I2C_AcknowledgedAddress = I2C_AcknowledgedAddress_7bit; // 7位地址 I2C_InitStructure.I2C_ClockSpeed = 400000; // 时钟速度 // 初始化I2C1 I2C_Cmd(I2C1, ENABLE); // 使能I2C1 I2C_Init(I2C1, &I2C_InitStructure); // 初始化I2C1 } // IIC发送数据函数 void IIC_SendByte(uint8_t byte) { uint8_t i; // 开始发送 I2C_GenerateSTART(I2C1, ENABLE); while(!I2C_CheckEvent(I2C1, I2C_EVENT_MASTER_MODE_SELECT)); // 等待事件发生 // 发送设备地址 I2C_Send7bitAddress(I2C1, OLED_ADDRESS, I2C_Direction_Transmitter); // 读写方向为写 while(!I2C_CheckEvent(I2C1, I2C_EVENT_MASTER_TRANSMITTER_MODE_SELECTED)); // 等待事件发生 // 发送数据 I2C_SendData(I2C1, byte); while(!I2C_CheckEvent(I2C1, I2C_EVENT_MASTER_BYTE_TRANSMITTED)); // 等待事件发生 // 停止发送 I2C_GenerateSTOP(I2C1, ENABLE); for(i=0; i<50; i++); // 延时 } // OLED写入命令函数 void OLED_WriteCmd(uint8_t cmd) { IIC_SendByte(OLED_CMD_MODE); // 指令模式 IIC_SendByte(cmd); // 发送指令 } // OLED写入数据函数 void OLED_WriteData(uint8_t data) { IIC_SendByte(OLED_DATA_MODE); // 数据模式 IIC_SendByte(data); // 发送数据 } // OLED初始化函数 void OLED_Init(void) { OLED_WriteCmd(OLED_DISPLAY_OFF); // 关闭OLED显示 OLED_WriteCmd(OLED_SET_DISPLAY_CLOCK_DIV_RATIO); // 设置显示时钟分频比; 频率 OLED_WriteCmd(0x80); // 0x80是分频比值 OLED_WriteCmd(OLED_SET_MULTIPLEX_RATIO); // 设置驱动路数 OLED_WriteCmd(0x1F); // 驱动路数(1-64) OLED_WriteCmd(OLED_SET_DISPLAY_OFFSET); // 设置显示偏移 OLED_WriteCmd(0x00); // 偏移量为0 OLED_WriteCmd(OLED_SET_START_LINE | 0x00); // 设置起始行 OLED_WriteCmd(OLED_CHARGE_PUMP); // 电荷泵设置 OLED_WriteCmd(0x14); // 0x14是启用内部VCC OLED_WriteCmd(OLED_MEMORY_MODE); // 内存地址模式 OLED_WriteCmd(0x00); // 水平地址模式 OLED_WriteCmd(OLED_SEG_REMAP | 0x01); // 列地址0映射到SEG0 OLED_WriteCmd(OLED_COM_SCAN_DEC); // 从COM[N-1]到COM0;输出扫描 OLED_WriteCmd(OLED_SET_COM_PINS); // 设置COM硬件引脚配置 OLED_WriteCmd(0x12); // 0x12是设置COM硬件引脚配置 OLED_WriteCmd(OLED_SET_CONTRAST_CONTROL); // 设置对比度控制 OLED_WriteCmd(0xCF); // 0xCF是对比度值 OLED_WriteCmd(OLED_SET_PRECHARGE_PERIOD); // 设置预充电周期 OLED_WriteCmd(0xF1); // 预充电周期(1-15) OLED_WriteCmd(OLED_SET_VCOM_DETECT); // 设置VCOMH电压倍增比 OLED_WriteCmd(0x40); // 0x40是VCOMH电压倍增比 OLED_WriteCmd(OLED_DISPLAY_ALL_ON_RESUME); // 全局显示开启; 常规显示模式 OLED_WriteCmd(OLED_NORMAL_DISPLAY); // 常规显示模式; 反相显示 OLED_WriteCmd(OLED_DISPLAY_ON); // OLED开启显示 } // OLED清屏函数 void OLED_Clear(void) { uint8_t i, j; for(i=0; i<8; i++) { OLED_WriteCmd(OLED_SET_LOW_COLUMN); // 设置列低地址 OLED_WriteCmd(OLED_SET_HIGH_COLUMN); // 设置列高地址 OLED_WriteCmd(OLED_PAGE_ADDR + i); // 设置页面地址 for(j=0; j<128; j++) { OLED_WriteData(0x00); // 清屏,发送0x00 } } } // OLED显示字符串函数 void OLED_ShowString(uint8_t x, uint8_t y, const uint8_t *str) { uint8_t c = 0, i = 0, j = 0; while (str[c] != '\0') { i = 0; j = 0; c = str[c] - 32; if(x > 120) { x = 0; y++; } OLED_WriteCmd(OLED_SET_LOW_COLUMN | (x & 0x0f)); // 设置列低地址 OLED_WriteCmd(OLED_SET_HIGH_COLUMN | ((x >> 4) & 0x0f)); // 设置列高地址 OLED_WriteCmd(OLED_PAGE_ADDR | y); // 设置页面地址 for(i=0; i<6; i++) { OLED_WriteData(Font_6x8[c][i]); } x += 6; } } int main(void) { SystemInit(); Delay_Init(); IIC_Init(); // IIC初始化 OLED_Init(); // OLED初始化 OLED_Clear(); // OLED清屏 while(1) { OLED_ShowString(0, 0, "Hello, World!"); // OLED显示字符串 Delay_Ms(1000); // 延时1秒 OLED_Clear(); // OLED清屏 Delay_Ms(1000); // 延时1秒 } } 其中,Font_6x8是一个6x8的字符点阵数组,用于在OLED上显示字符串。你可以在自己的工程中自行定义和修改。

最新推荐

DAC简介及参考电路PPT学习教案.pptx

DAC简介及参考电路PPT学习教案.pptx

管理建模和仿真的文件

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

OceanBase数据库简介及原理解析

# 1. OceanBase数据库概述 ## 1.1 OceanBase数据库的发展历程 OceanBase数据库是由阿里巴巴集团自主研发的一款分布式关系型数据库系统,起源于阿里集团的业务需求和技术挑战。自2010年开始研发,经过多年的迭代和优化,OceanBase已经成为阿里巴巴集团重要的核心数据库产品之一。在实际的业务场景中,OceanBase已经被广泛应用于金融、电商、物流等各个领域。 ## 1.2 OceanBase数据库的特点和优势 OceanBase数据库具有以下特点和优势: - **分布式架构**:OceanBase采用多副本分布式架构,可以实现高可用和数据容灾。 -

python的pandas读取excel怎么将excel表里的列从1开始而不是0

在 Pandas 中,数据框的列默认从0开始编号,但我们可以通过自定义函数来进行数据列的转换。可以先将读取的数据框列的第一个值设为1,然后对后续列进行递增处理。 以下是示例代码: ```python import pandas as pd # 读取 Excel 文件 df = pd.read_excel('your_excel_file.xlsx') # 定义函数将列从1开始 def reset_column(x): return str(int(x) + 1) # 应用函数到所有列名 df = df.rename(columns=reset_column) # 打印数据框

第三章薪酬水平、薪酬系统的运行与控制.pptx

第三章薪酬水平、薪酬系统的运行与控制.pptx

"互动学习:行动中的多样性与论文攻读经历"

多样性她- 事实上SCI NCES你的时间表ECOLEDO C Tora SC和NCESPOUR l’Ingén学习互动,互动学习以行动为中心的强化学习学会互动,互动学习,以行动为中心的强化学习计算机科学博士论文于2021年9月28日在Villeneuve d'Asq公开支持马修·瑟林评审团主席法布里斯·勒菲弗尔阿维尼翁大学教授论文指导奥利维尔·皮耶昆谷歌研究教授:智囊团论文联合主任菲利普·普雷教授,大学。里尔/CRISTAL/因里亚报告员奥利维耶·西格德索邦大学报告员卢多维奇·德诺耶教授,Facebook /索邦大学审查员越南圣迈IMT Atlantic高级讲师邀请弗洛里安·斯特鲁布博士,Deepmind对于那些及时看到自己错误的人...3谢谢你首先,我要感谢我的两位博士生导师Olivier和Philippe。奥利维尔,"站在巨人的肩膀上"这句话对你来说完全有意义了。从科学上讲,你知道在这篇论文的(许多)错误中,你是我可以依

理解MVC架构:Laravel框架的核心设计

# 1. 第1章 项目立项与概述 ## 1.1 动机 随着互联网的快速发展,Web应用的开发需求不断增加。为了提高开发效率、代码可维护性和团队协作效率,我们决定采用MVC架构来设计我们的Web应用。 ## 1.2 服务器状态 我们的服务器环境采用了LAMP(Linux + Apache + MySQL + PHP)架构,满足了我们Web应用开发的基本需求,但为了更好地支持MVC架构,我们将对服务器进行适当的配置和优化。 ## 1.3 项目立项 经过团队讨论和决定,决定采用Laravel框架来开发我们的Web应用,基于MVC架构进行设计和开发,为此做出了项目立项。 ## 1.4 项目概况

如何将HDFS上的文件读入到Hbase,用java

要将HDFS上的文件读入到HBase,可以使用Java编写MapReduce程序实现,以下是实现步骤: 1. 首先需要创建一个HBase表,可使用HBase Shell或Java API创建; 2. 编写MapReduce程序,其中Map阶段读取HDFS上的文件,将数据转换成Put对象,然后将Put对象写入到HBase表中; 3. 在MapReduce程序中设置HBase表名、列族名、列名等参数; 4. 在程序运行前,需要将HBase相关的jar包和配置文件加入到classpath中; 5. 最后提交MapReduce任务运行即可。 以下是示例代码: ``` Configuration

酒店餐饮部工作程序及标准(某酒店).doc

餐饮

关系数据表示学习

关系数据卢多维奇·多斯桑托斯引用此版本:卢多维奇·多斯桑托斯。关系数据的表示学习机器学习[cs.LG]。皮埃尔和玛丽·居里大学-巴黎第六大学,2017年。英语。NNT:2017PA066480。电话:01803188HAL ID:电话:01803188https://theses.hal.science/tel-01803188提交日期:2018年HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaireUNIVERSITY PIERRE和 MARIE CURIE计算机科学、电信和电子学博士学院(巴黎)巴黎6号计算机科学实验室D八角形T HESIS关系数据表示学习作者:Ludovic DOS SAntos主管:Patrick GALLINARI联合主管:本杰明·P·伊沃瓦斯基为满足计算机科学博士学位的要求而提交的论文评审团成员:先生蒂埃里·A·退休记者先生尤尼斯·B·恩