docs/content/docs/custom-native-camera-outputs.mdx
import { Tab, Tabs } from 'fumadocs-ui/components/tabs'
Third-party libraries can implement the CameraOutput class in native code to build a custom camera output that can be connected to the Camera just like any other output. This is achieved using Nitro Modules Hybrid Object inheritance - simply implement the native HybridCameraOutputSpec, and conform to the NativeCameraOutput interface/protocol:
<Tabs items={["Swift (iOS)", "Kotlin (Android)"]} groupId="native-language"> <Tab value="Swift (iOS)">
import AVFoundation
import VisionCamera
class MyCustomOutput: HybridCameraOutputSpec, NativeCameraOutput {
// ...
}
class MyCustomOutput: HybridCameraOutputSpec(), NativeCameraOutput { // ... }
</Tab>
</Tabs>
> [!NOTE]
> The `NativeCameraOutput` interface/protocol requires you to implement methods and properties that expose the actual native `AVCaptureOutput`/`UseCase`, which will get used by the [`CameraSession`](/api/react-native-vision-camera/hybrid-objects/CameraSession).
> Additionally, you can participate in resolution negotiations, and input/format requirements via these.
Then, create a [Nitro Modules](https://github.com/mrousavy/nitro) `HybridObject` that returns a [`CameraOutput`](/api/react-native-vision-camera/hybrid-objects/CameraOutput):
```ts
import type { CameraOutput } from 'react-native-vision-camera'
export interface MyCustomOutputFactory {
createMyCustomOutput(): CameraOutput
}
And finally, implement the createMyCustomOutput() method:
<Tabs items={["Swift (iOS)", "Kotlin (Android)"]} groupId="native-language"> <Tab value="Swift (iOS)">
import AVFoundation
import VisionCamera
class MyCustomOutputFactory: HybridMyCustomOutputFactorySpec {
func createMyCustomOutput() -> any HybridCameraOutputSpec {
return MyCustomOutput()
}
}
class MyCustomOutputFactory: HybridMyCustomOutputFactorySpec() { fun createMyCustomOutput(): HybridCameraOutputSpec { return MyCustomOutput() } }
</Tab>
</Tabs>
Now, if you create an instance of this output in JS, you can attach it to the Camera Session.
> [!NOTE]
> This is how the VisionCamera Barcode Scanner ([react-native-vision-camera-barcode-scanner](/api/react-native-vision-camera-barcode-scanner)) output is implemented - see: [`createBarcodeScannerOutput(...)`](/api/react-native-vision-camera-barcode-scanner/functions/createBarcodeScannerOutput).