嵌入式 单片机 OLED 字模 反取模 python实现

文章介绍如何使用Python解码u8g2库中的十六进制数据,将其转换为可显示的图像,适用于嵌入式开发中的图形显示。

前言

最近在看别的大佬使用u8g2图形库的代码,看到这一串十六进制数据

PROGMEM const uint8_t main_icon_pic[]{
     0xFF, 0xFF, 0xFF, 0x3F, 0xFF, 0xFF, 0xFF, 0x3F, 0xFF, 0xFF, 0xFF, 0x3F, 0xFF, 0xFF, 0xF1, 0x3F,
     0xFF, 0xFF, 0xC3, 0x3F, 0xFF, 0xFF, 0x87, 0x3F, 0xFF, 0xFF, 0x07, 0x3F, 0xFF, 0xFF, 0x0F, 0x3E,
     0xFF, 0xFF, 0x0F, 0x3E, 0xFF, 0xFF, 0x0F, 0x3C, 0xFF, 0xFF, 0x0F, 0x3C, 0xFF, 0xFF, 0x0F, 0x38,
     0xFF, 0xFF, 0x0F, 0x38, 0xFF, 0xFF, 0x0F, 0x38, 0xFF, 0xFF, 0x07, 0x38, 0xFF, 0xFF, 0x07, 0x38,
     0xFF, 0xFF, 0x03, 0x38, 0xF7, 0xFF, 0x01, 0x38, 0xE7, 0xFF, 0x00, 0x3C, 0x87, 0x3F, 0x00, 0x3C,
     0x0F, 0x00, 0x00, 0x3E, 0x0F, 0x00, 0x00, 0x3E, 0x1F, 0x00, 0x00, 0x3F, 0x3F, 0x00, 0x80, 0x3F,
     0x7F, 0x00, 0xC0, 0x3F, 0xFF, 0x01, 0xF0, 0x3F, 0xFF, 0x07, 0xFC, 0x3F, 0xFF, 0xFF, 0xFF, 0x3F,
     0xFF, 0xFF, 0xFF, 0x3F, 0xFF, 0xFF, 0xFF, 0x3F}

懵了,这是什么图像。搜下反取模软件,好像没有,PCtoLCD2002只有取模的功能,没有反推图像的功能。好吧,自己写个python程序吧。

正文

PCtoLCD2002设置如图
在这里插入图片描述
生成的十六进制数据放入到pyhton文件的data列表里,调好图像的宽高
在这里插入图片描述
注意要填好宽高
运行python程序后就能看到图像
在这里插入图片描述

代码

Python3及pip、numpy、Matplotlib等模块的安装

import numpy as np
import matplotlib.pyplot as plt

# 输入图像宽高
width = 30      # 宽
height = 30     # 高
# 输入数据
data = [
    0x20,0x02,0x00,0x20,0x06,0x00,0x20,0x02,0x00,0x10,0x02,0x00,0x10,0xFF,0x00,0x18,
    0x81,0x00,0x98,0x58,0x00,0x54,0x08,0x00,0x12,0x09,0x00,0x10,0x49,0x00,0x10,0x49,
    0x00,0x90,0x88,0x00,0x90,0x08,0x01,0x50,0x08,0x01,0x30,0x08,0x00,0x10,0x0E,0x00,
    0x10,0x04,0x00,0x00,0x00,0x00]


num_row = height                # 行数
num_col = int(width / 8) +1     # 列数
pixels = np.zeros((height, width), dtype=np.uint8)  # 空np矩阵,使用uint8类型以保证数值范围在0-255

# 转换为二进制格式的字符串列表并反转每个字符串
binary_strings = ['{:08b}'.format(val)[::-1] for val in data]
  
# 将二进制字符串拼接成指定数量的一行
rows = [''.join(binary_strings[i:i+num_col])
        for i in range(0, len(binary_strings), num_col)]

y = 0
for row in rows:
    for i in range(width):
    	# 要反色、取反显示,就把下面这行代码的0和255互换一下
        pixels[y, i] = 255 if row[i] == '1' else 0
    y = y+1

# 显示图像
plt.imshow(pixels, cmap='gray', origin='upper',
           vmin=0, vmax=255)  # 显示范围设置为0-255
plt.axis('off')
plt.show()

实践

看到如下代码,如何反取模

PROGMEM const uint8_t icon_pic[]{0xFF, 0xFF, 0xFF, 0x3F, 0xFF, 0xFF, 0xFF, 0x3F, 0xFF, 0xFF, 0xFF, 0x3F, 0xFF, 0xFF, 0xFF, 0x3F,
     0xFF, 0x1F, 0xFE, 0x3F, 0xFF, 0x1F, 0xFE, 0x3F, 0xFF, 0x0C, 0xCC, 0x3F, 0x7F, 0x00, 0x80, 0x3F,
     0x3F, 0x00, 0x00, 0x3F, 0x3F, 0xE0, 0x01, 0x3F, 0x7F, 0xF8, 0x87, 0x3F, 0x7F, 0xFC, 0x8F, 0x3F,
     0x3F, 0xFC, 0x0F, 0x3F, 0x0F, 0x3E, 0x1F, 0x3C, 0x0F, 0x1E, 0x1E, 0x3C, 0x0F, 0x1E, 0x1E, 0x3C,
     0x0F, 0x3E, 0x1F, 0x3C, 0x3F, 0xFC, 0x0F, 0x3F, 0x7F, 0xFC, 0x8F, 0x3F, 0x7F, 0xF8, 0x87, 0x3F,
     0x3F, 0xE0, 0x01, 0x3F, 0x3F, 0x00, 0x00, 0x3F, 0x7F, 0x00, 0x80, 0x3F, 0xFF, 0x0C, 0xCC, 0x3F,
     0xFF, 0x1F, 0xFE, 0x3F, 0xFF, 0x1F, 0xFE, 0x3F, 0xFF, 0xFF, 0xFF, 0x3F, 0xFF, 0xFF, 0xFF, 0x3F,
     0xFF, 0xFF, 0xFF, 0x3F, 0xFF, 0xFF, 0xFF, 0x3F}
/* 使用u8g2库绘制位图 
	u8g2.drawXBMP(x, y, w, h, bitmap);
	x,y 是图像左上角的坐标
	w,h 是图像的宽和高
	bitmap是位图数组*/   
u8g2.drawXBMP(10, 12, 30, 30, icon_pic);

这个u8g2.drawXBMP(10, 12, 30, 30, icon_pic)函数的意思是,在坐标为(10, 12)的位置,绘制宽高30*30的图像,内容为icon_pic
那怎么在python中把这串十六进制数据绘制成图像呢?
上面的代码,把width 填入30,高height 也填入30,十六进制数据填入data,运行

# 输入图像宽高
width = 30      # 宽
height = 30     # 高
# 输入数据
data = [
     0xFF, 0xFF, 0xFF, 0x3F, 0xFF, 0xFF, 0xFF, 0x3F, 0xFF, 0xFF, 0xFF, 0x3F, 0xFF, 0xFF, 0xFF, 0x3F,
     0xFF, 0x1F, 0xFE, 0x3F, 0xFF, 0x1F, 0xFE, 0x3F, 0xFF, 0x0C, 0xCC, 0x3F, 0x7F, 0x00, 0x80, 0x3F,
     0x3F, 0x00, 0x00, 0x3F, 0x3F, 0xE0, 0x01, 0x3F, 0x7F, 0xF8, 0x87, 0x3F, 0x7F, 0xFC, 0x8F, 0x3F,
     0x3F, 0xFC, 0x0F, 0x3F, 0x0F, 0x3E, 0x1F, 0x3C, 0x0F, 0x1E, 0x1E, 0x3C, 0x0F, 0x1E, 0x1E, 0x3C,
     0x0F, 0x3E, 0x1F, 0x3C, 0x3F, 0xFC, 0x0F, 0x3F, 0x7F, 0xFC, 0x8F, 0x3F, 0x7F, 0xF8, 0x87, 0x3F,
     0x3F, 0xE0, 0x01, 0x3F, 0x3F, 0x00, 0x00, 0x3F, 0x7F, 0x00, 0x80, 0x3F, 0xFF, 0x0C, 0xCC, 0x3F,
     0xFF, 0x1F, 0xFE, 0x3F, 0xFF, 0x1F, 0xFE, 0x3F, 0xFF, 0xFF, 0xFF, 0x3F, 0xFF, 0xFF, 0xFF, 0x3F,
     0xFF, 0xFF, 0xFF, 0x3F, 0xFF, 0xFF, 0xFF, 0x3F]

在这里插入图片描述
是一个齿轮的图标!!

end

几点说明: 1。打开功能是专门用于对C语言文件自动提显示所需要的汉字,进行点阵码数据转换的, 在您的C语言程序中,有一点需要特别留意:您的注解中请不要使用双引号,否则会引起 提错误。 软件包中的文件ee.c作为一个简单例程供提测试用。 2。提以后的点阵码可以随意修改点阵数据,使用鼠标的左键为加一点,右键为擦除一点。 修改完毕请按旁边的确认键将数据记录到点阵码中,否则您的修改将自动放弃。 3。点阵码可以随意平移,请谨慎使用。平移之前请查看一遍所有的字符点阵图,平移有可能 会丢失边界点,移出了边界的点阵将被丢弃,不可恢复。 平移前请确认是否有必要进行全体字符一起移动。 4。用户自定义特殊字符的建立,首先选定点阵数据,在下面的汉字输入窗口输入几个您不使 用的汉字,确认。然后生成了这些汉字的点阵码,再将他们清空(使用平移按钮中间的那 块抹布),就可以用鼠标描绘你的图案了,最后别忘了打“确认”键。 5。ASCII字符可以自动提0x20~0x7f的全部,最后一个0x7f一般都没有用,可以手工将它删 除,也可以利用它做一个简单的特殊字符。 汉字库中也包含有ascii字符,但是经查对与这三个ascii库基本一样,所以就不再重复。 6。保存文件:C语言格式的默认为.h类型,汇编格式的默认为.inc类型,只要将他们加入到 您的工程中就可以了。 7。新增加了自动添加下划线功能。这项功能在做点阵显示和修改的时候并不出现下划线, 设置了以后仅仅在最后的输出文件中出现,以免干扰编辑修改。 8。扩充对windows汉字的直接提,从16~96范围内可以任意设定选。主要用于制作界面的 开机封面少量标识性汉字。 9。扩充了对ascii小字库5x8以及大字库20*40/24*48的支持,毕竟字库文件比较工整。 10。增加了字模输出格式的选择,可以将汉字码与点阵数据分开列表; 11。增加了对单色.bmp文件的支持,可以从原有的bitmap文件上截一部分作为点阵码数据 输出,点阵图案可以随意修改。 12。bitmap用户自建方案,可以先设定好图形的宽度和高度,然后用打开图形文件窗口下选 择消,自动生成一块空白的图板。 13。图形区域显示的图形点阵可以用调节拉条进行放大或缩小。 14。图形编辑的鼠标可以单点加点也可以慢速拖线,擦除也可以,只是左右健的区别。 15。字模部分当采用非结构型格式输出的时候添加了对应汉字标识,便于对照查看。 16。bitmap文件的读入前可以设定是否白读。 17。增加了图形编辑板直接保存便于为制作说明书等提供贴图。 18。修正了华文中宋汉字模生成过程中的切(底)边现象 配合lcmsim排版仿真软件一起使用,可以大大提高单片机编程的工作效率。 -----------------2005.10.25更新内容 19。扩充了一次可转换汉字量,最大可以达到对整个汉字库的转换。附加了整个汉字库 的码表,使用者可以从中选需要的部分而把多余部分删除掉。整个字库的转换需 要大约15分钟或更长时间,并不是死机。 20。一次可以循序打开多个c文件从中自动提汉字码。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值