如何打包 Android ROM:修订间差异

来自Uotan Wiki · 刷机百科
(首次编写)
 
(修正目录错误)
第29行: 第29行:
访问工具链接 并点击 下载图标 下载文件
访问工具链接 并点击 下载图标 下载文件


==== 2. 打包 ====
===== 2. 打包 =====
 
# 将工具放置到 所需打包分区 所在目录
# 将工具放置到 所需打包分区 所在目录
# 在该目录下打开 cmd 命令行
# 在该目录下打开 cmd 命令行

2024年2月16日 (五) 21:31的版本

提醒事项

注意:本教程以在 Windows 10 平台下进行解包操作为例,并确保你拥有可以访问国际网络的能力

格式确认

在正式开始之前,你需要了解你接下来需要打包的是哪种类型的文件。本教程将介绍

  1. img格式
  2. dat格式
  3. br格式

img格式打包

特别注意

本章节将分为三个部分,分别是

  1. ext4 格式 img 打包
  2. erofs 格式 img 打包
  3. boot/recovery类型 img 打包

1. ext4 格式打包

本部分将分为两个部分(两种打包方式),分别是

  1. 通过 make_ext4fs 打包
  2. 通过 mke2fs + e2fsdroid 打包

1. 通过 make_ext4fs 打包

1.获得所需工具 - make_ext4fs(GitHub)

访问工具链接 并点击 下载图标 下载文件

2. 打包
  1. 将工具放置到 所需打包分区 所在目录
  2. 在该目录下打开 cmd 命令行
  3. 记录 config\分区名_size.txt 内数值
  4. 输入 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)
  5. 小等一会将会打包完成

注意:打包要求您的文件需要严格按照解包后的结构(即 所需打包文件夹 + config文件夹)存放,避免造成找不到文件的情况。如果您的机器是动态分区,请参考第二种打包方式

正确存放示例:vendor config make_ext4fs.exe

2. 通过 mke2fs + e2fsdroid 打包

1. 获得所需工具 - mke2fs + e2fsdroid

所需环境: Python(官网)

所需工具:

mke2fs - GitHub

e2fsdroid - GitHub

工具运行库 - GitHub

访问对应链接 并点击 下载图标 下载文件

fspatch - GitHub

访问 fspatch 仓库并点击 Code - Download zip 下载

2. 打包
  1. 将工具及运行库放置到 所需打包分区 所在目录
  2. 在该目录下打开 cmd 命令行
  3. 输入 python fspatch.py 分区文件夹名 config\分区名_fs_config (示例: python fspatch.py vendor config\vendor_fs_config)
  4. 记录 config\分区名_size.txt 内数值,并除以 4096 后的数值(示例: 11451419 除以 4096)。如果有小数点(如 114514.19),请去除小数点并加1(即 114515)
  5. 输入 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)
  6. 输入 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)
  7. 小等一会将会打包完成

注意:打包要求您的文件需要严格按照解包后的结构(即 所需打包文件夹 + 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. 打包

  1. 将工具内所有文件放置到 所需打包分区 所在目录
  2. 在该目录下打开 cmd 命令行
  3. 输入 python fspatch.py 分区文件夹名 config\分区名_fs_config (示例: python fspatch.py vendor config\vendor_fs_config)
  4. 输入 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)
  5. 小等一会将会打包完成

注意:打包要求您的文件需要严格按照解包后的结构(即 所需打包文件夹 + config文件夹)存放,避免造成找不到文件的情况。

正确存放示例:vendor config mkfs.erofs.exe winfsp-x64.dll cygwin1.dll fspatch.py

3. boot/recovery类型 img 打包

1. 获得所需工具 - magiskboot(GitHub)

请访问工具 GitHub 仓库并从 Release 内下载工具

2. 打包

  1. 将工具放置到 所需打包boot/recovery 所在目录
  2. 在该目录下打开 cmd 命令行
  3. 输入 magiskboot.exe repack 原img文件 新img文件 (示例: magiskboot.exe repack boot.img boot_new.img)
  4. 小等一会将会打包完成

注意:请严格按照解包教程内的 解包方法 操作才可使用本方法进行打包

dat格式打包

1. 获得所需工具 - img2sdat(GitHub)

所需环境: Python(官网)

访问 img2sdat 仓库并点击 Code - Download zip 下载

2. 打包

  1. 将工具解压到 img文件 所在目录
  2. 在该目录下打开 cmd 命令行
  3. 输入 python img2sdat.py img文件 -v 4 [-p 分区名] (示例: python img2sdat.py system.img -v 4 -p system)
  4. 小等一会将会打包完成

注意:[-p 分区名] 为可选项 不传入此参数打包得到的 dat 名称默认为 system.new.dat, system.patch.dat, system.transfer.list

br格式打包

1. 获得所需工具 - brotli(GitHub)

请访问工具 GitHub 仓库并从 Release 内下载工具

2. 打包

  1. 将工具解压到 br文件 所在目录
  2. 在该目录下打开 cmd 命令行
  3. 输入 brotli -q 5 dat文件 -o 输出的br文件 (示例: brotli -q 5 system.new.dat -o system.new.dat.br)
  4. 小等一会 br文件 将会被解压 解压后的文件在同目录

注意:-q 后的数字为压缩等级,可选1 - 9,数字越大 压缩率越高 耗时越长