[]【HarmonyOS HiSpark Wi-Fi IoT 套件试用连载】第四弹,OLED折腾日记

阅读量0
1
1
`上午给大家介绍了OLED是怎样点亮的:试用第三弹,点亮你的OLED
但是博主并比就此满足,感觉没有输出到有用的东西给到大家
这里用一个简单的demo教大家玩转你的OLED屏幕




先上最终效果图:

要实现这个效果首先要确定两个事情:要输入的文字和准备图片
准备要输入的文字:
用汉字取模程序,在这里贴上地址,大家自行下载:http://www.pc0359.cn/downinfo/110811.html
然后就是用取模软件把想取模的数组复制下来,如下:
无标题.png

把数组复制过来,形成一个数组
  1. #define font_size 16
  2. #define font_height 16
  3. #define font_width 16

  4. unsigned char hope_arr[][32] = {
  5.         //当前汉字是:祝
  6.         {0x00, 0x00, 0x00, 0x00, 0x0C, 0x00, 0x06, 0x18, 0x01, 0xFC, 0x0D, 0x98, 0x7C, 0xB0, 0x2C, 0xF0,
  7.          0x1E, 0xF0, 0x1E, 0xE0, 0x3D, 0xA1, 0x6D, 0x23, 0x0E, 0x3F, 0x08, 0x1E, 0x08, 0x00, 0x00, 0x00},

  8.         //鸿
  9.         {0x00, 0x00, 0x00, 0x30, 0x00, 0x30, 0x18, 0x78, 0x08, 0xFC, 0x0F, 0xE8, 0x76, 0xF8, 0x32, 0xF8,
  10.          0x0B, 0xD8, 0x1E, 0xFE, 0x30, 0xC6, 0x71, 0xFE, 0x23, 0x86, 0x00, 0x0E, 0x00, 0x0C, 0x00, 0x00},
  11.         //蒙
  12.         {0x00, 0x00, 0x00, 0x60, 0x06, 0x78, 0x1F, 0xF8, 0x02, 0x78, 0x1F, 0xFE, 0x17, 0xDC, 0x33, 0xE0,
  13.          0x0F, 0xE0, 0x0E, 0xE0, 0x1F, 0x80, 0x0F, 0xF0, 0x37, 0xBF, 0x1D, 0x88, 0x33, 0x80, 0x01, 0x00},
  14.         //社
  15.         {0x00, 0x00, 0x00, 0x00, 0x06, 0x30, 0x02, 0x30, 0x00, 0x30, 0x06, 0x30, 0x7E, 0x30, 0x2C, 0x7C,
  16.          0x0E, 0xF0, 0x1F, 0x30, 0x3C, 0x30, 0x2C, 0x3F, 0x0F, 0xFE, 0x0C, 0x00, 0x0C, 0x00, 0x00, 0x00},
  17.         //区
  18.         {0x00, 0x00, 0x00, 0x00, 0x00, 0xF8, 0x1F, 0xF0, 0x18, 0x70, 0x18, 0x60, 0x1B, 0xE0, 0x19, 0xE0,
  19.          0x18, 0xE0, 0x19, 0xF0, 0x1B, 0x30, 0x1E, 0x10, 0x1B, 0xFE, 0x1F, 0xFC, 0x00, 0x00, 0x00, 0x00},
  20.         //越
  21.         {0x00, 0x00, 0x00, 0x20, 0x06, 0x30, 0x06, 0x3C, 0x07, 0x36, 0x0F, 0x18, 0x07, 0xFC, 0x7E, 0x56,
  22.          0x77, 0x5C, 0x1F, 0x78, 0x3E, 0xFE, 0x26, 0x27, 0x63, 0xC2, 0x00, 0xFC, 0x00, 0x3F, 0x00, 0x00},
  23.         //办
  24.         {0x00, 0x00, 0x01, 0x80, 0x01, 0x80, 0x01, 0x80, 0x01, 0xF0, 0x0F, 0xF0, 0x05, 0xB0, 0x09, 0x30,
  25.          0x1B, 0x3E, 0x33, 0x36, 0x36, 0x32, 0x06, 0x20, 0x0D, 0xE0, 0x18, 0xE0, 0x00, 0xC0, 0x00, 0x00},
  26.         //越
  27.         {0x00, 0x00, 0x00, 0x20, 0x06, 0x30, 0x06, 0x3C, 0x07, 0x36, 0x0F, 0x18, 0x07, 0xFC, 0x7E, 0x56,
  28.          0x77, 0x5C, 0x1F, 0x78, 0x3E, 0xFE, 0x26, 0x27, 0x63, 0xC2, 0x00, 0xFC, 0x00, 0x3F, 0x00, 0x00},
  29.         //好
  30.         {0x00, 0x00, 0x00, 0x00, 0x0C, 0x08, 0x0C, 0xFC, 0x0C, 0x5C, 0x0F, 0x30, 0x0F, 0x32, 0x7B, 0xFF,
  31.          0x1B, 0xF0, 0x0E, 0x18, 0x0E, 0x18, 0x0F, 0x18, 0x3B, 0x30, 0x20, 0x70, 0x00, 0x30, 0x00, 0x00},
  32.         //,
  33.         {0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  34.          0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x38, 0x00, 0x38, 0x00, 0x18, 0x00, 0x30, 0x00},
  35.         //蒸
  36.         {0x00, 0x00, 0x04, 0x60, 0x06, 0x78, 0x3F, 0xFC, 0x12, 0xC0, 0x07, 0xF0, 0x02, 0xD8, 0x1F, 0xB0,
  37.          0x0D, 0xE0, 0x09, 0xB8, 0x1B, 0x9E, 0x2F, 0xE6, 0x04, 0xD8, 0x36, 0xCC, 0x32, 0x04, 0x00, 0x00},
  38.         //蒸
  39.         {0x00, 0x00, 0x04, 0x60, 0x06, 0x78, 0x3F, 0xFC, 0x12, 0xC0, 0x07, 0xF0, 0x02, 0xD8, 0x1F, 0xB0,
  40.          0x0D, 0xE0, 0x09, 0xB8, 0x1B, 0x9E, 0x2F, 0xE6, 0x04, 0xD8, 0x36, 0xCC, 0x32, 0x04, 0x00, 0x00},
  41.         //日
  42.         {0x00, 0x00, 0x00, 0x00, 0x00, 0x20, 0x0F, 0xF0, 0x0E, 0x30, 0x04, 0x30, 0x04, 0x30, 0x07, 0xF0,
  43.          0x07, 0x30, 0x04, 0x30, 0x04, 0x30, 0x0F, 0xF0, 0x0E, 0x30, 0x00, 0x30, 0x00, 0x00, 0x00, 0x00},
  44.         //上
  45.         {0x00, 0x00, 0x00, 0x00, 0x01, 0x80, 0x01, 0x80, 0x01, 0x80, 0x01, 0x80, 0x01, 0xF8, 0x01, 0xE0,
  46.          0x01, 0x80, 0x01, 0x80, 0x01, 0x80, 0x01, 0x84, 0x3F, 0xFF, 0x7F, 0x00, 0x00, 0x00, 0x00, 0x00},
  47.         //.
  48.         {0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  49.          0x00, 0x00, 0x00, 0x00, 0x1C, 0x00, 0x3C, 0x00, 0x36, 0x00, 0x3C, 0x00, 0x08, 0x00, 0x00, 0x00},
  50.         //芝
  51.         {0x00, 0x00, 0x00, 0x60, 0x06, 0x60, 0x07, 0xFC, 0x3F, 0xC0, 0x02, 0x40, 0x03, 0x80, 0x01, 0xF0,
  52.          0x0F, 0x60, 0x00, 0xC0, 0x03, 0x00, 0x0E, 0x00, 0x3F, 0x00, 0x01, 0xFF, 0x00, 0x3C, 0x00, 0x00},
  53.         //麻
  54.         {0x00, 0x00, 0x00, 0x00, 0x01, 0x80, 0x00, 0xF0, 0x1F, 0xF0, 0x1A, 0x60, 0x1A, 0x38, 0x1B, 0xF8,
  55.          0x1F, 0x60, 0x17, 0x78, 0x37, 0xEC, 0x3B, 0xAF, 0x62, 0x20, 0x42, 0x60, 0x02, 0x20, 0x00, 0x00},
  56.         //开
  57.         {0x00, 0x00, 0x00, 0x00, 0x00, 0x38, 0x0F, 0xF8, 0x0F, 0x60, 0x02, 0x60, 0x02, 0x7E, 0x7F, 0xFE,
  58.          0x32, 0x60, 0x06, 0x60, 0x06, 0x60, 0x04, 0x60, 0x0C, 0x60, 0x18, 0x60, 0x00, 0x60, 0x00, 0x00},
  59.         //花
  60.         {0x00, 0x00, 0x00, 0x60, 0x06, 0x60, 0x03, 0xFC, 0x3F, 0xE0, 0x02, 0x40, 0x06, 0xD8, 0x06, 0xD8,
  61.          0x0C, 0xF0, 0x0C, 0xE0, 0x1D, 0x80, 0x3E, 0x82, 0x4C, 0xC2, 0x0C, 0xFF, 0x0C, 0x7E, 0x00, 0x0},
  62.         //-
  63.         {0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xFF, 0x00,
  64.          0xFF, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},
  65.         //-
  66.         {0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xFF, 0x00,
  67.          0xFF, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},
  68.         //节
  69.         {0x00, 0x00, 0x00, 0x30, 0x06, 0x24, 0x0F, 0xFE, 0x3E, 0x60, 0x02, 0x10, 0x03, 0xF8, 0x1F, 0x98,
  70.          0x01, 0x98, 0x01, 0x98, 0x01, 0x98, 0x01, 0xF8, 0x01, 0xB0, 0x01, 0x80, 0x01, 0x00, 0x01, 0x00},
  71.         //节
  72.         {0x00, 0x00, 0x00, 0x30, 0x06, 0x24, 0x0F, 0xFE, 0x3E, 0x60, 0x02, 0x10, 0x03, 0xF8, 0x1F, 0x98,
  73.          0x01, 0x98, 0x01, 0x98, 0x01, 0x98, 0x01, 0xF8, 0x01, 0xB0, 0x01, 0x80, 0x01, 0x00, 0x01, 0x00},
  74.         //高
  75.         {0x00, 0x00, 0x01, 0x80, 0x00, 0xB8, 0x1F, 0xFC, 0x08, 0xE0, 0x07, 0xE0, 0x07, 0xC0, 0x03, 0x98,
  76.          0x3F, 0xFE, 0x38, 0xCC, 0x17, 0xEC, 0x17, 0xCC, 0x37, 0x8C, 0x30, 0x3C, 0x10, 0x1C, 0x00, 0x18},
  77.         //.
  78.         {0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  79.          0x00, 0x00, 0x00, 0x00, 0x1C, 0x00, 0x3C, 0x00, 0x36, 0x00, 0x3C, 0x00, 0x08, 0x00, 0x00, 0x00},
  80. };
复制代码

,到这里文字就做好了
准备要显示的图片:
先找一个图片(我这里用的微信的头像,主要是四四方方的感觉看着很爽)
然后把图片最好存成OLED屏幕分辨率以下的尺寸(win10自带的画图就能做到,具体方法不述)
,再到这个网址去转换:http://tools.clz.me/image-to-bitmap-array
把转换完的图片数组拷贝过来,如下图:
无标题22.png

,最后形成一个数组,如下:
  1. // width: 64, height: 64
  2. const unsigned char picture_arr[] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x30, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x30, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x30, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x30, 0xff, 0xff, 0xff, 0x80, 0x7f, 0xfc, 0x00, 0x30, 0xff, 0xff, 0xfe, 0x00, 0x1f, 0xfc, 0x00, 0x30, 0xff, 0xff, 0xfc, 0x00, 0x07, 0xff, 0x00, 0x30, 0xff, 0xff, 0xf8, 0x00, 0x07, 0xff, 0x00, 0x10, 0xff, 0xff, 0xf0, 0x00, 0x03, 0xff, 0x00, 0x30, 0xff, 0xff, 0xe0, 0x00, 0x01, 0xfd, 0x00, 0x30, 0xff, 0xff, 0xe0, 0x00, 0x01, 0xf8, 0x0c, 0x10, 0xff, 0xff, 0xc0, 0x00, 0x01, 0xf8, 0x01, 0xd0, 0xff, 0xff, 0xc0, 0x07, 0x00, 0xf8, 0x01, 0xc1, 0xff, 0xff, 0xc7, 0xff, 0x80, 0xf8, 0x01, 0x91, 0xff, 0xff, 0xcf, 0xff, 0x80, 0xf8, 0x03, 0xb9, 0xff, 0xff, 0xef, 0xff, 0xe0, 0xf8, 0x1f, 0x3b, 0xff, 0xff, 0xff, 0xfc, 0xf9, 0xf8, 0x00, 0x31, 0xff, 0xff, 0xff, 0xe0, 0xf9, 0x00, 0x08, 0x3a, 0xff, 0xff, 0xfc, 0x60, 0x7e, 0x00, 0x0c, 0x3b, 0xff, 0xff, 0xfc, 0x00, 0x7c, 0xc0, 0x0c, 0x79, 0xff, 0xff, 0xfc, 0x31, 0xff, 0xc1, 0x0e, 0xf8, 0xff, 0xff, 0xfc, 0x7f, 0xff, 0xf8, 0x0e, 0xfc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0xfc, 0xe2, 0xff, 0xff, 0xff, 0xff, 0xff, 0xec, 0xbe, 0xf0, 0xff, 0xff, 0xff, 0xfd, 0xff, 0xe7, 0xee, 0x62, 0xff, 0xff, 0xff, 0x22, 0x3f, 0xff, 0xce, 0xf8, 0xff, 0xff, 0xff, 0xfe, 0x7e, 0xff, 0x0e, 0x98, 0xff, 0xff, 0xff, 0xf8, 0xfc, 0xff, 0x2d, 0x80, 0xff, 0xff, 0xff, 0x83, 0xfc, 0xff, 0xfd, 0xc0, 0xff, 0xff, 0xff, 0xe3, 0xb0, 0x1f, 0xf8, 0x80, 0xff, 0xff, 0xff, 0xff, 0x80, 0x3f, 0x00, 0x9f, 0xff, 0xff, 0xff, 0xff, 0x00, 0x5e, 0x00, 0x9f, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x3a, 0x03, 0x81, 0xff, 0xff, 0xfb, 0xf0, 0x00, 0x1c, 0x01, 0x00, 0xff, 0xff, 0xf3, 0xf0, 0x00, 0x0c, 0x00, 0x07, 0xff, 0xff, 0xc7, 0xf8, 0x00, 0x5c, 0x00, 0x07, 0xff, 0xff, 0x87, 0xd8, 0x00, 0xfc, 0x00, 0x04, 0xff, 0xff, 0x87, 0xd0, 0x02, 0xfc, 0x00, 0x1c, 0xff, 0xff, 0x86, 0xc0, 0x03, 0xf8, 0x00, 0x18, 0xff, 0xff, 0x87, 0xc0, 0x03, 0xf8, 0x00, 0x38, 0xff, 0xff, 0x87, 0xc0, 0x03, 0xf0, 0x00, 0x18, 0xff, 0xff, 0x87, 0xc0, 0x07, 0xf0, 0x00, 0x00, 0xff, 0xff, 0x07, 0xc0, 0x07, 0xf0, 0x00, 0x00, 0xff, 0xff, 0x07, 0xc0, 0x07, 0xd0, 0x00, 0x00, 0xff, 0xff, 0x07, 0xc0, 0x07, 0xc0, 0x00, 0x00, 0xff, 0xff, 0x07, 0x80, 0x07, 0xc0, 0x00, 0x00, 0xff, 0xff, 0x03, 0x80, 0x07, 0xc0, 0x00, 0x0c, 0xff, 0xff, 0x03, 0x80, 0x05, 0xc0, 0x00, 0x00, 0xff, 0xff, 0x01, 0x80, 0x06, 0x00, 0x00, 0x10, 0xff, 0xff, 0x00, 0x80, 0x04, 0x00, 0x00, 0x10, 0xff, 0xff, 0x00, 0xc0, 0x07, 0x80, 0x00, 0x10, 0xff, 0xff, 0x00, 0x40, 0x00, 0x00, 0x00, 0x10, 0xff, 0xff, 0x00, 0x40, 0x00, 0x00, 0x00, 0x10, 0xff, 0xfc, 0x00, 0x40, 0x00, 0x00, 0x00, 0x08, 0xff, 0xfc, 0x00, 0x60, 0x00, 0x00, 0x00, 0x08, 0xff, 0xfc, 0x00, 0xf0, 0x00, 0x00, 0x00, 0x08, 0xff, 0xfc, 0x00, 0x7c, 0x00, 0x00, 0x00, 0x0f, 0xff, 0xfc, 0x00, 0x7c, 0x00, 0x00, 0x00, 0x04, 0xff, 0xf8, 0x00, 0xff, 0x00, 0x00, 0x00, 0x04, 0xff, 0xf8, 0x00, 0xff, 0x80, 0x00, 0x00, 0x02, 0xff, 0xf0, 0x01, 0xff, 0x80, 0x00, 0x00, 0x02, 0xff, 0xf0, 0x03, 0xff, 0x80, 0x00, 0x00, 0x02, 0xff, 0xf0, 0x03, 0xff, 0xf8, 0x00, 0x00, 0x00, 0xff, 0xec, 0x03, 0xff, 0xf0, 0x00, 0x00, 0x00};
复制代码
到这里准备工作就完成了.

在代码里把文字区域填充文字和图片(利用官方的驱动):
  1. ssd1306_Fill(Black);
  2.                 ssd1306_SetCursor(0, 0);

  3.                 int x = 0;
  4.                 int y = 0;
  5.                 printf("hope_num =%d
  6. ", hope_num);
  7.                 // int start_num = text_alredy_show * text_per_line_num;
  8.                 int showed_num = 0;
  9.                 for (int i = text_alredy_show; i < hope_num; i++)
  10.                 {

  11.                         ssd1306_DrawRegion(x, y, font_height, font_width, hope_arr[i], sizeof(hope_arr[0]), 0);

  12.                         x += font_width;
  13.                         if (x >= text_area_width)
  14.                         {
  15.                                 y += font_height;
  16.                                 x = 0;
  17.                         }
  18.                         showed_num++;
  19.                         if (y >= text_area_height)
  20.                         {

  21.                                 break;
  22.                         }
  23.                 }

  24.                 ssd1306_DrawRegion(64, 0, 64, 64, picture_arr, sizeof(picture_arr), 0);
  25.                 ssd1306_UpdateScreen();
复制代码
然后把程序下载进去就可以看到效果了

当然如果想玩的更爽一点那就是动态文字了:进阶版视频如下:
`
微信图片_20201114181720.jpg

回帖

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容图片侵权或者其他问题,请联系本站作侵删。 侵权投诉
链接复制成功,分享给好友