Inizia
Copia un prompt di configurazione con i passaggi di installazione e la guida markdown completa per questo 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.
Installa
Sezione intitolata “Installa”bun add @capgo/camera-previewbunx cap syncImporta
Sezione intitolata “Importa”import { CameraPreview } from '@capgo/camera-preview';API Panoramica
Sezione intitolata “API Panoramica”Avvia la preview della camera.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.start({} as CameraPreviewOptions);Ferma la preview della camera.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.stop();capture
Sezione intitolata “cattura”Cattura una foto dalla camera.
Se storeToFile era stato impostato true al momento di avviare la preview, il valore restituito
value sarà una percorso di file assoluto sul dispositivo al posto di una stringa base64. Utilizza getBase64FromFilePath per ottenere la stringa base64 dal percorso del file.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.capture({} as CameraPreviewPictureOptions);captureSample
Sezione intitolata “catturaSample”Cattura un singolo frame dal flusso di anteprima della fotocamera.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.captureSample({} as CameraSampleOptions);getSupportedFlashModes
Sezione intitolata “ottieniModiFlashSupportati”Ottiene i modi flash supportati dalla fotocamera attiva.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.getSupportedFlashModes();setAspectRatio
Sezione intitolata “impostaAspettoRapporto”Imposta il rapporto di aspetto della fotocamera anteprima.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.setAspectRatio({} as { aspectRatio: '4:3' | '16:9'; x?: number; y?: number });getAspectRatio
Sezione intitolata “ottieneAspettoRapporto”Ottiene l'attuale rapporto di aspetto della fotocamera anteprima.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.getAspectRatio();setGridMode
Sezione intitolata “setGridMode”Imposta il modo della griglia della sovrapposizione della preview della camera.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.setGridMode({} as { gridMode: GridMode });getGridMode
Sezione intitolata “getGridMode”Ottiene lo stato corrente del modo della griglia della sovrapposizione della camera.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.getGridMode();checkPermissions
Sezione intitolata “checkPermissions”Controlla lo stato di autorizzazione corrente della camera (e facoltativamente del microfono) senza sollecitare la finestra di dialogo del sistema.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.checkPermissions();requestPermissions
Sezione intitolata “requestPermissions”Richiede le autorizzazioni per la camera (e facoltativamente del microfono). Se le autorizzazioni sono già state concesse o negate,
lo stato corrente viene restituito senza sollecitare. Quando
è vero e le autorizzazioni sono negate,
una finestra di dialogo guidata dall'applicazione per la configurazione dell'utente verrà presentata. showSettingsAlert Copy to clipboard
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.requestPermissions();getHorizontalFov
Sezione intitolata “getHorizontalFov”Ottiene il campo orizzontale di visione per la camera attiva. Nota: Questo può essere un'indicazione approssimativa su alcuni dispositivi.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.getHorizontalFov();getSupportedPictureSizes
Sezione intitolata “getSupportedPictureSizes”Ottiene le dimensioni delle immagini supportate per tutte le telecamere.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.getSupportedPictureSizes();setFlashMode
Sezione intitolata “setFlashMode”Imposta il modo flash per la camera attiva.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.setFlashMode({} as { flashMode: CameraPreviewFlashMode | string });Torna a scelta tra le telecamere anteriore e posteriore.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.flip();setOpacity
Sezione intitolata “setOpacity”Imposta la trasparenza della anteprima della camera.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.setOpacity({} as CameraOpacityOptions);stopRecordVideo
Sezione intitolata “stopRecordVideo”Interrompe la registrazione video in corso.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.stopRecordVideo();startRecordVideo
Sezione intitolata “startRecordVideo”Avvia la registrazione di un video.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.startRecordVideo({} as CameraPreviewOptions);isRunning
Sezione intitolata “isRunning”Controlla se l'anteprima della camera è attualmente in esecuzione.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.isRunning();getAvailableDevices
Sezione intitolata “getAvailableDevices”Ottenere tutti i dispositivi di camera disponibili.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.getAvailableDevices();getZoom
Sezione intitolata “getZoom”Ottenere lo stato di zoom attuale, compreso minimo/maximo e informazioni sulla lente attuale.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.getZoom();getZoomButtonValues
Sezione intitolata “getZoomButtonValues”Restituisce i valori dei pulsanti di zoom per la selezione rapida.
- iOS/Android: include 0,5 se disponibile ultra-largangolo; 1 e 2 se disponibile ampio; 3 se disponibile teleobiettivo
- Web: non supportato
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.getZoomButtonValues();setZoom
Sezione intitolata “setZoom”Imposta il livello di zoom della camera.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.setZoom({} as { level: number; ramp?: boolean; autoFocus?: boolean });getFlashMode
Sezione intitolata “getFlashMode”Ottiene il modo di flash corrente.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.getFlashMode();setDeviceId
Sezione intitolata “setDeviceId”Sostituisce la camera attiva con quella specificata. deviceId.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.setDeviceId({} as { deviceId: string });getDeviceId
Sezione intitolata “getDeviceId”Ottiene l'ID del dispositivo di camera attualmente associato. Su Android, se una richiesta di lente fisica cade su una logica, questo restituisce l'ID della logica camera associata.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.getDeviceId();getPreviewSize
Sezione intitolata “getPreviewSize”Ottiene la dimensione e la posizione attuali della anteprima.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.getPreviewSize();setPreviewSize
Sezione intitolata “setPreviewSize”Imposta la dimensione e la posizione della anteprima.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.setPreviewSize({} as { x?: number; y?: number; width: number; height: number });setFocus
Sezione intitolata “setFocus”Imposta il focus della camera su un punto specifico nella anteprima.
Nota: Il plugin non gestisce alcun gestore di tap-to-focus nativo. Gestisci i tocchi nella tua HTML/JS (ad esempio, sull'interfaccia utente sovrapposta), quindi passa le coordinate normalizzate qui.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.setFocus({} as { x: number; y: number });deleteFile
Sezione intitolata “deleteFile”Elimina un file all'indirizzo assoluto specificato sul dispositivo.
Usa questo per pulire velocemente le immagini temporanee create con storeToFile.
In rete, questo non è supportato e lancerà un'eccezione.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.deleteFile({} as { path: string });getSafeAreaInsets
Sezione intitolata “getSafeAreaInsets”Ottiene gli insetti di area sicura per dispositivi. Restituisce l'insetto di orientamento consapevole della notch/camera e l'orientamento corrente. In modalità ritratto: restituisce l'insetto superiore (notch in alto). In modalità orizzontale: restituisce l'insetto sinistro (notch spostata sul lato). Questo si concentra specificamente sull'area del taglio (notch, foro, ecc.) che tutti i moderni telefoni hanno.
Android: I valori restituiti in dp (pixel logici). iOS: I valori restituiti in pixel fisici, escludendo la barra dello stato (solo dimensione pura della notch/cutout).
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.getSafeAreaInsets();getOrientation
Sezione intitolata “getOrientation”Ottiene l'orientamento corrente del dispositivo in un formato cross-platform.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.getOrientation();getExposureModes
Sezione intitolata “getExposureModes”Restituisce i modi di esposizione supportati dalla camera attiva. I modi possono includere: ‘bloccato’, ‘auto’, ‘continuo’, ‘personalizzato’.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.getExposureModes();getExposureMode
Sezione intitolata “getExposureMode”Restituisce il modo di esposizione corrente.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.getExposureMode();setExposureMode
Sezione intitolata “setExposureMode”Imposta il modo di esposizione.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.setExposureMode({} as { mode: ExposureMode });getExposureCompensationRange
Sezione intitolata “getExposureCompensationRange”Restituisce il range di compensazione di esposizione (bias EV) supportato.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.getExposureCompensationRange();getExposureCompensation
Sezione intitolata “getExposureCompensation”Restituisce la compensazione di esposizione corrente (bias EV).
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.getExposureCompensation();setExposureCompensation
Sezione intitolata “setExposureCompensation”Imposta la compensazione di esposizione (EV bias). Il valore sarà limitato al range.
import { CameraPreview } from '@capgo/camera-preview';
await CameraPreview.setExposureCompensation({} as { value: number });Riferimento di tipo
Sezione intitolata “Riferimento di tipo”CameraPreviewOptions
Sezione intitolata “CameraPreviewOptions”Definisce le opzioni di configurazione per l'avvio della preview della fotocamera.
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
Sezione intitolata “CameraPreviewPictureOptions”Definisce le opzioni per la cattura di una foto.
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';}ExifData
Sezione intitolata “ExifData”Rappresenta i dati EXIF estratti da un'immagine.
export interface ExifData { [key: string]: any;}CameraSampleOptions
Sezione intitolata “CameraSampleOptions”Definisce le opzioni per la cattura di un frame di prova dalla preview della fotocamera.
export interface CameraSampleOptions { /** * The quality of the captured sample, from 0 to 100. * @default 85 */ quality?: number;}CameraPreviewFlashMode
Sezione intitolata “CameraPreviewFlashMode”I modi di flash disponibili per la fotocamera. ‘torch’ è un modo di luce continua.
export type CameraPreviewFlashMode = 'off' | 'on' | 'auto' | 'torch';GridMode
Sezione intitolata “GridMode”export type GridMode = 'none' | '3x3' | '4x4';PermissionRequestOptions
Sezione intitolata “PermissionRequestOptions”export interface PermissionRequestOptions { disableAudio?: boolean; showSettingsAlert?: boolean; title?: string; message?: string; openSettingsButtonTitle?: string; cancelButtonTitle?: string;}CameraPermissionStatus
Sezione intitolata “CameraPermissionStatus”export interface CameraPermissionStatus { camera: PermissionState; microphone?: PermissionState;}SupportedPictureSizes
Sezione intitolata “Dimensioni delle immagini supportate”Rappresenta le dimensioni delle immagini supportate per una certa direzione della fotocamera.
export interface SupportedPictureSizes { /** The camera direction ("front" or "rear"). */ facing: string; /** A list of supported picture sizes for this camera. */ supportedPictureSizes: PictureSize[];}CameraOpacityOptions
Sezione intitolata “Opacità della fotocamera”Definisce le opzioni per impostare l'opacità della preview della fotocamera.
export interface CameraOpacityOptions { /** * The opacity percentage, from 0.0 (fully transparent) to 1.0 (fully opaque). * @default 1.0 */ opacity?: number;}CameraDevice
Sezione intitolata “Dispositivo di fotocamera”Rappresenta una fotocamera fisica sul dispositivo (ad esempio, la fotocamera frontale).
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;}Rappresenta le informazioni dettagliate della lente attualmente attiva.
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;}Fonte di Verità
Sezione intitolata “Fonte di Verità”Questa pagina è generata dal plugin’s src/definitions.tsRiepiloga quando le informazioni pubbliche API cambiano in modo significativo.