Produktneuheiten
CameraX 1.5: Leistungsstarke Videoaufzeichnung und Bildaufnahmen auf Profiniveau
Lesezeit: 7 Minuten
Das CameraX-Team freut sich, die Veröffentlichung von Version 1.5 bekanntzugeben. Dieses Update bietet Ihnen professionelle Funktionen und macht die Konfiguration der Kamerasitzung einfacher als je zuvor.
Mit der Videoaufzeichnung können Nutzer jetzt ganz einfach beeindruckende Zeitlupen- oder High-Frame-Rate-Videos aufnehmen. Außerdem können Sie mit der neuen Feature Group API komplexe Kombinationen wie 10‑Bit-HDR und 60 FPS aktivieren und so für konsistente Ergebnisse auf allen unterstützten Geräten sorgen.
Bei der Bildaufnahme bietet das Pixel 8 Pro maximale Flexibilität, da es die Aufnahme von unverarbeiteten, unkomprimierten DNG-Dateien (RAW) unterstützt. Außerdem können Sie jetzt Ultra HDR auch bei Verwendung leistungsstarker Kameraerweiterungen nutzen.
Die Grundlage für diese Funktionen ist die neue SessionConfig API, die die Einrichtung und Neukonfiguration von Kameras vereinfacht. Sehen wir uns diese neuen Funktionen nun genauer an.
Leistungsstarke Videoaufzeichnung: Hochgeschwindigkeit und Kombination von Funktionen
CameraX 1.5 bietet deutlich mehr Videofunktionen und ermöglicht so kreativere und robustere Aufnahmen.
Zeitlupe und Videos mit hoher Framerate
Eine unserer am meisten erwarteten Funktionen, die Zeitlupenvideo-Funktion, ist jetzt verfügbar. Sie können jetzt Videos mit hoher Geschwindigkeit (z.B. 120 oder 240 fps) aufnehmen und direkt in ein dramatisches Zeitlupenvideo umwandeln. Alternativ können Sie auch mit derselben hohen Framerate aufnehmen, um besonders flüssige Videos zu erhalten.
Die Implementierung ist einfach, wenn Sie mit der VideoCapture API vertraut sind.
1. Unterstützung für High-Speed prüfen:Mit der neuen Methode Recorder.getHighSpeedVideoCapabilities() können Sie abfragen, ob das Gerät diese Funktion unterstützt.
val cameraInfo = cameraProvider.getCameraInfo(cameraSelector)
val highSpeedCapabilities = Recorder.getHighSpeedVideoCapabilities(cameraInfo)
if (highSpeedCapabilities == null) {
// This camera device does not support high-speed video.
return
}
2. Anwendungsfall konfigurieren und binden:Verwenden Sie die zurückgegebene videoCapabilities (die Informationen zur unterstützten Videoqualität enthält), um eine HighSpeedVideoSessionConfig zu erstellen. Anschließend müssen Sie die unterstützten Frame-Rate-Bereiche über cameraInfo.getSupportedFrameRateRanges() abfragen und den gewünschten Bereich festlegen. Rufen Sie setSlowMotionEnabled(true) auf, um Videos in Zeitlupe aufzunehmen. Andernfalls werden Videos mit hoher Bildrate aufgenommen. Im letzten Schritt wird die reguläre Recorder.prepareRecording().start() verwendet, um die Videoaufnahme zu starten.
val preview = Preview.Builder().build()
val quality = highSpeedCapabilities
.getSupportedQualities(DynamicRange.SDR).first()
val recorder = Recorder.Builder()
.setQualitySelector(QualitySelector.from(quality)))
.build()
val videoCapture = VideoCapture.withOutput(recorder)
val frameRateRange = cameraInfo.getSupportedFrameRateRanges(
HighSpeedVideoSessionConfig(videoCapture, preview)
).first()
val sessionConfig = HighSpeedVideoSessionConfig(
videoCapture,
preview,
frameRateRange = frameRateRange,
// Set true for slow-motion playback, or false for high-frame-rate
isSlowMotionEnabled = true
)
cameraProvider.bindToLifecycle(
lifecycleOwner, cameraSelector, sessionConfig)
// Start recording slow motion videos.
val recording = recorder.prepareRecording(context, outputOption)
.start(executor, {})
Kompatibilität und Einschränkungen
Für die Hochgeschwindigkeitsaufzeichnung sind bestimmte CameraConstrainedHighSpeedCaptureSession- und CamcorderProfile-Unterstützung erforderlich. Führen Sie immer die Funktionsprüfung durch und aktivieren Sie die High-Speed-Aufnahme nur auf unterstützten Geräten, um eine schlechte Nutzererfahrung zu vermeiden. Derzeit wird diese Funktion von den Rückkameras fast aller Pixel-Geräte und ausgewählter Modelle anderer Hersteller unterstützt.
Weitere Informationen finden Sie in diesem Blogpost.
Funktionen mit Zuversicht kombinieren: Die Feature Group API
Mit CameraX 1.5 wird die Feature Group API eingeführt, mit der sich die Kompatibilität von Funktionen leichter ermitteln lässt. Basierend auf der API für die Abfrage von Funktionskombinationen in Android 15 können Sie jetzt mehrere Funktionen gleichzeitig aktivieren und so eine stabile Kamerasitzung gewährleisten. Die Funktionsgruppe unterstützt derzeit HDR (HLG), 60 fps, Vorschau-Stabilisierung und Ultra HDR. Auf Geräten der Pixel 10- und Galaxy S25-Serie können Sie beispielsweise gleichzeitig HDR, 60 fps und die Vorschau-Stabilisierung aktivieren. Es ist geplant, in Zukunft 4K-Aufnahmen und Ultraweitwinkelzoom hinzuzufügen.
Die Feature Group API ermöglicht zwei wichtige Anwendungsfälle:
Anwendungsfall 1: Priorisierung der besten Qualität
Wenn Sie die bestmögliche Kombination von Funktionen verwenden möchten, können Sie eine priorisierte Liste angeben. CameraX versucht, sie in der Reihenfolge zu aktivieren, und wählt die erste Kombination aus, die das Gerät vollständig unterstützt.
val sessionConfig = SessionConfig(
useCases = listOf(preview, videoCapture),
preferredFeatureGroup = listOf(
GroupableFeature.HDR_HLG10,
GroupableFeature.FPS_60,
GroupableFeature.PREVIEW_STABILIZATION
)
).apply {
// (Optional) Get a callback with the enabled features to update your UI.
setFeatureSelectionListener { selectedFeatures ->
updateUiIndicators(selectedFeatures)
}
}
processCameraProvider.bindToLifecycle(activity, cameraSelector, sessionConfig)
In diesem Beispiel versucht CameraX, Funktionen in dieser Reihenfolge zu aktivieren:
- HDR + 60 fps + Vorschau-Stabilisierung
- HDR + 60 fps
- HDR+ und Stabilisierung der Vorschau
- HDR
- 60 fps + Stabilisierung der Vorschau
- 60 fps
- Vorschau der Stabilisierung
- Keine
Anwendungsfall 2: Erstellen einer nutzerorientierten Einstellungs-UI
Sie können jetzt genau angeben, welche Funktionskombinationen in der Benutzeroberfläche der Einstellungen Ihrer App unterstützt werden. Dazu deaktivieren Sie die Ein/Aus-Schaltflächen für nicht unterstützte Optionen, wie im Bild unten zu sehen ist.
Mit den folgenden Codes können Sie prüfen, ob eine bestimmte Kombination von Funktionen unterstützt wird, um zu entscheiden, ob ein Schalter ausgegraut werden soll. Fragen Sie zuerst den Status jeder einzelnen Funktion ab. Sobald eine Funktion aktiviert ist, fragen Sie die verbleibenden Funktionen noch einmal ab, um zu prüfen, ob ihre Ein/Aus-Schalter aufgrund von Kompatibilitätseinschränkungen jetzt ausgegraut werden müssen.
fun disableFeatureIfNotSuported(
enabledFeatures: Set<GroupableFeature>,
featureToCheck:GroupableFeature
) {
val sessionConfig = SessionConfig(
useCases = useCases,
requiredFeatureGroup = enabledFeatures + featureToCheck
)
val isSupported = cameraInfo.isFeatureGroupSupported(sessionConfig)
if (!isSupported) {
// disable the toggle for featureToCheck
}
}
Weitere Informationen finden Sie in diesem Blogpost .
Weitere Video-Optimierungen
-
Verbesserungen bei der gleichzeitigen Verwendung von Kameras:Mit CameraX 1.5.1 können Sie jetzt die Anwendungsfälle „Vorschau“, „Bildaufnahme“ und „Videoaufnahme“ gleichzeitig für jede SingleCameraConfig im Nicht-Kompositionsmodus binden. Außerdem können Sie im Kompositionsmodus (dieselben Anwendungsfälle wie bei CompositionSettings) jetzt die
CameraEffectfestlegen, die auf das endgültige Kompositionsergebnis angewendet wird. -
Dynamische Stummschaltung:Sie können jetzt eine Aufnahme mit
PendingRecording.withAudioEnabled(boolean initialMuted)stummgeschaltet starten und dem Nutzer erlauben, die Stummschaltung später mitRecording.mute(boolean muted)aufzuheben. -
Verbesserte Verarbeitung von unzureichendem Speicherplatz:CameraX gibt jetzt zuverlässig den Fehler
VideoRecordEvent.Finalize.ERROR_INSUFFICIENT_STORAGEaus, sodass Ihre App Situationen mit wenig Speicherplatz ordnungsgemäß verarbeiten und den Nutzer informieren kann. - Low Light Boost:Auf unterstützten Geräten (z. B. der Pixel 10-Serie) können Sie CameraControl.enableLowLightBoostAsync aktivieren, um die Vorschau- und Videostreams in dunklen Umgebungen automatisch aufzuhellen.
Professionelle Bilderfassung
CameraX 1.5 bietet wichtige Verbesserungen für ImageCapture für Entwickler, die maximale Qualität und Flexibilität benötigen.
Kreative Kontrolle mit DNG-Aufnahmen (RAW)
Für die vollständige Kontrolle über die Nachbearbeitung unterstützt CameraX jetzt die DNG-Aufnahme (RAW). So haben Sie Zugriff auf die unbearbeiteten, unkomprimierten Bilddaten direkt vom Kamerasensor und können professionelle Bearbeitungen und Farbkorrekturen vornehmen. Die API unterstützt das Aufnehmen der DNG-Datei allein oder das gleichzeitige Aufnehmen von JPEG- und DNG-Ausgaben. Im Beispielcode unten sehen Sie, wie Sie JPEG- und DNG-Dateien gleichzeitig aufnehmen.
val capabilities = ImageCapture.getImageCaptureCapabilities(cameraInfo)
val imageCapture = ImageCapture.Builder().apply {
if (capabilities.supportedOutputFormats
.contains(OUTPUT_FORMAT_RAW_JPEG)) {
// Capture both RAW and JPEG formats.
setOutputFormat(OUTPUT_FORMAT_RAW_JPEG)
}
}.build()
// ... bind imageCapture to lifecycle ...
// Provide separate output options for each format.
val outputOptionRaw = /* ... configure for image/x-adobe-dng ... */
val outputOptionJpeg = /* ... configure for image/jpeg ... */
imageCapture.takePicture(
outputOptionRaw,
outputOptionJpeg,
executor,
object : ImageCapture.OnImageSavedCallback {
override fun onImageSaved(results: OutputFileResults) {
// This callback is invoked twice: once for the RAW file
// and once for the JPEG file.
}
override fun onError(exception: ImageCaptureException) {}
}
)
Ultra HDR für Kamera-Erweiterungen
Sie erhalten das Beste aus zwei Welten: die beeindruckende computergestützte Fotografie von Kameraerweiterungen (z. B. Nachtmodus) in Kombination mit den brillanten Farben und dem Dynamikumfang von Ultra HDR. Diese Funktion wird jetzt auf vielen aktuellen Premium-Android-Smartphones unterstützt, z. B. auf der Pixel 9‑/10‑Serie und der Samsung S24‑/S25‑Serie.
// Support UltraHDR when Extension is enabled.
val extensionsEnabledCameraSelector = extensionsManager
.getExtensionEnabledCameraSelector(
CameraSelector.DEFAULT_BACK_CAMERA, ExtensionMode.NIGHT)
val imageCapabilities = ImageCapture.getImageCaptureCapabilities(
cameraProvider.getCameraInfo(extensionsEnabledCameraSelector)
val imageCapture = ImageCapture.Builder()
.apply {
if (imageCapabilities.supportedOutputFormats
.contains(OUTPUT_FORMAT_JPEG_ULTRA_HDR) {
setOutputFormat(OUTPUT_FORMAT_JPEG_ULTRA_HDR)
}
}.build()
Verbesserungen bei der Core API und der Nutzerfreundlichkeit
Neue Konfigurationsmöglichkeiten: SessionConfig
Wie in den obigen Beispielen zu sehen ist, ist SessionConfig ein neues Konzept in CameraX 1.5. Die Konfiguration wird zentralisiert und die API wird auf zwei wichtige Arten vereinfacht:
-
Keine manuellen
unbind()Aufrufe mehr:CameraX-APIs sind lebenszyklusbezogen. Die Anwendungsfälle werden implizit „entbunden“, wenn die Aktivität oder andereLifecycleOwnerzerstört werden. Wenn Sie jedoch Anwendungsfälle aktualisieren oder Kameras wechseln möchten, müssen Sieunbind()oderunbindAll()anrufen, bevor Sie die Geräte neu verknüpfen. Wenn Sie jetzt mit CameraX 1.5 ein neuesSessionConfigbinden, wird die Sitzung von CameraX nahtlos aktualisiert. Aufrufe zum Aufheben der Bindung sind nicht mehr erforderlich. -
Deterministische Steuerung der Framerate:Die neue
SessionConfig-API bietet eine deterministische Möglichkeit zur Verwaltung der Framerate. Im Gegensatz zur vorherigensetTargetFrameRate, die nur ein Hinweis war, garantiert diese neue Methode, dass der angegebene Bereich für die Bildrate bei erfolgreicher Konfiguration angewendet wird. Um die Genauigkeit zu gewährleisten, müssen Sie unterstützte Framerates mitCameraInfo.getSupportedFrameRateRanges(SessionConfig)abfragen. Wenn Sie die vollständigeSessionConfigübergeben, kann CameraX die unterstützten Bereiche anhand der Streamkonfigurationen genau bestimmen.
Camera-Compose ist jetzt stabil
Wir wissen, wie gern Sie Jetpack Compose verwenden. Deshalb freuen wir uns, Ihnen mitteilen zu können, dass die camera-compose-Bibliothek jetzt in der stabilen Version 1.5.1 verfügbar ist. Diese Version enthält wichtige Fehlerkorrekturen im Zusammenhang mit der Verwendung von CameraXViewfinder mit Compose-Funktionen wie moveableContentOf und Pager sowie die Behebung eines Problems mit der Vorschau. Wir werden camera-compose in zukünftigen Versionen um weitere Funktionen ergänzen.
Verbesserungen bei der Bildanalyse und Kamerasteuerung
- Anpassen der Taschenlampenhelligkeit:Mit neuen APIs können Sie die Helligkeit der Taschenlampe des Geräts genau anpassen. Sie können die maximal unterstützte Stärke mit CameraInfo.getMaxTorchStrengthLevel() abfragen und dann die gewünschte Stärke mit CameraControl.setTorchStrengthLevel() festlegen.
-
NV21-Unterstützung in
ImageAnalysis:Sie können das NV21-Bildformat jetzt direkt überImageAnalysisanfordern. Dadurch wird die Integration mit anderen Bibliotheken und APIs vereinfacht. Dies wird durch Aufrufen vonImageAnalysis.Builder.setOutputImageFormat(OUTPUT_IMAGE_FORMAT_NV21)ermöglicht.
Jetzt loslegen
Aktualisieren Sie Ihre Abhängigkeiten noch heute auf CameraX 1.5 und probieren Sie die neuen Funktionen aus. Wir sind gespannt darauf, was Sie damit alles anstellen.
Wenn Sie CameraX 1.5 verwenden möchten, fügen Sie Ihrer Datei „libs.versions.toml“ die folgenden Abhängigkeiten hinzu. Wir empfehlen die Verwendung von Version 1.5.1, da sie viele kritische Fehlerkorrekturen und Verbesserungen für die gleichzeitige Verwendung mehrerer Kameras enthält.
[versions]
camerax = "1.5.1"
[libraries]
..
androidx-camera-core = { module = "androidx.camera:camera-core", version.ref = "camerax" }
androidx-camera-compose = { module = "androidx.camera:camera-compose", version.ref = "camerax" }
androidx-camera-view = { module = "androidx.camera:camera-view", version.ref = "camerax" }
androidx-camera-lifecycle = { group = "androidx.camera", name = "camera-lifecycle", version.ref = "camerax" }
androidx-camera-camera2 = { module = "androidx.camera:camera-camera2", version.ref = "camerax" }
androidx-camera-extensions = { module = "androidx.camera:camera-extensions", version.ref = "camerax" }
Fügen Sie diese dann den Abhängigkeiten in der Datei „build.gradle.kts“ Ihres Moduls hinzu:
dependencies {
..
implementation(libs.androidx.camera.core)
implementation(libs.androidx.camera.lifecycle)
implementation(libs.androidx.camera.camera2)
implementation(libs.androidx.camera.view) // for PreviewView
implementation(libs.androidx.camera.compose) // for compose UI
implementation(libs.androidx.camera.extensions) // For Extensions
}
Haben Sie Fragen oder möchten Sie sich mit dem CameraX-Team in Verbindung setzen? Treten Sie dem CameraX-Entwicklerforum bei oder reichen Sie einen Fehlerbericht ein:
Weiterlesen
-
Produktneuheiten
Android Studio Panda 4 ist jetzt stabil und kann für die Produktion verwendet werden. Diese Version bietet den Planungsmodus, die Vorhersage des nächsten Bearbeitungsschritts und weitere Funktionen, die das Erstellen hochwertiger Android-Apps noch einfacher machen.
Matt Dyor • Lesezeit: 5 Minuten
-
Produktneuheiten
Wenn Sie Android-Entwickler sind und innovative KI-Funktionen in Ihre App einbinden möchten, haben wir vor Kurzem leistungsstarke neue Updates eingeführt.
Thomas Ezan • Lesezeit: 3 Minuten
-
Produktneuheiten
Android 17 hat Beta 4 erreicht, die letzte geplante Betaversion dieses Releasezyklus. Das ist ein wichtiger Meilenstein für die App-Kompatibilität und die Stabilität der Plattform.
Daniel Galpin • Lesezeit: 4 Minuten
Auf dem Laufenden bleiben
Lassen Sie sich Woche für Woche die neuesten Informationen zur Android-Entwicklung zusenden.