fix: Fix build on Xcode 14 (#2033)

* fix: Fix build on Xcode 14

* Format

* Make CI run on `macOS-latest`

* Nested if
This commit is contained in:
Marc Rousavy 2023-10-18 18:25:30 +02:00 committed by GitHub
parent 9573ae19cb
commit 2666ac53a6
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 27 additions and 19 deletions

View File

@ -21,7 +21,7 @@ on:
jobs: jobs:
build: build:
name: Build iOS Example App name: Build iOS Example App
runs-on: macOS-13 runs-on: macOS-latest
defaults: defaults:
run: run:
working-directory: package/example/ios working-directory: package/example/ios
@ -80,7 +80,7 @@ jobs:
build-no-frame-processors: build-no-frame-processors:
name: Build iOS Example App without Frame Processors name: Build iOS Example App without Frame Processors
runs-on: macOS-13 runs-on: macOS-latest
defaults: defaults:
run: run:
working-directory: package/example/ios working-directory: package/example/ios

View File

@ -27,7 +27,7 @@ jobs:
env: env:
WORKING_DIRECTORY: ios WORKING_DIRECTORY: ios
SwiftFormat: SwiftFormat:
runs-on: macOS-13 runs-on: macOS-latest
defaults: defaults:
run: run:
working-directory: ./package/ios working-directory: ./package/ios

View File

@ -38,13 +38,15 @@ class CameraDevicesManager: RCTEventEmitter {
override func constantsToExport() -> [AnyHashable: Any]! { override func constantsToExport() -> [AnyHashable: Any]! {
let devices = getDevicesJson() let devices = getDevicesJson()
let preferredDevice: [String: Any]? let preferredDevice = devices.first
if #available(iOS 17.0, *),
let userPreferred = AVCaptureDevice.userPreferredCamera { #if swift(>=5.9)
if #available(iOS 17.0, *) {
if let userPreferred = AVCaptureDevice.userPreferredCamera {
preferredDevice = userPreferred.toDictionary() preferredDevice = userPreferred.toDictionary()
} else {
preferredDevice = devices.first
} }
}
#endif
return [ return [
"availableCameraDevices": devices, "availableCameraDevices": devices,

View File

@ -32,6 +32,7 @@ extension AVCaptureOutput {
func setOrientation(_ orientation: Orientation) { func setOrientation(_ orientation: Orientation) {
// Set orientation for each connection // Set orientation for each connection
connections.forEach { connection in connections.forEach { connection in
#if swift(>=5.9)
if #available(iOS 17.0, *) { if #available(iOS 17.0, *) {
// Camera Sensors are always in landscape rotation (90deg). // Camera Sensors are always in landscape rotation (90deg).
// We are setting the target rotation here, so we need to rotate by landscape once. // We are setting the target rotation here, so we need to rotate by landscape once.
@ -46,6 +47,11 @@ extension AVCaptureOutput {
connection.videoOrientation = orientation.toAVCaptureVideoOrientation() connection.videoOrientation = orientation.toAVCaptureVideoOrientation()
} }
} }
#else
if connection.isVideoOrientationSupported {
connection.videoOrientation = orientation.toAVCaptureVideoOrientation()
}
#endif
} }
} }
} }