react-native-vision-camera/package/ios
Marc Rousavy b3a88278de
perf: Fix double configuration flicker on fast device change (#2537)
* fix: Fix double configuration on device change

Fixes a situation that happened on every device change (or initial mount) where the device was configured after the session, separately, instead of just all at once causing an additonal delay/flicker of the prevjew.

* Try?

* Format

* Update CameraSession.swift

* Use `defer`

* Throw `.device`
2024-02-13 13:32:11 +01:00
..
Core perf: Fix double configuration flicker on fast device change (#2537) 2024-02-13 13:32:11 +01:00
Extensions chore: Remove unused file AVCaptureConnection+setInterfaceOrientation.swift 2024-01-26 10:20:55 +01:00
Frame Processor feat: SharedArray:wrapData:withSize init for iOS (#2410) 2024-01-18 10:41:26 +01:00
Parsers
React Utils
Types
VisionCamera.xcodeproj chore: Remove unused file AVCaptureConnection+setInterfaceOrientation.swift 2024-01-26 10:20:55 +01:00
.swift-version
.swiftformat
.swiftlint.yml chore: Update swiftlint to latest (#2398) 2024-01-16 18:01:41 +01:00
CameraBridge.h feat: Add zero-copy SharedArray type to Frame Processor Plugins (#2383) 2024-01-12 16:00:36 +01:00
CameraDevicesManager.m
CameraDevicesManager.swift
CameraView.swift fix: Prevent phone from going to sleep if Camera is active (#2421) 2024-01-19 12:35:33 +01:00
CameraView+Focus.swift
CameraView+RecordVideo.swift
CameraView+TakePhoto.swift
CameraView+Zoom.swift fix: Fix iOS native enableZoomGesture zoom logic (#2329) 2024-01-02 11:57:22 +01:00
CameraViewManager.m perf: Make getCameraPermission and getMicrophonePermission synchronous (#2302) 2023-12-19 14:22:04 +01:00
CameraViewManager.swift perf: Make getCameraPermission and getMicrophonePermission synchronous (#2302) 2023-12-19 14:22:04 +01:00
README.md

ios

This folder contains the iOS-platform-specific code for react-native-vision-camera.

Prerequesites

  1. Install Xcode tools
    xcode-select --install
    
  2. Install need SwiftFormat and SwiftLint
    brew install swiftformat swiftlint
    

Getting Started

It is recommended that you work on the code using the Example project (example/ios/VisionCameraExample.xcworkspace), since that always includes the React Native header files, plus you can easily test changes that way.

You can however still edit the library project here by opening VisionCamera.xcodeproj, this has the advantage of automatically formatting your Code (swiftformat) and showing you Linter errors (swiftlint) when trying to build (+B).

Committing

Before committing, make sure that you're not violating the Swift or C++ codestyles. To do that, run the following command:

yarn check-ios

This will also try to automatically fix any errors by re-formatting the Swift code.