使用create-dmg工具制作dmg安装包

简介

create-dmg 是一个用来创建磁盘镜像文件(dmg)的 shell 脚本命令行工具。本文将介绍如何使用 create-dmg 来创建一个 dmg 磁盘镜像文件,即 macOS 系统的安装包。

准备工作

create-dmg 可以通过 Homebrew 来安装,使用以下命令安装 create-dmg

bash 复制代码
brew install create-dmg

创建 DMG 文件

在创建 dmg 文件之前,确保你的应用程序已经打包好,并且所有的资源文件都已经放置在正确的位置。通常为 xxx.app 的 bundle 形式文件。

创建一个文件夹,将你的应用程序拖放进去。这个文件夹将作为 dmg 文件的根目录。这里以 dmg-demo 作为目录为例:

复制代码
dmg-demo
├── QtProjectDemo.app
├── bg.svg

只需要额外提供一张背景图即可。当然也可再提供一个 icns 图标文件作为磁盘镜像文件的图标(双击 dmg 后,桌面显示的磁盘镜像图标)

如图,上面为默认的磁盘镜像图标,下图为自行替换的图标:

这里提供的是SVG格式的背景图:

在应用程序文件夹所在的目录打开终端。然后运行以下命令:

bash 复制代码
create-dmg \
  --volname "Application Installer" \
  --background "bg.svg" \
  --window-pos 400 200 \
  --window-size 660 400 \
  --icon-size 100 \
  --icon "QtProjectDemo.app" 160 185 \
  --hide-extension "QtProjectDemo.app" \
  --app-drop-link 500 185 \
  "Installer.dmg" \
  "QtProjectDemo.app/"

这个命令中包含了多个参数:

  • --volname:设置卷的名称。
  • --background:设置窗口的背景图。
  • --window-pos:设置双击 dmg,打开窗口的位置坐标。
  • --window-size:设置窗口的大小。
  • --icon-size:设置应用程序图标的大小。
  • --icon:设置应用程序的图标和位置坐标。
  • --hide-extension:隐藏应用程序文件的扩展名。
  • 最后两个参数分别是输出的 dmg 文件名和包含应用程序的文件夹名称。

输出信息:

bash 复制代码
Creating disk image...
..................................................................................................
created: /Users/leo/Downloads/dmg-demo/rw.74691.Installer.dmg
Mounting disk image...
Device name:     /dev/disk5
Searching for mounted interstitial disk image using /dev/disk5s...
Mount dir:       /Volumes/dmg.kaLqeq
Copying background file 'bg.svg'...
Making link to Applications dir...
/Volumes/dmg.kaLqeq
Running AppleScript to make Finder stuff pretty: /usr/bin/osascript "/var/folders/mn/vvr3gxpn7b38rlkyfl_j5m2h0000gn/T/createdmg.tmp.XXXXXXXXXX.SfFuKvgIMf" "dmg.kaLqeq"
waited 1 seconds for .DS_STORE to be created.
Done running the AppleScript...
Fixing permissions...
Done fixing permissions
Skipping blessing on sandbox
Deleting .fseventsd
Unmounting disk image...
"disk5" ejected.
Compressing disk image...
正在准备映像引擎...
正在读取Protective Master Boot Record(MBR:0)...
   (CRC32 $0821720F:Protective Master Boot Record(MBR:0))
正在读取GPT Header(Primary GPT Header:1)...
   (CRC32 $2718773B:GPT Header(Primary GPT Header:1))
正在读取GPT Partition Data(Primary GPT Table:2)...
   (CRC32 $D08A2D56:GPT Partition Data(Primary GPT Table:2))
正在读取(Apple_Free:3)...
   (CRC32 $00000000:(Apple_Free:3))
正在读取disk image(Apple_HFS:4)...
.........................................................................................................................
   (CRC32 $FC0F7A84:disk image(Apple_HFS:4))
正在读取(Apple_Free:5)...
.........................................................................................................................
   (CRC32 $00000000:(Apple_Free:5))
正在读取GPT Partition Data(Backup GPT Table:6)...
.........................................................................................................................
   (CRC32 $D08A2D56:GPT Partition Data(Backup GPT Table:6))
正在读取GPT Header(Backup GPT Header:7)...
.........................................................................................................................
   (CRC32 $E02061DB:GPT Header(Backup GPT Header:7))
正在添加资源...
.........................................................................................................................
已耗时: 3.355s
文件大小:31846419字节,校验和:CRC32 $7457A18C
已处理扇区:213072,已压缩158148
速度:23.0MB/秒
节省:70.8%
created: /Users/leo/Downloads/dmg-demo/Installer.dmg
hdiutil does not support internet-enable. Note it was removed in macOS 10.15.
Disk image done

创建完成后,双击 dmg 文件,检查它是否按照预期显示和工作。

这里需要注意的点在于,安装界面的图标位置计算。图标的位置是中心坐标,而不是左上角坐标。

这里指定了宽度 660 px 和高度 400 px 的窗口大小,是整个窗口(包含标题栏),而标题栏本身会占有 30 px 的高度,也就是实际上的区域只有 (660,370),这就导致,如果你要想要图标都居中,那么图标的的中心坐标位置将是 (x, 370/2)。

背景图的制作也是,中间的▶️图标如果要中心居中,那么实际上需要向上偏移 30 px 高度,才会居中。

另外,虽然 create-dmg 文档说支持 png、gif、jpg,但实测还支持 SVG、tiff 格式。

总结

通过使用 create-dmg,你可以为你的 Mac 应用程序创建 DMG 磁盘镜像文件,同时也能方便地集成到 CI/CD 流程中。

附录

create-dmg 用法:

xml 复制代码
create-dmg [options ...] <output_name.dmg> <source_folder>

参数选项:

  • --volname <name>:设置卷标名称(在 Finder 侧边栏和窗口标题中显示)
  • --volicon <icon.icns>:设置卷标图标
  • --background <pic.png>:设置文件夹背景图像(提供 png、gif、jpg 格式)
  • --window-pos <x> <y>:设置文件夹窗口的位置
  • --window-size <width> <height>:设置文件夹窗口的大小
  • --text-size <text_size>:设置窗口文本大小(10-16)
  • --icon-size <icon_size>:设置窗口图标大小(最大 128)
  • --icon <file_name> <x> <y>:设置文件图标的位置
  • --hide-extension <file_name>:隐藏文件的扩展名
  • --app-drop-link <x> <y>:在位置 x, y 创建一个指向应用程序的快捷链接
  • --ql-drop-link <x> <y>:在位置 x, y 创建一个指向 /Library/QuickLook 的快捷链接
  • --eula <eula_file>:附加一个许可协议文件到 dmg
  • --rez <rez_path>:指定包含许可协议文件的 Rez 工具的自定义路径
  • --no-internet-enable:禁用自动挂载和复制
  • --format:指定最终图像格式(UDZO|UDBZ|ULFO|ULMO)(默认为 UDZO)
  • --filesystem:指定图像文件系统(HFS+|APFS)(默认为 HFS+,APFS 支持 macOS 10.13 或更新版本)
  • --encrypt:启用结果磁盘镜像的加密(AES-256 - 将提示输入密码)
  • --encrypt-aes128:启用结果磁盘镜像的加密(AES-128 - 将提示输入密码)
  • --add-file <target_name> <file|folder> <x> <y>:添加额外的文件或文件夹(可多次使用)
  • --disk-image-size <x>:手动设置磁盘镜像大小为 x MB
  • --hdiutil-verbose:以详细模式执行 hdiutil
  • --hdiutil-quiet:以安静模式执行 hdiutil
  • --codesign <signature>:使用指定的签名对磁盘镜像进行代码签名
  • --notarize <credentials>:使用存储在钥匙串中的凭据对磁盘镜像进行签名(等待并装订)。更多信息请查看 Apple的文档
  • --skip-jenkins:跳过 Finder 美化 AppleScript,适用于沙盒和非 GUI 环境
  • --sandbox-safe:与沙盒兼容的 hdiutil,不祝福也不执行 AppleScript(不支持 APFS 磁盘镜像)
  • --version:显示工具版本号
  • -h, --help:显示帮助

create-dmg/create-dmg: A shell script to build fancy DMGs (github.com)

相关推荐
淡忘_cx1 小时前
Dify 插件开发与打包教程 (Mac)
macos
2501_915918411 小时前
App 上架苹果商店全流程详解 从开发者账号申请到开心上架(Appuploader)跨平台免 Mac 上传实战指南
macos·ios·小程序·uni-app·objective-c·cocoa·iphone
亚林瓜子7 小时前
SpringBoot中使用tess4j进行OCR(在macos上面开发)
java·spring boot·macos·ocr·lstm·tess4j
AirDroid_cn7 小时前
在 iOS 18 的照片应用,如何批量隐藏截屏?
macos·objective-c·cocoa
00后程序员张8 小时前
iOS 文件管理与导出实战,多工具协同打造高效数据访问与调试体系
android·macos·ios·小程序·uni-app·cocoa·iphone
javaGHui17 小时前
macOS 上获取调试版
macos
2501_915918411 天前
iOS描述文件功能解析
android·macos·ios·小程序·uni-app·cocoa·iphone
2501_915918412 天前
iOS 上架应用市场全流程指南,App Store 审核机制、证书管理与跨平台免 Mac 上传发布方案(含开心上架实战)
android·macos·ios·小程序·uni-app·cocoa·iphone
darkb1rd2 天前
MacCalendar:专为 Mac 用户打造的高效日历工具
macos
神秘剑客_CN3 天前
MacOS学习笔记
笔记·学习·macos