Iibchara-dev(讨论 | 贡献) 无编辑摘要 |
Iibchara-dev(讨论 | 贡献) 小 (→2. 打包) |
||
(未显示同一用户的2个中间版本) | |||
第1行: | 第1行: | ||
== 提醒事项 == | == 提醒事项 == | ||
注意:本教程以在 Windows 10 | 注意:本教程以在 Windows 10 平台下进行打包操作为例,并确保你拥有可以访问国际网络的能力 | ||
== 格式确认 == | == 格式确认 == | ||
第51行: | 第51行: | ||
* 工具运行库 - [https://github.com/ColdWindScholar/MIO-KITCHEN-SOURCE/blob/main/bin/Windows/AMD64/cygwin1.dll GitHub] | * 工具运行库 - [https://github.com/ColdWindScholar/MIO-KITCHEN-SOURCE/blob/main/bin/Windows/AMD64/cygwin1.dll GitHub] | ||
访问对应链接 并点击 '''下载图标''' 下载文件 | <p style="color: gray;">访问对应链接 并点击 '''下载图标''' 下载文件</p> | ||
fspatch - [https://github.com/affggh/fspatch GitHub] | * fspatch - [https://github.com/affggh/fspatch GitHub] | ||
访问 fspatch 仓库并点击 '''Code - Download zip''' 下载 | <p style="color: gray;">访问 fspatch 仓库并点击 '''Code - Download zip''' 下载</p> | ||
===== 2. 打包 ===== | ===== 2. 打包 ===== | ||
第62行: | 第62行: | ||
# 在'''该目录'''下打开 cmd 命令行 | # 在'''该目录'''下打开 cmd 命令行 | ||
# 输入:<pre>python fspatch.py 分区文件夹名 config\分区名_fs_config</pre> 示例:<pre>python fspatch.py vendor config\vendor_fs_config</pre> | # 输入:<pre>python fspatch.py 分区文件夹名 config\分区名_fs_config</pre> 示例:<pre>python fspatch.py vendor config\vendor_fs_config</pre> | ||
# 记录'''config\分区名_size.txt'''内数值,并除以'''4096'''后的数值 (例如: 11451419 / 4096)。如果有'''小数点'''(如 114514. | # 记录'''config\分区名_size.txt'''内数值,并除以'''4096'''后的数值 (例如: 11451419 / 4096)。如果有'''小数点'''(如 114514.19),请向上取整(如 114515) | ||
# 输入:<pre>mke2fs -O ^has_journal -L 分区名 -I 256 -M /分区名 -m 0 -t ext4 -b 4096 打包文件名 上一步记录的数值</pre>示例:<pre>mke2fs -O ^has_journal -L vendor -I 256 -M /vendor -m 0 -t ext4 -b 4096 vendor_new.img 114515</pre> | # 输入:<pre>mke2fs -O ^has_journal -L 分区名 -I 256 -M /分区名 -m 0 -t ext4 -b 4096 打包文件名 上一步记录的数值</pre>示例:<pre>mke2fs -O ^has_journal -L vendor -I 256 -M /vendor -m 0 -t ext4 -b 4096 vendor_new.img 114515</pre> | ||
# 输入:<pre>e2fsdroid -e -T 1167580800 -S 分区名_fs_config的绝对路径 -C 分区名_fs_config的绝对路径 -a /分区名 -f 分区文件夹名 上一步输入的打包文件名</pre>示例:<pre>e2fsdroid -e -T 1167580800 -S D:\homo\config\vendor_file_contexts -C D:\homo\config\vendor_fs_config -a /vendor -f vendor vendor_new.img</pre> | # 输入:<pre>e2fsdroid -e -T 1167580800 -S 分区名_fs_config的绝对路径 -C 分区名_fs_config的绝对路径 -a /分区名 -f 分区文件夹名 上一步输入的打包文件名</pre>示例:<pre>e2fsdroid -e -T 1167580800 -S D:\homo\config\vendor_file_contexts -C D:\homo\config\vendor_fs_config -a /vendor -f vendor vendor_new.img</pre> |
2024年2月17日 (六) 02:30的最新版本
提醒事项
注意:本教程以在 Windows 10 平台下进行打包操作为例,并确保你拥有可以访问国际网络的能力
格式确认
在正式开始之前,你需要了解你接下来需要打包的是哪种类型的文件。本教程将介绍
img格式打包
特别注意
本章节将分为三个部分,分别是:
- ext4 格式 img 打包
- erofs 格式 img 打包
- boot/recovery类型 img 打包
1. ext4 格式打包
本部分将分为两个部分(两种打包方式),分别是
- 通过 make_ext4fs 打包
- 通过 mke2fs + e2fsdroid 打包
1. 通过 make_ext4fs 打包
1.获得所需工具 - make_ext4fs - GitHub
访问工具链接并点击 下载图标 下载文件
2. 打包
- 将工具放置到所需打包分区所在目录
- 在该目录下打开 cmd 命令行
- 记录 config\分区名_size.txt 内数值
- 输入:
make_ext4fs.exe -J -T 1167580800 -S config\分区名_file_contexts -l 上一步记录的数值 -C config\分区名_fs_config -L 分区名 -a 分区名 打包文件名 分区文件夹名
示例:make_ext4fs.exe -J -T 1167580800 -S config\vendor_file_contexts -l 1145141919 -C config\vendor_fs_config -L vendor -a vendor vendor_new.img vendor
- 小等一会将会打包完成
注意
- 打包要求您的文件需要严格按照解包后的结构(即所需打包文件夹 + config文件夹)存放,避免造成找不到文件的情况。如果您的机器是动态分区,请参考第二种打包方式
- 正确存放示例:
vendor config make_ext4fs.exe
2. 通过 mke2fs + e2fsdroid 打包
1. 获得所需工具 - mke2fs + e2fsdroid
所需环境:Python - 官网
所需工具:
访问对应链接 并点击 下载图标 下载文件
- fspatch - GitHub
访问 fspatch 仓库并点击 Code - Download zip 下载
2. 打包
- 将工具及运行库放置到所需打包分区所在目录
- 在该目录下打开 cmd 命令行
- 输入:
python fspatch.py 分区文件夹名 config\分区名_fs_config
示例:python fspatch.py vendor config\vendor_fs_config
- 记录config\分区名_size.txt内数值,并除以4096后的数值 (例如: 11451419 / 4096)。如果有小数点(如 114514.19),请向上取整(如 114515)
- 输入:
mke2fs -O ^has_journal -L 分区名 -I 256 -M /分区名 -m 0 -t ext4 -b 4096 打包文件名 上一步记录的数值
示例:mke2fs -O ^has_journal -L vendor -I 256 -M /vendor -m 0 -t ext4 -b 4096 vendor_new.img 114515
- 输入:
e2fsdroid -e -T 1167580800 -S 分区名_fs_config的绝对路径 -C 分区名_fs_config的绝对路径 -a /分区名 -f 分区文件夹名 上一步输入的打包文件名
示例:e2fsdroid -e -T 1167580800 -S D:\homo\config\vendor_file_contexts -C D:\homo\config\vendor_fs_config -a /vendor -f vendor vendor_new.img
- 小等一会将会打包完成
注意
- 打包要求您的文件需要严格按照解包后的结构(即所需打包文件夹 + config文件夹)存放,避免造成找不到文件的情况。
- 正确存放示例:
vendor config mke2fs.exe e2fsdroid.exe cygwin1.dll fspatch.py
2. erofs 格式打包
1. 获得所需工具 - mkfs.erofs
所需环境:Python - 官网
所需工具:
- mkfs.erofs - GitHub
访问工具 GitHub 仓库并从 Release 内下载工具
- fspatch - GitHub
访问 fspatch 仓库并点击 Code - Download zip 下载
2. 打包
- 将工具内所有文件放置到所需打包分区所在目录
- 在该目录下打开 cmd 命令行
- 输入:
python fspatch.py 分区文件夹名 config\分区名_fs_config
示例:python fspatch.py vendor config\vendor_fs_config
- 输入:
mkfs.erofs -zlz4hc,8 -T 1167580800 --mount-point=/分区名 --fs-config-file=分区名_fs_config的绝对路径 --file-contexts=分区名_file_contexts的绝对路径 打包文件名 分区文件夹名
示例:mkfs.erofs -zlz4hc,8 -T 1167580800 --mount-point=/vendor --fs-config-file=D:\homo\config\vendor_fs_config --file-contexts=D:\homo\config\vendor_file_contexts vendor_new.img vendor
- 小等一会将会打包完成
注意
- 打包要求您的文件需要严格按照解包后的结构(即所需打包文件夹 + config文件夹)存放,避免造成找不到文件的情况。
- 正确存放示例:
vendor config mkfs.erofs.exe winfsp-x64.dll cygwin1.dll fspatch.py
3. boot/recovery类型 img 打包
1. 获得所需工具 - magiskboot(GitHub)
请访问工具 GitHub 仓库并从 Release 内下载工具
2. 打包
- 将工具放置到所需打包的boot/recovery的所在目录
- 在该目录下打开 cmd 命令行
- 输入:
magiskboot.exe repack 原img文件 新img文件
示例:magiskboot.exe repack boot.img boot_new.img
- 小等一会将会打包完成
注意
- 请严格按照解包教程内的解包方法操作才可使用本方法进行打包
dat格式打包
1. 获得所需工具 - img2sdat(GitHub)
所需环境: Python(官网)
访问 img2sdat 仓库并点击 Code - Download zip 下载
2. 打包
- 将工具解压到 img文件 所在目录
- 在该目录下打开 cmd 命令行
- 输入
python img2sdat.py img文件 -v 4 [-p 分区名]
示例:python img2sdat.py system.img -v 4 -p system
- 小等一会将会打包完成
注意
[-p 分区名]
为可选项 不传入此参数打包得到的 dat 名称默认为system.new.dat
,system.patch.dat
,system.transfer.list
br格式打包
1. 获得所需工具 - brotli(GitHub)
请访问工具 GitHub 仓库并从 Release 内下载工具
2. 打包
- 将工具解压到 br文件 所在目录
- 在该目录下打开 cmd 命令行
- 输入:
brotli -q 5 dat文件 -o 输出的br文件
示例:brotli -q 5 system.new.dat -o system.new.dat.br
- 小等一会,br文件将会被解压,解压后的文件在同目录
注意
- -q 后的数字为压缩等级,可选1 - 9。数字越大,压缩率越高,耗时越长。