En esta página, se describe cómo capturar imágenes de alta calidad con CameraX. Para ello, se usa la ImageCapture clase y sus métodos asociados.
Conceptos clave
A continuación, se presentan los conceptos principales que se abordan en este documento:
- Método de almacenamiento: Puedes capturar imágenes en un búfer en la memoria o directamente en un archivo.
- Ejecutores:
ImageCaptureusa ejecutores para controlar las devoluciones de llamada y operaciones de E/S. Puedes personalizar estos ejecutores para obtener un mejor rendimiento y control. - Modos de captura: Puedes configurar el modo de captura para optimizar la latencia o la calidad de la imagen.
Método de almacenamiento
Hay dos formas de capturar imágenes con ImageCapture. Cada una usa una sobrecarga de ImageCapture.takePicture():
Archivo: Usa
takePicture(OutputFileOptions, Executor, OnImageSavedCallback)para guardar la imagen capturada directamente en un archivo en el disco.- Esta es la forma más común de capturar fotos.
En la memoria: Usa
takePicture(Executor, OnImageCapturedCallback)para recibir un búfer en la memoria de la imagen capturada.- Esto es útil para el procesamiento o el análisis de imágenes en tiempo real.
Ejecutores
Cuando llamas a takePicture, pasas un Executor y una función
OnImageCapturedCallback o OnImageSavedCallback. El Executor ejecuta la devolución de llamada y controla cualquier E/S resultante.
Tomar foto
Para tomar una foto, configura la cámara y, luego, llama a takePicture.
Configura la cámara
Para configurar la cámara, crea un CameraProvider. Luego, crea un objeto ImageCapture. Usa ImageCapture.Builder():
Kotlin
val imageCapture = ImageCapture.Builder()
.setTargetRotation(view.display.rotation)
.build()
cameraProvider.bindToLifecycle(lifecycleOwner, cameraSelector, imageCapture, preview)
Java
ImageCapture imageCapture =
new ImageCapture.Builder()
.setTargetRotation(view.getDisplay().getRotation())
.build();
cameraProvider.bindToLifecycle(lifecycleOwner, cameraSelector, imageCapture, preview);
Tomar una foto
Después de configurar la cámara, llama a takePicture() para capturar una imagen.
En este ejemplo, se muestra cómo usar takePicture() para guardar una imagen
en el disco:
Kotlin
fun onClick() {
val outputFileOptions = ImageCapture.OutputFileOptions.Builder(File(...)).build()
imageCapture.takePicture(outputFileOptions, cameraExecutor,
object : ImageCapture.OnImageSavedCallback {
override fun onError(error: ImageCaptureException)
{
// insert your code here.
}
override fun onImageSaved(outputFileResults: ImageCapture.OutputFileResults) {
// insert your code here.
}
})
}
Java
public void onClick() {
ImageCapture.OutputFileOptions outputFileOptions =
new ImageCapture.OutputFileOptions.Builder(new File(...)).build();
imageCapture.takePicture(outputFileOptions, cameraExecutor,
new ImageCapture.OnImageSavedCallback() {
@Override
public void onImageSaved(ImageCapture.OutputFileResults outputFileResults) {
// insert your code here.
}
@Override
public void onError(ImageCaptureException error) {
// insert your code here.
}
}
);
}
Estos son los puntos clave sobre este fragmento:
- El
ImageCapture.OutputFileOptionste permite configurar la ubicación de guardado y los metadatos.- Aquí, el
OutputFileOptions.Builder()usa un objetoFilepara determinar la ubicación de guardado.
- Aquí, el
- La función
takePicture()captura la imagen de forma asíncrona con las opciones y el ejecutor proporcionados. - El
OnImageSavedCallbackproporciona devoluciones de llamada para el éxito y el fracaso.- La devolución de llamada
onImageSaved()controla la captura de imágenes correcta y proporciona acceso a los resultados de la imagen guardada. - La devolución de llamada
onError()controla los errores de captura de imágenes.
- La devolución de llamada
Opciones adicionales
Consulta la guía Configura para la optimización, el flash y el formato de archivo para obtener más
formas de configurar ImageCapture.
Más recursos
Para obtener más información acerca de CameraX, consulta los siguientes recursos:
Codelab
Muestra de código