[其他ST产品] STM32F103的SPI或IIC接口实现OLED屏显和汉字输出

[复制链接]
 楼主| 在水一方00 发表于 2023-1-26 16:32 | 显示全部楼层 |阅读模式
使用OLED显示屏显示数据
实验工具与材料
软件:keil
硬件:PC机,STM32开发板(本过程采用的是野火stm32mini开发板),0.96寸OLED显示屏,下载器(本过程采用ST_Link)
0.96寸OLED显示屏相关介绍
参考下面链接:0.96inch SPI OLED Module - LCD wiki
运行厂家给出的Demo程序
————————————————
版权声明:本文为CSDN博主「m0_54384176」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/m0_54384176/article/details/127924866

 楼主| 在水一方00 发表于 2023-1-26 16:35 | 显示全部楼层
①下载程序
程序下载链接:http://www.lcdwiki.com/res/Program/OLED/0.96inch/SPI_SSD1306_MSP096X_V1.0/0.96inch_SPI_OLED_Module_SSD1306_MSP096X_V1.0.zip 9201963d23b2d2c039.png
②打开资料包,选择与自己平台相同的实例,打开Demo的工程,使用keil编译
③将程序烧录到开发板
④连接显示屏和开发板
 楼主| 在水一方00 发表于 2023-1-26 16:36 | 显示全部楼层
显示自己的学号和姓名;
打开取自模软件新建图像
6220463d23b6a4fdee.png
在输入区输入姓名学号后按下ctrl+enter键
点击取模方式的c51格式后显示点阵
将点阵复制,之后会用
 楼主| 在水一方00 发表于 2023-1-26 16:37 | 显示全部楼层
实现显示代码
在test.c可以找到类似这样的代码
3864763d23bcf423e8.png
在引号中写入自己的姓名
 楼主| 在水一方00 发表于 2023-1-26 16:38 | 显示全部楼层
然后找到oledfont.h
7543363d23bfa6b0c5.png
按照实例类型将刚才的字模生成点阵复制到这里
 楼主| 在水一方00 发表于 2023-1-26 16:39 | 显示全部楼层
在主函数中设置
  1. int main(void)
  2. {       
  3.         delay_init();                           //延时函数初始化          
  4.         OLED_Init();                                 //初始化OLED  
  5.         OLED_Clear(0);             //清屏(全黑)
  6.         while(1)
  7.         {       
  8.                 TEST_MainPage();         //界面显示
  9.         }
  10. }
 楼主| 在水一方00 发表于 2023-1-26 16:41 | 显示全部楼层
烧录并展示结果
自行修改程序实现显示温度和湿度
显示要求:

显示AHT20的温度和湿度;
271963d23cc264b26.png
 楼主| 在水一方00 发表于 2023-1-26 20:50 | 显示全部楼层
自行修改程序实现显示温度和湿度
显示要求:

显示AHT20的温度和湿度;
 楼主| 在水一方00 发表于 2023-1-26 20:52 | 显示全部楼层
主函数修改
int main(void)
{
delay_init(); //延时函数初始化
uart_init(115200);
IIC_Init();
 楼主| 在水一方00 发表于 2023-1-26 20:53 | 显示全部楼层
  1. NVIC_Configuration();            //设置NVIC中断分组2:2位抢占优先级,2位响应优先级        
  2. OLED_Init();                                 //初始化OLED  
  3. OLED_Clear(0);
  4. while(1)
  5. {
  6.         //printf("温度湿度显示");
  7.         read_AHT20_once();
  8.         OLED_Clear(0);
  9.         delay_ms(1500);
 楼主| 在水一方00 发表于 2023-1-28 12:35 | 显示全部楼层
.新建bsp_i2c.c
代码如下
  1. #include "bsp_i2c.h"
  2. #include "delay.h"
  3. #include "oled.h"
  4. #include "gui.h"
  5. #include "test.h"
  6. #include "stdio.h"
  7. #include "string.h"

  8. uint8_t   ack_status=0;
  9. uint8_t   readByte[6];
  10. uint8_t   AHT20_status=0;

  11. uint32_t  H1=0;  //Humility
  12. uint32_t  T1=0;  //Temperature

  13. uint8_t t1,t2,t3,t4;
  14. uint8_t h1,h2,h3,h4;

  15. uint8_t  AHT20_OutData[4];
  16. uint8_t  AHT20sendOutData[10] = {0xFA, 0x06, 0x0A, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xFF};
  17. char strTemp[30];  //声明字符数组strTemp,初始化元素30  
  18. char strHumi[30];  //声明字符数组strHumi,初始化元素30
  19. int t;
  20. int h;
  21. float a;
  22. float b;
  23. void IIC_Init(void)
  24. {                                             
  25.         GPIO_InitTypeDef GPIO_InitStructure;
  26.         RCC_APB2PeriphClockCmd(        RCC_APB2Periph_GPIOB, ENABLE );       
  27.           
  28.         GPIO_InitStructure.GPIO_Pin = GPIO_Pin_6|GPIO_Pin_7;
  29.         GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP ;   //í?íìê?3?
  30.         GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  31.         GPIO_Init(GPIOB, &GPIO_InitStructure);

  32.         IIC_SCL=1;
  33.         IIC_SDA=1;

  34. }
  35. //2úéúIIC?eê?D?o?
  36. void IIC_Start(void)
  37. {
  38.         SDA_OUT();     //sda??ê?3?
  39.         IIC_SDA=1;                    
  40.         IIC_SCL=1;
  41.         delay_us(4);
  42.         IIC_SDA=0;//START:when CLK is high,DATA change form high to low
  43.         delay_us(4);
  44.         IIC_SCL=0;//?ˉ×?I2C×ü??£?×?±?·¢?í?ò?óê?êy?Y
  45. }          
  46. //2úéúIICí£?1D?o?
  47. void IIC_Stop(void)
  48. {
  49.         SDA_OUT();//sda??ê?3?
  50.         IIC_SCL=0;
  51.         IIC_SDA=0;//STOP:when CLK is high DATA change form low to high
  52.         delay_us(4);
  53.         IIC_SCL=1;
  54.         IIC_SDA=1;//·¢?íI2C×ü???áê?D?o?
  55.         delay_us(4);                                                                  
  56. }
  57. //μè′yó|′eD?o?μ?à′
  58. //·μ???μ£o1£??óê?ó|′eê§°ü
  59. //        0£??óê?ó|′e3é1|
  60. u8 IIC_Wait_Ack(void)
  61. {
  62.         u8 ucErrTime=0;
  63.         SDA_IN();      //SDAéè???aê?è?  
  64.         IIC_SDA=1;delay_us(1);          
  65.         IIC_SCL=1;delay_us(1);         
  66.         while(READ_SDA)
  67.         {
  68.                 ucErrTime++;
  69.                 if(ucErrTime>250)
  70.                 {
  71.                         IIC_Stop();
  72.                         return 1;
  73.                 }
  74.         }
  75.         IIC_SCL=0;//ê±?óê?3?0           
  76.         return 0;  
  77. }
  78. //2úéúACKó|′e
  79. void IIC_Ack(void)
  80. {
  81.         IIC_SCL=0;
  82.         SDA_OUT();
  83.         IIC_SDA=0;
  84.         delay_us(2);
  85.         IIC_SCL=1;
  86.         delay_us(2);
  87.         IIC_SCL=0;
  88. }
  89. //2?2úéúACKó|′e                    
  90. void IIC_NAck(void)
  91. {
  92.         IIC_SCL=0;
  93.         SDA_OUT();
  94.         IIC_SDA=1;
  95.         delay_us(2);
  96.         IIC_SCL=1;
  97.         delay_us(2);
  98.         IIC_SCL=0;
  99. }                                                                              
  100. //IIC·¢?íò???×??ú
  101. //·μ??′ó?úóD?Tó|′e
  102. //1£?óDó|′e
  103. //0£??Tó|′e                          
  104. void IIC_Send_Byte(u8 txd)
  105. {                        
  106.     u8 t;   
  107.                 SDA_OUT();             
  108.     IIC_SCL=0;//à-μíê±?ó?aê?êy?Y′?ê?
  109.     for(t=0;t<8;t++)
  110.     {              
  111.         IIC_SDA=(txd&0x80)>>7;
  112.         txd<<=1;           
  113.                 delay_us(2);   //??TEA5767?aèy???óê±??ê?±?D?μ?
  114.                 IIC_SCL=1;
  115.                 delay_us(2);
  116.                 IIC_SCL=0;       
  117.                 delay_us(2);
  118.     }         
  119. }             
  120. //?á1??×??ú£?ack=1ê±£?·¢?íACK£?ack=0£?·¢?ínACK   
  121. u8 IIC_Read_Byte(unsigned char ack)
  122. {
  123.         unsigned char i,receive=0;
  124.         SDA_IN();//SDAéè???aê?è?
  125.   for(i=0;i<8;i++ )
  126.         {
  127.     IIC_SCL=0;
  128.     delay_us(2);
  129.                 IIC_SCL=1;
  130.     receive<<=1;
  131.     if(READ_SDA)receive++;   
  132.                 delay_us(1);
  133.   }                                         
  134.         if (!ack)
  135.                         IIC_NAck();//·¢?ínACK
  136.         else
  137.                         IIC_Ack(); //·¢?íACK   
  138.         return receive;
  139. }

  140. void IIC_WriteByte(uint16_t addr,uint8_t data,uint8_t device_addr)
  141. {
  142.         IIC_Start();  
  143.        
  144.         if(device_addr==0xA0) //eepromμ??·′óóú1×??ú
  145.                 IIC_Send_Byte(0xA0 + ((addr/256)<<1));//·¢?í??μ??·
  146.         else
  147.                 IIC_Send_Byte(device_addr);            //·¢?÷?tμ??·
  148.         IIC_Wait_Ack();
  149.         IIC_Send_Byte(addr&0xFF);   //·¢?íμíμ??·
  150.         IIC_Wait_Ack();
  151.         IIC_Send_Byte(data);     //·¢?í×??ú                                                          
  152.         IIC_Wait_Ack();                                
  153.   IIC_Stop();//2úéúò???í£?1ì??t
  154.         if(device_addr==0xA0) //
  155.                 delay_ms(10);
  156.         else
  157.                 delay_us(2);
  158. }

  159. uint16_t IIC_ReadByte(uint16_t addr,uint8_t device_addr,uint8_t ByteNumToRead)  //?á??′??÷?ò?áêy?Y
  160. {       
  161.                 uint16_t data;
  162.                 IIC_Start();  
  163.                 if(device_addr==0xA0)
  164.                         IIC_Send_Byte(0xA0 + ((addr/256)<<1));
  165.                 else
  166.                         IIC_Send_Byte(device_addr);       
  167.                 IIC_Wait_Ack();
  168.                 IIC_Send_Byte(addr&0xFF);   //·¢?íμíμ??·
  169.                 IIC_Wait_Ack();

  170.                 IIC_Start();         
  171.                 IIC_Send_Byte(device_addr+1);            //·¢?÷?tμ??·
  172.                 IIC_Wait_Ack();
  173.                 if(ByteNumToRead == 1)//LM75???èêy?Y?a11bit
  174.                 {
  175.                         data=IIC_Read_Byte(0);
  176.                 }
  177.                 else
  178.                         {
  179.                                 data=IIC_Read_Byte(1);
  180.                                 data=(data<<8)+IIC_Read_Byte(0);
  181.                         }
  182.                 IIC_Stop();//2úéúò???í£?1ì??t            
  183.                 return data;
  184. }


  185. /**********
  186. *é???2?·??aIO?ú?£?éI2C????
  187. *
  188. *′ó?aò????aê??aAHT20μ?????I2C
  189. *oˉêy??óDIICoíI2Cμ???±e£???×¢òa£?£?£?£?£?
  190. *
  191. *2020/2/23×?oóDT??è??ú
  192. *
  193. ***********/
  194. void  read_AHT20_once(void)
  195. {
  196.         delay_ms(10);

  197.         reset_AHT20();
  198.         delay_ms(10);

  199.         init_AHT20();
  200.         delay_ms(10);

  201.         startMeasure_AHT20();
  202.         delay_ms(80);

  203.         read_AHT20();
  204.         delay_ms(5);
  205. }


  206. void  reset_AHT20(void)
  207. {

  208.         I2C_Start();

  209.         I2C_WriteByte(0x70);
  210.         ack_status = Receive_ACK();
  211.         if(ack_status) printf("1");
  212.         else printf("1-n-");
  213.         I2C_WriteByte(0xBA);
  214.         ack_status = Receive_ACK();
  215.                 if(ack_status) printf("2");
  216.         else printf("2-n-");
  217.         I2C_Stop();

  218.         /*
  219.         AHT20_OutData[0] = 0;
  220.         AHT20_OutData[1] = 0;
  221.         AHT20_OutData[2] = 0;
  222.         AHT20_OutData[3] = 0;
  223.         */
  224. }



  225. void  init_AHT20(void)
  226. {
  227.         I2C_Start();

  228.         I2C_WriteByte(0x70);
  229.         ack_status = Receive_ACK();
  230.         if(ack_status) printf("3");
  231.         else printf("3-n-");       
  232.         I2C_WriteByte(0xE1);
  233.         ack_status = Receive_ACK();
  234.         if(ack_status) printf("4");
  235.         else printf("4-n-");
  236.         I2C_WriteByte(0x08);
  237.         ack_status = Receive_ACK();
  238.         if(ack_status) printf("5");
  239.         else printf("5-n-");
  240.         I2C_WriteByte(0x00);
  241.         ack_status = Receive_ACK();
  242.         if(ack_status) printf("6");
  243.         else printf("6-n-");
  244.         I2C_Stop();
  245. }



  246. void  startMeasure_AHT20(void)
  247. {
  248.         //------------
  249.         I2C_Start();

  250.         I2C_WriteByte(0x70);
  251.         ack_status = Receive_ACK();
  252.         if(ack_status) printf("7");
  253.         else printf("7-n-");
  254.         I2C_WriteByte(0xAC);
  255.         ack_status = Receive_ACK();
  256.         if(ack_status) printf("8");
  257.         else printf("8-n-");
  258.         I2C_WriteByte(0x33);
  259.         ack_status = Receive_ACK();
  260.         if(ack_status) printf("9");
  261.         else printf("9-n-");
  262.         I2C_WriteByte(0x00);
  263.         ack_status = Receive_ACK();
  264.         if(ack_status) printf("10");
  265.         else printf("10-n-");
  266.         I2C_Stop();
  267. }



  268. void read_AHT20(void)
  269. {
  270.         uint8_t   i;
  271.         for(i=0; i<6; i++)
  272.         {
  273.                 readByte[i]=0;
  274.         }

  275.         //-------------
  276.         I2C_Start();

  277.         I2C_WriteByte(0x71);
  278.         ack_status = Receive_ACK();
  279.         readByte[0]= I2C_ReadByte();
  280.         Send_ACK();

  281.         readByte[1]= I2C_ReadByte();
  282.         Send_ACK();

  283.         readByte[2]= I2C_ReadByte();
  284.         Send_ACK();

  285.         readByte[3]= I2C_ReadByte();
  286.         Send_ACK();

  287.         readByte[4]= I2C_ReadByte();
  288.         Send_ACK();

  289.         readByte[5]= I2C_ReadByte();
  290.         SendNot_Ack();
  291.         //Send_ACK();

  292.         I2C_Stop();

  293.         //--------------
  294.         if( (readByte[0] & 0x68) == 0x08 )
  295.         {
  296.                 H1 = readByte[1];
  297.                 H1 = (H1<<8) | readByte[2];
  298.                 H1 = (H1<<8) | readByte[3];
  299.                 H1 = H1>>4;

  300.                 H1 = (H1*1000)/1024/1024;

  301.                 T1 = readByte[3];
  302.                 T1 = T1 & 0x0000000F;
  303.                 T1 = (T1<<8) | readByte[4];
  304.                 T1 = (T1<<8) | readByte[5];

  305.                 T1 = (T1*2000)/1024/1024 - 500;

  306.                 AHT20_OutData[0] = (H1>>8) & 0x000000FF;
  307.                 AHT20_OutData[1] = H1 & 0x000000FF;

  308.                 AHT20_OutData[2] = (T1>>8) & 0x000000FF;
  309.                 AHT20_OutData[3] = T1 & 0x000000FF;
  310.         }
  311.         else
  312.         {
  313.                 AHT20_OutData[0] = 0xFF;
  314.                 AHT20_OutData[1] = 0xFF;

  315.                 AHT20_OutData[2] = 0xFF;
  316.                 AHT20_OutData[3] = 0xFF;
  317.                 printf("lyy");

  318.         }
  319.         printf("\r\n");
  320.        
  321.         printf("温度:%d%d.%d",T1/100,(T1/10)%10,T1%10);
  322.         printf("湿度:%d%d.%d",H1/100,(H1/10)%10,H1%10);
  323.         printf("\r\n");
  324.         t=T1/10;
  325.         t1=T1%10;
  326.         a=(float)(t+t1*0.1);
  327.         h=H1/10;
  328.         h1=H1%10;
  329.         b=(float)(h+h1*0.1);
  330.         sprintf(strTemp,"%.1f",a);   //调用Sprintf函数把DHT11的温度数据格式化到字符串数组变量strTemp中  
  331.   sprintf(strHumi,"%.1f",b);    //调用Sprintf函数把DHT11的湿度数据格式化到字符串数组变量strHumi中  
  332.         //printf(strTemp);
  333.         //printf("/r/n");
  334.         GUI_ShowCHinese(16,00,16,"温湿度显示",1);
  335.         GUI_ShowCHinese(16,20,16,"温度",1);
  336.         GUI_ShowString(53,20,strTemp,16,1);
  337.         GUI_ShowCHinese(16,38,16,"湿度",1);
  338.         GUI_ShowString(53,38,strHumi,16,1);
  339.         delay_ms(1500);               
  340.         delay_ms(1500);
  341.         delay_ms(1500);
  342.         delay_ms(1500);
  343.        
  344. }




  345. uint8_t  Receive_ACK(void)
  346. {
  347.         uint8_t result=0;
  348.         uint8_t cnt=0;

  349.         IIC_SCL = 0;
  350.         SDA_IN();
  351.         delay_us(4);

  352.         IIC_SCL = 1;
  353.         delay_us(4);

  354.         while(READ_SDA && (cnt<100))
  355.         {
  356.                 cnt++;
  357.         }

  358.         IIC_SCL = 0;
  359.         delay_us(4);

  360.         if(cnt<100)
  361.         {
  362.                 result=1;
  363.         }
  364.         return result;
  365. }



  366. void  Send_ACK(void)
  367. {
  368.         SDA_OUT();
  369.         IIC_SCL = 0;
  370.         delay_us(4);

  371.         IIC_SDA = 0;
  372.         delay_us(4);

  373.         IIC_SCL = 1;
  374.         delay_us(4);
  375.         IIC_SCL = 0;
  376.         delay_us(4);

  377.         SDA_IN();
  378. }



  379. void  SendNot_Ack(void)
  380. {
  381.         SDA_OUT();
  382.         IIC_SCL = 0;
  383.         delay_us(4);

  384.         IIC_SDA = 1;
  385.         delay_us(4);

  386.         IIC_SCL = 1;
  387.         delay_us(4);

  388.         IIC_SCL = 0;
  389.         delay_us(4);

  390.         IIC_SDA = 0;
  391.         delay_us(4);
  392. }


  393. void I2C_WriteByte(uint8_t  input)
  394. {
  395.         uint8_t  i;
  396.         SDA_OUT();
  397.         for(i=0; i<8; i++)
  398.         {
  399.                 IIC_SCL = 0;
  400.                 delay_ms(5);

  401.                 if(input & 0x80)
  402.                 {
  403.                         IIC_SDA = 1;
  404.                         //delaymm(10);
  405.                 }
  406.                 else
  407.                 {
  408.                         IIC_SDA = 0;
  409.                         //delaymm(10);
  410.                 }

  411.                 IIC_SCL = 1;
  412.                 delay_ms(5);

  413.                 input = (input<<1);
  414.         }

  415.         IIC_SCL = 0;
  416.         delay_us(4);

  417.         SDA_IN();
  418.         delay_us(4);
  419. }       


  420. uint8_t I2C_ReadByte(void)
  421. {
  422.         uint8_t  resultByte=0;
  423.         uint8_t  i=0, a=0;

  424.         IIC_SCL = 0;
  425.         SDA_IN();
  426.         delay_ms(4);

  427.         for(i=0; i<8; i++)
  428.         {
  429.                 IIC_SCL = 1;
  430.                 delay_ms(3);

  431.                 a=0;
  432.                 if(READ_SDA)
  433.                 {
  434.                         a=1;
  435.                 }
  436.                 else
  437.                 {
  438.                         a=0;
  439.                 }

  440.                 //resultByte = resultByte | a;
  441.                 resultByte = (resultByte << 1) | a;

  442.                 IIC_SCL = 0;
  443.                 delay_ms(3);
  444.         }

  445.         SDA_IN();
  446.         delay_ms(10);

  447.         return   resultByte;
  448. }


  449. void  set_AHT20sendOutData(void)
  450. {
  451.         /* --------------------------
  452.          * 0xFA 0x06 0x0A temperature(2 Bytes) humility(2Bytes) short Address(2 Bytes)
  453.          * And Check (1 byte)
  454.          * -------------------------*/
  455.         AHT20sendOutData[3] = AHT20_OutData[0];
  456.         AHT20sendOutData[4] = AHT20_OutData[1];
  457.         AHT20sendOutData[5] = AHT20_OutData[2];
  458.         AHT20sendOutData[6] = AHT20_OutData[3];

  459. //        AHT20sendOutData[7] = (drf1609.shortAddress >> 8) & 0x00FF;
  460. //        AHT20sendOutData[8] = drf1609.shortAddress  & 0x00FF;

  461. //        AHT20sendOutData[9] = getXY(AHT20sendOutData,10);
  462. }


  463. void  I2C_Start(void)
  464. {
  465.         SDA_OUT();
  466.         IIC_SCL = 1;
  467.         delay_ms(4);

  468.         IIC_SDA = 1;
  469.         delay_ms(4);
  470.         IIC_SDA = 0;
  471.         delay_ms(4);

  472.         IIC_SCL = 0;
  473.         delay_ms(4);
  474. }



  475. void  I2C_Stop(void)
  476. {
  477.         SDA_OUT();
  478.         IIC_SDA = 0;
  479.         delay_ms(4);

  480.         IIC_SCL = 1;
  481.         delay_ms(4);

  482.         IIC_SDA = 1;
  483.         delay_ms(4);
  484. }

 楼主| 在水一方00 发表于 2023-1-28 12:36 | 显示全部楼层
烧录并展示结果
3353463d4a64b6a6d5.png
 楼主| 在水一方00 发表于 2023-1-28 12:36 | 显示全部楼层
自行修改程序实现长字符显示
显示要求:

上下或左右的滑动显示长字符,比如“Hello,欢迎来到重庆交通大学物联网205实训室!”或者一段歌词或诗词(最好使用硬件刷屏模式)
根据之前实验中显示学号和姓名的流程来做即可
wangxiangtan2 发表于 2023-1-28 14:37 | 显示全部楼层
学习了,
 楼主| 在水一方00 发表于 2023-1-28 15:17 | 显示全部楼层
在主函数修改:
  1. int main(void)
  2. {       
  3.         delay_init();                           //延时函数初始化          
  4.         NVIC_Configuration();            //设置NVIC中断分组2:2位抢占优先级,2位响应优先级        
  5.         OLED_Init();                                 //初始化OLED  
  6.         OLED_Clear(0);             //清屏(全黑)
  7.         OLED_WR_Byte(0x2E,OLED_CMD);        //关闭滚动
  8.   OLED_WR_Byte(0x27,OLED_CMD);        //水平向左或者右滚动 26/27
  9.   OLED_WR_Byte(0x00,OLED_CMD);        //虚拟字节
  10.         OLED_WR_Byte(0x00,OLED_CMD);        //起始页 0
  11.         OLED_WR_Byte(0x07,OLED_CMD);        //滚动时间间隔
  12.         OLED_WR_Byte(0x07,OLED_CMD);        //终止页 7
  13.         OLED_WR_Byte(0x00,OLED_CMD);        //虚拟字节
  14.         OLED_WR_Byte(0xFF,OLED_CMD);        //虚拟字节
  15.         TEST_MainPage();
  16.         OLED_WR_Byte(0x2F,OLED_CMD);        //开启滚动
  17.         while(1)
  18.         {       
  19.                 //TEST_MainPage();         //主界面显示测试
  20.                

  21.                 //TEST_MainPage();
  22.                 /*OLED_Clear(0);
  23.                 Test_Color();            //刷屏测试
  24.                 OLED_Clear(0);
  25.                 Test_Rectangular();      //矩形绘制测试
  26.                 OLED_Clear(0);
  27.                 Test_Circle();           //圆形绘制测试
  28.                 OLED_Clear(0);
  29.                 Test_Triangle();         //三角形绘制测试
  30.                 OLED_Clear(0);  
  31.                
  32.                 TEST_English();          //英文显示测试
  33.                 OLED_Clear(0);
  34.                 TEST_Number_Character(); //数字和符号显示测试
  35.                 OLED_Clear(0);
  36.                
  37.                 TEST_Chinese();          //中文显示测试
  38.                 OLED_Clear(0);
  39.                 TEST_BMP();              //BMP单色图片显示测试
  40.                 OLED_Clear(0);
  41.                 TEST_Menu1();            //菜单1显示测试
  42.                 OLED_Clear(0);
  43.                 TEST_Menu2();            //菜单2显示测试
  44.                 OLED_Clear(0); */
  45.         }
  46. }
 楼主| 在水一方00 发表于 2023-1-28 15:21 | 显示全部楼层
总结
通过对厂商代码的修改,完成温度,汉字等的输出,对OLED屏显的输出原理和代码有了更深的理解
您需要登录后才可以回帖 登录 | 注册

本版积分规则

51

主题

581

帖子

0

粉丝
快速回复 在线客服 返回列表 返回顶部

51

主题

581

帖子

0

粉丝
快速回复 在线客服 返回列表 返回顶部