部署到 iOS 和 Android
由于我们在项目创建之初就添加了 Capacitor,现在只需几个步骤就能将照片库应用部署到我们的设备上了!
Capacitor 设置
Capacitor 是 Ionic 官方的应用运行时,它使得将 Web 应用部署到 iOS、Android 等原生平台变得简单。如果您过去使用过 Cordova,建议阅读此处了解更多差异。
如果终端仍在运行 ionic serve,请先停止它。完成 Ionic 项目的新构建,并修复所有报告的错误:
ionic build
接下来,同时创建 iOS 和 Android 项目:
ionic cap add ios
ionic cap add android
项目根目录下会创建 android 和 ios 文件夹。这些是完全独立的原生项目,应视为 Ionic 应用的一部分(例如,将它们纳入版本控制,使用原生工具进行编辑等)。
每次执行构建(例如 ionic build)并更新了 web 目录(默认:build)后,都需要将这些更改复制到原生项目中:
ionic cap copy
注意:在更新代码的原生部分(例如添加新插件)后,请使用 sync 命令:
ionic cap sync
iOS 部署
要构建 iOS 应用,您需要一台 Mac 电脑。
Capacitor iOS 应用通过 Xcode(Apple 的 iOS/Mac IDE)进行配置和管理,依赖项由 CocoaPods 管理。在 iOS 设备上运行此应用之前,需要完成几个步骤。
首先,运行 Capacitor 的 open 命令,该命令会在 Xcode 中打开原生 iOS 项目:
ionic cap open ios
为了使某些原生插件正常工作,必须配置用户权限。在我们的照片库应用中,这包括 Camera 插件:iOS 在首次调用 Camera.getPhoto() 后会自动显示一个模态对话框,提示用户允许应用使用相机。驱动此功能的权限标记为“Privacy - Camera Usage”。要设置它,必须修改 Info.plist 文件(更多详情)。要访问它,请点击“Info”,然后展开“Custom iOS Target Properties”。

Info.plist 中的每个设置都有一个低级参数名和一个高级名称。默认情况下,属性列表编辑器显示高级名称,但切换到显示原始的低级名称通常很有用。为此,在属性列表编辑器中的任意位置右键单击,然后切换“Raw Keys/Values”。
添加 NSCameraUsageDescription 键,并将值设置为描述应用需要使用相机的原因,例如“用于拍摄照片”。当权限提示打开时,值字段会显示给应用用户。
按照相同的过程添加 Camera 插件所需的另外两个键:NSPhotoLibraryAddUsageDescription 和 NSPhotoLibraryUsageDescription。
接下来,单击左侧项目导航器中的 App,然后在 Signing & Capabilities 部分中,选择您的开发团队。

权限设置完毕并选择了开发团队后,我们就可以在真实设备上试运行应用了!将 iOS 设备连接到 Mac 电脑,选择它(对我来说是 App -> Matthew’s iPhone),然后单击“Build”按钮以在设备上构建、安装和启动应用:

点击照片库标签页上的相机按钮后,权限提示将显示。点击“OK”,然后使用相机拍照。之后,照片会显示在应用中!

Android 部署
Capacitor Android 应用通过 Android Studio 进行配置和管理。在 Android 设备上运行此应用之前,需要完成几个步骤。
首先,运行 Capacitor 的 open 命令,该命令会在 Android Studio 中打开原生 Android 项目:
ionic cap open android
与 iOS 类似,我们必须启用正确的权限才能使用相机。在 AndroidManifest.xml 文件中配置这些权限。Android Studio 可能会自动打开此文件,但如果没有,请在 android/app/src/main/ 下找到它。

滚动到 Permissions 部分,确保包含以下条目:
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/>
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
保存文件。权限设置完成后,我们就可以在真实设备上试运行应用了!将 Android 设备连接到计算机。在 Android Studio 中,单击“Run”按钮,选择已连接的 Android 设备,然后单击“OK”以在设备上构建、安装和启动应用。

再次,点击照片库标签页上的相机按钮后,应显示权限提示。点击“OK”,然后使用相机拍照。之后,照片应出现在应用中。

我们的照片库应用刚刚部署到了 Android 和 iOS 设备上。🎉
在本教程的最后部分,我们将使用 Ionic CLI 的 Live Reload 功能快速实现照片删除功能——从而完成我们的照片库功能。