Anleitung zum Starten
Kopieren Sie einen Einrichtungsbefehl mit den Installationsanweisungen und der vollständigen Markdown-Dokumentation für diesen Plugin.
Set up this Capacitor plugin in the project.
Use the package manager already used by the project.
Install these package(s): `@capgo/camera-preview`
Run the required Capacitor sync/update step after installation.
Read this markdown guide for the full setup steps: https://raw.githubusercontent.com/Cap-go/website/refs/heads/main/apps/docs/src/content/docs/docs/plugins/camera-preview/getting-started.mdx
Use that guide for platform-specific steps, native file edits, permissions, config changes, imports, and usage setup.
If that guide references other docs pages, read them too.
Installieren
Abschnitt mit dem Titel „Installieren“bun add @capgo/camera-previewbunx cap syncImportieren
Abschnitt mit dem Titel „Importieren“import { CameraPreview } from '@capgo/camera-preview';API Übersicht
Abschnitt mit dem Titel „API Übersicht“Startet die Kameravorschau.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.start({} as CameraPreviewOptions);Beendet die Kameravorschau.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.stop();Ermittelt ein Bild vom Kamera.
Wenn storeToFile war auf " true gesetzt, wenn die Vorschau gestartet wird, wird das zurückgegebene
value ein absoluter Dateipfad auf dem Gerät anstatt eine Base64-Zeichenfolge sein. Verwenden Sie getBase64FromFilePath, um die Base64-Zeichenfolge aus dem Dateipfad zu erhalten.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.capture({} as CameraPreviewPictureOptions);captureSample
Abschnitt mit dem Titel “AufnahmeProbe”Ermittelt eine einzelne Frame aus dem Kamera-Vorschau-Stream.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.captureSample({} as CameraSampleOptions);getSupportedFlashModes
Abschnitt mit dem Titel “erhalteGeschriebeneBlitzeModi”Ermittelt die Blitze-Modi, die von der aktiven Kamera unterstützt werden.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.getSupportedFlashModes();setAspectRatio
Abschnitt mit dem Titel „setAspectRatio“Setzt den Aspektverhältnis des Kameravorschau-Bildes.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.setAspectRatio({} as { aspectRatio: '4:3' | '16:9'; x?: number; y?: number });getAspectRatio
Abschnitt mit dem Titel „getAspectRatio“Ermittelt das aktuelle Aspektverhältnis des Kameravorschau-Bildes.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.getAspectRatio();setGridMode
Abschnitt mit dem Titel „setGridMode“Setzt den Rastermodus des Kameravorschau-Overlay-Bildes.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.setGridMode({} as { gridMode: GridMode });getGridMode
Abschnitt mit dem Titel „getGridMode“Ermittelt den aktuellen Rastermodus des Kameravorschau-Overlay-Bildes.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.getGridMode();checkPermissions
Abschnitt mit dem Titel “checkPermissions”Überprüft den aktuellen Stand der Kamera- (und optional der Mikrofon-) Berechtigung ohne das Systemdialog zu öffnen.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.checkPermissions();requestPermissions
Abschnitt mit dem Titel “requestPermissions”Berechtigungen für die Kamera (und optional das Mikrofon) anfordern. Wenn Berechtigungen bereits erteilt oder abgelehnt wurden,
wird der aktuelle Status ohne Anfrage zurückgegeben. Wenn showSettingsAlert wahr ist und Berechtigungen abgelehnt wurden,
wird eine plattform-spezifische Warnung vorgestellt, die den Benutzer zu den Einstellungen der App leitet.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.requestPermissions();getHorizontalFov
Abschnitt mit dem Titel “getHorizontalFov”Ermittelt den horizontalen Gesichtswinkel für die aktive Kamera. Hinweis: Dies kann auf einigen Geräten eine Schätzung sein.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.getHorizontalFov();getSupportedPictureSizes
Abschnitt mit dem Titel “getSupportedPictureSizes”Ermittelt die unterstützten Bildgrößen für alle Kameras.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.getSupportedPictureSizes();setFlashMode
Abschnitt mit dem Titel “setFlashMode”Setzt die Blitzmodus für die aktive Kamera.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.setFlashMode({} as { flashMode: CameraPreviewFlashMode | string });Schaltet zwischen der Vorder- und Rückseite der Kamera.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.flip();setOpacity
Abschnitt mit dem Titel “setOpacity”Setzt die Opazität der Kamera-Vorschau.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.setOpacity({} as CameraOpacityOptions);stopRecordVideo
Abschnitt mit dem Titel “stopRecordVideo”Beendet eine laufende Videoaufzeichnung.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.stopRecordVideo();startRecordVideo
Abschnitt mit dem Titel “startRecordVideo”Beginnt eine Videoaufzeichnung.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.startRecordVideo({} as CameraPreviewOptions);isRunning
Abschnitt mit dem Titel “isRunning”Überprüft, ob die Kamera-Vorschau derzeit läuft.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.isRunning();getAvailableDevices
Abschnitt mit dem Titel “getAvailableDevices”Ermittelt alle verfügbaren Kamera-Geräte.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.getAvailableDevices();Ermittelt den aktuellen Zoomzustand, einschließlich Min./Max. und aktuellen Brennweiten-Info.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.getZoom();getZoomButtonValues
Abschnitt mit dem Titel “getZoomButtonValues”Gibt die Zoom-Taste-Werte für schnelles Umstellen zurück.
- iOS/Android: enthält 0,5, wenn Ultra-Wide verfügbar ist; 1 und 2, wenn breit verfügbar ist; 3, wenn Telephoto verfügbar ist
- Web: nicht unterstützt
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.getZoomButtonValues();Setzt die Zoomstufe der Kamera.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.setZoom({} as { level: number; ramp?: boolean; autoFocus?: boolean });getFlashMode
Abschnitt mit dem Titel “getFlashMode”Ermittelt den aktuellen Blitzmodus.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.getFlashMode();setDeviceId
Abschnitt mit dem Titel „setDeviceId“Schaltet die aktive Kamera auf die mit der angegebenen ID deviceId.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.setDeviceId({} as { deviceId: string });getDeviceId
Abschnitt mit dem Titel „getDeviceId“Ermittelt die ID der Kamera, die derzeit gebunden ist. Bei Android, wenn eine physische-Linsen-Anfrage auf eine logische Kamera zurückfällt, gibt diese die ID der gebundenen logischen Kamera zurück.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.getDeviceId();getPreviewSize
Abschnitt mit dem Titel „getPreviewSize“Ermittelt die aktuelle Vorschau-Größe und -Position.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.getPreviewSize();setPreviewSize
Abschnitt mit dem Titel „setPreviewSize“Setzt die Vorschau-Größe und -Position.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.setPreviewSize({} as { x?: number; y?: number; width: number; height: number });Setzt die Kamera-Belichtung auf einen bestimmten Punkt im Vorschau-Bild.
Hinweis: Das Plugin bindet keine native Berührungsfokussierung-Gesten-Handler. Behandeln Sie Berührungen in Ihrer HTML/JS (z. B. auf der überlagerten UI), dann übergeben Sie normalisierte Koordinaten hier.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.setFocus({} as { x: number; y: number });deleteFile
Abschnitt mit dem Titel „deleteFile“Löscht ein Datei an der gegebenen absoluten Pfad auf dem Gerät.
Verwenden Sie dies, um temporäre Bilder schnell zu löschen, die mit
erstellt wurden. storeToFile
Auf dem Web wird dies nicht unterstützt und wird einen Fehler werfen.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.deleteFile({} as { path: string });getSafeAreaInsets
Abschnitt mit dem Titel „getSafeAreaInsets“Erhält die sicheren Bereichs-Einrückungen für Geräte. Gibt die orientierungsbewusste Notch/Kamera-Schnittstelle-Einrückung und die aktuelle Orientierung zurück. In Portrait-Modus: Gibt die obere Einrückung (Notch oben) zurück. In Landschaftsmodus: Gibt die linke Einrückung (Notch an der Seite) zurück. Dies zielt speziell auf die Schnittstelle-Bereich (Notch, Loch, usw.) ab, die alle modernen Smartphones haben.
Android: Werte in dp (logische Pixel) zurückgegeben. iOS: Werte in physischen Pixel, ausschließlich Statusleiste (reine Notch-/Schnittstelle-Größe).
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.getSafeAreaInsets();getOrientation
Abschnitt mit dem Titel “getOrientation”Ruft die aktuelle Geräteeinstellung in einer plattformübergreifenden Format ab.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.getOrientation();getExposureModes
Abschnitt mit dem Titel “getExposureModes”Gibt die von der aktiven Kamera unterstützten Belichtungsmodi zurück. Mögliche Modi umfassen: ‘gesperrt’, ‘automatisch’, ‘fortlaufend’, ‘benutzerdefiniert’.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.getExposureModes();getExposureMode
Abschnitt mit dem Titel “getExposureMode”Gibt den aktuellen Belichtungsmodus zurück.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.getExposureMode();setExposureMode
Abschnitt mit dem Titel “setExposureMode”Setzt den Belichtungsmodus.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.setExposureMode({} as { mode: ExposureMode });getExposureCompensationRange
Abschnitt mit dem Titel “getExposureCompensationRange”Gibt den Bereich der unterstützten Belichtungsanpassung (EV-Verschiebung) zurück.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.getExposureCompensationRange();getExposureCompensation
Abschnitt mit dem Titel “getExposureCompensation”Gibt die aktuelle Belichtungsanpassung (EV-Verschiebung) zurück.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.getExposureCompensation();setExposureCompensation
Abschnitt mit dem Titel “setExposureCompensation”Setzt die Belichtungsanpassung (EV-Verschiebung). Der Wert wird auf den Bereich begrenzt.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.setExposureCompensation({} as { value: number });Abschnitt mit dem Titel “Type Reference”
Abschnitt mit dem Titel “Type Reference”CameraPreviewOptions
Abschnitt mit dem Titel “Kameravorschauoptionen”Legt die Konfigurationsoptionen für das Starten der Kameravorschau fest.
export interface CameraPreviewOptions { /** * The parent element to attach the video preview to. * @platform web */ parent?: string; /** * A CSS class name to add to the preview element. * @platform web */ className?: string; /** * The width of the preview in pixels. Defaults to the screen width. * @platform android, ios, web */ width?: number; /** * The height of the preview in pixels. Defaults to the screen height. * @platform android, ios, web */ height?: number; /** * The horizontal origin of the preview, in pixels. * @platform android, ios */ x?: number; /** * The vertical origin of the preview, in pixels. * @platform android, ios */ y?: number; /** * The aspect ratio of the camera preview, '4:3' or '16:9' or 'fill'. * Cannot be set if width or height is provided, otherwise the call will be rejected. * Use setPreviewSize to adjust size after starting. * * @since 2.0.0 */ aspectRatio?: '4:3' | '16:9'; /** * Controls how the camera preview fills the available space. * - 'contain': Fits the entire preview within the space, may show letterboxing (default). * - 'cover': Fills the entire space, may crop edges of the preview. * @default "contain" * @platform android, ios, web */ aspectMode?: 'cover' | 'contain'; /** * The grid overlay to display on the camera preview. * @default "none" * @since 2.1.0 */ gridMode?: GridMode; /** * Adjusts the y-position to account for safe areas (e.g., notches). * @platform ios * @default false */ includeSafeAreaInsets?: boolean; /** * If true, places the preview behind the webview. * @platform android * @default true */ toBack?: boolean; /** * Bottom padding for the preview, in pixels. * @platform android, ios */ paddingBottom?: number; /** * Whether to rotate the preview when the device orientation changes. * @platform ios * @default true */ rotateWhenOrientationChanged?: boolean; /** * The camera to use. * @default "rear" */ position?: CameraPosition | string; /** * If true, saves the captured image to a file and returns the file path. * If false, returns a base64 encoded string. * @default false */ storeToFile?: boolean; /** * If true, prevents the plugin from rotating the image based on EXIF data. * @platform android * @default false */ disableExifHeaderStripping?: boolean; /** * If true, disables the audio stream, preventing audio permission requests. * @default true */ disableAudio?: boolean; /** * If true, locks the device orientation while the camera is active. * @platform android * @default false */ lockAndroidOrientation?: boolean; /** * If true, allows the camera preview's opacity to be changed. * @platform android, web * @default false */ enableOpacity?: boolean;
/** * If true, disables the visual focus indicator when tapping to focus. * @platform android, ios * @default false */ disableFocusIndicator?: boolean; /** * The `deviceId` of the camera to use. If provided, `position` is ignored. * @platform ios */ deviceId?: string; /** * On Android, attempts to bind a physical camera directly when `deviceId` refers to a physical lens. * Disabled by default because OEM support is inconsistent; when false, Android keeps the current logical-camera fallback behavior. * @default false * @platform android */ enablePhysicalDeviceSelection?: boolean; /** * The initial zoom level when starting the camera preview. * If the requested zoom level is not available, the native plugin will reject. * @default 1.0 * @platform android, ios * @since 2.2.0 */ initialZoomLevel?: number; /** * The vertical positioning of the camera preview. * @default "center" * @platform android, ios, web * @since 2.3.0 */ positioning?: CameraPositioning; /** * If true, enables video capture capabilities when the camera starts. * @default false * @platform android * @since 7.11.0 */ enableVideoMode?: boolean; /** * If true, forces the camera to start/restart even if it's already running or busy. * This will kill the current camera session and start a new one, ignoring all state checks. * @default false * @platform android, ios, web */ force?: boolean; /** * Sets the quality of video for recording. * Options: 'low', 'medium', 'high' * @note On Android requires 'enableVideoMode' to be true * @note Will affect the entire preview stream for iOS * @platform ios, android * @default "high" */ videoQuality?: 'low' | 'medium' | 'high';}CameraPreviewPictureOptions
Abschnitt mit dem Titel “Kameravorschaubildoptionen”Legt die Optionen für das Aufnehmen eines Bildes fest.
export interface CameraPreviewPictureOptions { /** * The maximum height of the picture in pixels. The image will be resized to fit within this height while maintaining aspect ratio. * If not specified the captured image will match the preview's visible area. */ height?: number; /** * The maximum width of the picture in pixels. The image will be resized to fit within this width while maintaining aspect ratio. * If not specified the captured image will match the preview's visible area. */ width?: number; /** * The quality of the captured image, from 0 to 100. * Does not apply to `.png` format. * @default 85 */ quality?: number; /** * The format of the captured image. * @default "jpeg" */ format?: PictureFormat; /** * If true, the captured image will be saved to the user's gallery. * @default false * @since 7.5.0 */ saveToGallery?: boolean; /** * If true, the plugin will attempt to add GPS location data to the image's EXIF metadata. * This may prompt the user for location permissions. * @default false * @since 7.6.0 */ withExifLocation?: boolean; /** * If true, the plugin will embed a timestamp in the top-right corner of the image. * @default false * @since 7.17.0 */ embedTimestamp?: boolean; /** * If true, the plugin will embed the current location in the top-right corner of the image. * Requires `withExifLocation` to be enabled. * @default false * @since 7.18.0 */ embedLocation?: boolean; /** * Sets the priority for photo quality vs. capture speed. * - "speed": Prioritizes faster capture times, may reduce image quality. * - "balanced": Aims for a balance between quality and speed. * - "quality": Prioritizes image quality, may reduce capture speed. * See https://developer.apple.com/documentation/avfoundation/avcapturephotosettings/photoqualityprioritization for details. * * @since 7.21.0 * @platform ios * @default "speed" */ photoQualityPrioritization?: 'speed' | 'balanced' | 'quality';}Stellt die aus einem Bild extrahierten EXIF-Daten dar.
export interface ExifData { [key: string]: any;}CameraSampleOptions
Abschnitt mit dem Titel “Kameravorschau-Probeoptionen”Legt die Optionen für das Aufnehmen einer Probebilder aus der Kameravorschau fest.
export interface CameraSampleOptions { /** * The quality of the captured sample, from 0 to 100. * @default 85 */ quality?: number;}CameraPreviewFlashMode
Abschnitt mit dem Titel “Kameravorschau-Blitzmodus”Die verfügbaren Blitzmodi für die Kamera. ‘Torch’ ist ein kontinuierlicher Lichtmodus.
export type CameraPreviewFlashMode = 'off' | 'on' | 'auto' | 'torch';export type GridMode = 'none' | '3x3' | '4x4';PermissionRequestOptions
Abschnitt mit dem Titel “Erlaubnisanforderungsoptionen”export interface PermissionRequestOptions { disableAudio?: boolean; showSettingsAlert?: boolean; title?: string; message?: string; openSettingsButtonTitle?: string; cancelButtonTitle?: string;}CameraPermissionStatus
Abschnitt mit dem Titel “Kamerazugriffstatus”export interface CameraPermissionStatus { camera: PermissionState; microphone?: PermissionState;}SupportedPictureSizes
Abschnitt mit dem Titel “Unterstützte Bildgrößen”Stellt die unterstützten Bildgrößen für eine Kamera in einer bestimmten Richtung dar.
export interface SupportedPictureSizes { /** The camera direction ("front" or "rear"). */ facing: string; /** A list of supported picture sizes for this camera. */ supportedPictureSizes: PictureSize[];}CameraOpacityOptions
Abschnitt mit dem Titel “CameraOpacityOptions”Legt die Optionen für die Einstellung der Opazität des Kameravorschau-Bildes fest.
export interface CameraOpacityOptions { /** * The opacity percentage, from 0.0 (fully transparent) to 1.0 (fully opaque). * @default 1.0 */ opacity?: number;}CameraDevice
Abschnitt mit dem Titel “CameraDevice”Stellt einen physischen Kameradevice auf dem Gerät dar (z.B. die Vorderkamera).
export interface CameraDevice { /** A unique identifier for the camera device. */ deviceId: string; /** A human-readable name for the camera device. */ label: string; /** The physical position of the camera on the device. */ position: CameraPosition; /** A list of all available lenses for this camera device. */ lenses: CameraLens[]; /** The overall minimum zoom factor available across all lenses on this device. */ minZoom: number; /** The overall maximum zoom factor available across all lenses on this device. */ maxZoom: number; /** Identifies whether the device is a logical camera (composed of multiple physical lenses). */ isLogical: boolean;}Stellt die detaillierten Informationen der derzeit aktiven Linse dar.
export interface LensInfo { /** The focal length of the active lens in millimeters. */ focalLength: number; /** The device type of the active lens. */ deviceType: DeviceType; /** The base zoom ratio of the active lens (e.g., 0.5x, 1.0x). */ baseZoomRatio: number; /** The current digital zoom factor applied on top of the base zoom. */ digitalZoom: number;}Quelle der Wahrheit
Abschnitt mit dem Titel “Quelle der Wahrheit”Diese Seite wird von der Plugin-Quelle generiert. src/definitions.ts. Wiederholen Sie die Synchronisation, wenn die öffentliche API upstream geändert wird.