二进制图片

This commit is contained in:
jeremygan2021
2025-11-26 17:29:16 +08:00
parent 5c36736141
commit 22aa782648
42 changed files with 2144 additions and 2 deletions

View File

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