Stream di output, ritaglio e zoom

Stream di output

Il sottosistema della fotocamera opera esclusivamente sulla pipeline basata su ANativeWindow per tutte le risoluzioni e i formati di output. È possibile configurare più stream contemporaneamente per inviare un singolo frame a molti target, come la GPU, il codificatore video, RenderScript o i buffer visibili dall'app (RAW Bayer, buffer YUV elaborati o buffer con codifica JPEG).

Come ottimizzazione, questi stream di output devono essere configurati in anticipo e possono essere presenti contemporaneamente solo un numero limitato di stream. In questo modo è possibile eseguire la preallocazione dei buffer della memoria e la configurazione dell'hardware della videocamera, in modo che quando le richieste vengono inviate con più pipeline di output elencate o diverse, non ci siano ritardi o latenze nell'evasione della richiesta.

Per ulteriori informazioni sulle combinazioni di output dello stream garantite che dipendono dal livello di hardware supportato, consulta createCaptureSession().

Ritaglio

Il ritaglio dell'array di pixel completo (per lo zoom digitale e altri casi d'uso in cui è auspicabile un FOV più piccolo) viene comunicato tramite l'impostazione ANDROID_SCALER_CROP_REGION. Si tratta di un'impostazione per richiesta e può variare in base alla richiesta, il che è fondamentale per implementare lo zoom digitale uniforme.

La regione è definita come un rettangolo (x, y, larghezza, altezza), con (x, y) che descrive l'angolo in alto a sinistra del rettangolo. Il rettangolo è definito nel sistema di coordinate dell'array di pixel attivi del sensore, dove (0,0) è il pixel in alto a sinistra dell'array di pixel attivi. Pertanto, la larghezza e l'altezza non possono essere superiori alle dimensioni riportate nel campo delle informazioni statiche ANDROID_SENSOR_ACTIVE_PIXEL_ARRAY. La larghezza e l'altezza minime consentite vengono registrate dall'HAL tramite il campo di informazioni statiche ANDROID_SCALER_MAX_DIGITAL_ZOOM, che descrive il fattore di zoom massimo supportato. Pertanto, la larghezza e l'altezza minime della regione di ritaglio sono:

  {width, height} =
   { floor(ANDROID_SENSOR_ACTIVE_PIXEL_ARRAY[0] /
       ANDROID_SCALER_MAX_DIGITAL_ZOOM),
     floor(ANDROID_SENSOR_ACTIVE_PIXEL_ARRAY[1] /
       ANDROID_SCALER_MAX_DIGITAL_ZOOM) }

Se la regione di ritaglio deve soddisfare requisiti specifici (ad esempio, deve iniziare con coordinate pari e la sua larghezza/altezza deve essere pari), l'HAL deve eseguire l'arrotondamento necessario e scrivere la regione di ritaglio finale utilizzata nei metadati del risultato di output. Analogamente, se l'HAL implementa la stabilizzazione video, deve regolare la regione di ritaglio del risultato per descrivere la regione effettivamente inclusa nell'output dopo l'applicazione della stabilizzazione video. In generale, un'app che utilizza la fotocamera deve essere in grado di determinare il campo visivo che riceve in base alla regione di ritaglio, alle dimensioni del sensore di immagine e alla lunghezza focale dell'obiettivo.

Poiché la regione di ritaglio si applica a tutti gli stream, che possono avere rapporti di aspetto diversi rispetto alla regione di ritaglio, la regione del sensore esatta utilizzata per ogni stream potrebbe essere più piccola della regione di ritaglio. Nello specifico, ogni stream deve mantenere i pixel quadrati e le proporzioni ritagliando ulteriormente in minima parte la regione di ritaglio definita. Se le proporzioni dello stream sono più larghe della regione di ritaglio, lo stream deve essere ulteriormente ritagliato verticalmente. Se le proporzioni dello stream sono più strette della regione di ritaglio, lo stream deve essere ulteriormente ritagliato orizzontalmente.

In tutti i casi, il ritaglio dello stream deve essere centrato all'interno dell'area di ritaglio completa e ogni stream deve essere ritagliato solo orizzontalmente o verticalmente rispetto all'area di ritaglio completa, mai in entrambi i modi.

Ad esempio, se sono definiti due stream, uno a 640 x 480 (formato 4:3) e uno a 1280 x 720 (formato 16:9), di seguito sono riportate le regioni di output previste per ciascun stream per alcune regioni di ritaglio di esempio, su un sensore ipotetico da 3 MP (array di 2000 x 1500 pixel).

Regione di ritaglio: (500, 375, 1000, 750) (proporzioni 4:3)
Ritaglio dello stream a 640 x 480: (500, 375, 1000, 750) (uguale alla regione di ritaglio)
Ritaglio dello stream a 1280 x 720: (500, 469, 1000, 562)

crop-region-43-ratio

Figura 1. Proporzioni di 4:3

Regione di ritaglio: (500, 375, 1333, 750) (proporzioni 16:9)
Ritaglio dello stream a 640 x 480: (666, 375, 1000, 750)
Ritaglio dello stream a 1280 x 720: (500, 375, 1333, 750) (uguale alla regione di ritaglio)

crop-region-169-ratio

Figura 2. Proporzioni di 16:9

Regione di ritaglio: (500, 375, 750, 750) (formato 1:1)
Ritaglio dello stream a 640 x 480: (500, 469, 750, 562)
Ritaglio dello stream a 1280 x 720: (500, 543, 750, 414)

crop-region-11-ratio

Figura 3. Proporzioni 1:1

Un ultimo esempio: uno stream con proporzioni quadrate di 1024 x 1024 anziché lo stream 480p:
Regione di ritaglio: (500, 375, 1000, 750) (proporzioni 4:3)
Ritaglio stream 1024 x 1024: (625, 375, 750, 750)
Ritaglio stream 1280 x 720: (500, 469, 1000, 562)

crop-region-43-square-ratio

Figura 4. Proporzioni 4:3, quadrato

Rielaborazione

Il supporto aggiuntivo per i file immagine RAW è fornito dal supporto di elaborazione per i dati Bayer RAW. Questo supporto consente alla pipeline della fotocamera di elaborare un buffer RAW e i metadati acquisiti in precedenza (un intero frame registrato in precedenza) per produrre un nuovo output YUV o JPEG visualizzato.

Zoom

Per i dispositivi con Android 11 o versioni successive, un'app può utilizzare lo zoom (digitale e ottico) di una fotocamera tramite l'impostazione ANDROID_CONTROL_ZOOM_RATIO.

Il rapporto di zoom è definito come fattore in virgola mobile. Anziché usare ANDROID_SCALER_CROP_REGION per il ritaglio e lo zoom, un'app può usare ANDROID_CONTROL_ZOOM_RATIO per controllare il livello di zoom e ANDROID_SCALER_CROP_REGION per il ritaglio orizzontale e verticale per ottenere proporzioni diverse da quelle del sensore della fotocamera nativo.

Un sistema multi-fotocamera può contenere più di un obiettivo con lunghezze focali diverse e l'utente può utilizzare lo zoom ottico passando da un obiettivo all'altro. L'utilizzo di ANDROID_CONTROL_ZOOM_RATIO presenta vantaggi nei seguenti scenari:

  • Zoom in da un obiettivo grandangolare a un teleobiettivo: un rapporto in virgola mobile offre una maggiore precisione rispetto ai valori interi di ANDROID_SCALER_CROP_REGION.
  • Lo zoom out da un obiettivo grandangolare a un obiettivo ultrawide: ANDROID_CONTROL_ZOOM_RATIO supporta lo zoom out (<1,0 f) mentre ANDROID_SCALER_CROP_REGION no.

Per fare un esempio, di seguito sono riportati diversi scenari con rapporti di zoom, regioni di ritaglio e stream di output diversi, utilizzando la stessa fotocamera ipotetica definita nella sezione precedente.

Rapporto zoom: 2,0; 1/4 del campo visivo originale
Regione di ritaglio: (0, 0, 2000, 1500) (proporzioni 4:3)
Ritaglio dello stream a 640 x 480: (0, 0, 2000, 1500) (uguale alla regione di ritaglio)
Ritaglio dello stream a 1280 x 720: (0, 187, 2000, 1125)

zoom-ratio-2-crop-43

Figura 5. Zoom 2,0, proporzioni 4:3

Rapporto zoom: 2,0; 1/4 del campo visivo originale
Regione di ritaglio: (0, 187, 2000, 1125) (proporzioni 16:9)
Ritaglio dello stream a 640 x 480: (250, 187, 1500, 1125) (con riquadri laterali)
Ritaglio dello stream a 1280 x 720: (0, 187, 2000, 1125) (uguale alla regione di ritaglio)

zoom-ratio-2-crop-169

Figura 6. Zoom 2.0, proporzioni 16:9

Rapporto zoom: 0,5; 4x del campo visivo originale (passaggio dall'obiettivo grandangolare a quello ultrawide)
Regione di ritaglio: (250, 0, 1500, 1500) (formato 1:1)
Ritaglio dello stream a 640 x 480: (250, 187, 1500, 1125) (letterbox)
Ritaglio dello stream a 1280 x 720: (250, 328, 1500, 844) (letterbox)

images/zoom-ratio-0.5-crop-11

Figura 7. Zoom 0,5, proporzioni 1:1

Come mostrato dai grafici precedenti, il sistema di coordinate della regione di ritaglio passa al campo visivo effettivo dopo lo zoom ed è rappresentato dal rettangolo con le seguenti dimensioni: (0, 0, activeArrayWith, activeArrayHeight). Lo stesso vale per le regioni AE/AWB/AF e per i volti. Questa modifica del sistema di coordinate non si applica all'acquisizione RAW e ai relativi metadati, come intrinsicCalibration e lensShadingMap.

Utilizzando lo stesso esempio ipotetico riportato sopra e supponendo che lo stream di output 1 (640 x 480) sia lo stream del mirino, lo zoom 2, 0x può essere ottenuto in due modi:

  • zoomRatio = 2.0, scaler.cropRegion = (0, 0, 2000, 1500)
  • zoomRatio = 1.0 (predefinito), scaler.cropRegion = (500, 375, 1000, 750)

Affinché un'app imposti android.control.aeRegions come il quarto superiore sinistro del campo visivo del mirino, imposta android.control.aeRegions su (0, 0, 1000, 750) con android.control.zoomRatio impostato su 2.0. In alternativa, l'app può impostare android.control.aeRegions sulla regione equivalente di (500, 375, 1000, 750) per android.control.zoomRatio di 1.0.