4.2 KiB
4.2 KiB
图片转换工具使用指南
这个工具可以将多种格式的图片转换为适用于ESP32墨水屏显示的二进制点阵数据。
功能特点
- 支持多种图片格式:JPG、PNG、BMP、GIF、TIFF等
- 自动调整图片大小并居中显示
- 支持黑色背景白色文本或白色背景黑色文本
- 支持旋转90度显示
- 支持Floyd-Steinberg抖动算法提高图像质量
- 支持创建文本图像
- 支持批量转换
安装依赖
pip install Pillow
使用方法
1. 转换单个图片
python3 image_converter.py image <输入图片路径> <输出文件路径> [选项]
cd "/Users/jeremygan/Desktop/
TangledupAI/esp32_GDEY042T81-24Pin-_dirver-" && python3 tool/image_con
verter.py image tool/test_iamge_white_bg2.png images/test_image2.py --
width 400 --height 300
选项参数:
--width: 目标宽度(默认400)--height: 目标高度(默认300)--invert: 反转颜色(白色背景黑色文本)--rotate: 旋转90度--no-dither: 不使用抖动算法
示例:
# 转换为黑色背景白色文本(默认)
python3 image_converter.py image photo.jpg photo_dark.py
# 转换为白色背景黑色文本
python3 image_converter.py image photo.jpg photo_light.py --invert
# 转换并旋转90度
python3 image_converter.py image photo.jpg photo_rotated.py --rotate
# 转换为128x296尺寸并旋转
python3 image_converter.py image photo.jpg photo_small.py --width 128 --height 296 --rotate
2. 创建文本图像
python3 image_converter.py text "<文本内容>" <输出文件路径> [选项]
选项参数:
--width: 目标宽度(默认400)--height: 目标高度(默认300)--font-size: 字体大小(默认24)--invert: 反转颜色(白色背景黑色文本)--rotate: 旋转90度
示例:
# 创建文本图像
python3 image_converter.py text "Hello ESP32!" hello.py
# 创建大字体文本图像
python3 image_converter.py text "Hello ESP32!" hello_big.py --font-size 32
# 创建旋转文本图像
python3 image_converter.py text "Rotated Text" rotated.py --rotate
3. 批量转换
python3 image_converter.py batch <输入目录> <输出目录> [选项]
示例:
# 批量转换目录中的所有图片
python3 image_converter.py batch images/ converted/
# 批量转换为白色背景黑色文本
python3 image_converter.py batch images/ converted/ --invert
输出格式
转换后的文件包含一个bytearray变量,变量名与文件名相同:
# Converted from photo.jpg
# Size: 400x300
# Inverted: False, Rotated: False
photo = bytearray(b'\x00\x00\x00\x0...')
在ESP32项目中使用
- 将转换后的.py文件复制到ESP32项目目录
- 在boot.py中设置
RUN_MODE=3 - 修改image.py导入转换后的图片数据:
# 在image.py中导入转换后的图片
from photo import photo
def run(img_data=None):
if img_data is None:
# 使用默认图片
img_data = photo
# ... 其余代码保持不变
- 上传代码到ESP32并运行
示例
运行示例脚本:
python3 convert_examples.py
这将创建示例图片目录并展示各种转换用法。
注意事项
- 图片会自动调整大小并居中显示,保持原始宽高比
- 使用抖动算法可以提高图像质量,但会增加文件大小
- 旋转90度后,宽度和高度会互换
- 确保输出目录有写入权限
- 转换大图片可能需要一些时间
故障排除
-
ImportError: No module named 'PIL'
- 解决方案:运行
pip install Pillow
- 解决方案:运行
-
无法识别的图片格式
- 解决方案:确保图片格式受支持(JPG、PNG、BMP、GIF、TIFF)
-
转换后的图片显示不正确
- 解决方案:尝试使用
--invert参数反转颜色 - 尝试使用
--rotate参数旋转图片
- 解决方案:尝试使用
-
内存不足
- 解决方案:减小目标尺寸或使用更小的源图片
技术细节
- 图片使用Floyd-Steinberg抖动算法转换为1位黑白图像
- 每个字节表示8个像素,最高位在前
- 像素值0表示黑色,1表示白色
- 字节数组按行组织,每行需要的字节数为(宽度+7)//8