CameraX
Esta tabela lista todos os artefatos no grupo androidx.camera
.
Artefato | Versão estável | Versão candidata a lançamento | Versão Beta | Versão Alfa |
---|---|---|---|---|
camera-camera2 | 1.3.4 | 1.4.0-rc01 | - | 1.5.0-alpha01 |
camera-core | 1.3.4 | 1.4.0-rc01 | - | 1.5.0-alpha01 |
efeitos de câmera | - | 1.4.0-rc01 | - | 1.5.0-alpha01 |
camera-extensions | 1.3.4 | 1.4.0-rc01 | - | 1.5.0-alpha01 |
camera-lifecycle | 1.3.4 | 1.4.0-rc01 | - | 1.5.0-alpha01 |
camera-mlkit-vision | - | 1.4.0-rc01 | - | 1.5.0-alpha01 |
camera-view | 1.3.4 | 1.4.0-rc01 | - | 1.5.0-alpha01 |
visor da câmera | - | - | 1.3.0-beta02 | 1.4.0-alpha07 |
camera-video | 1.3.4 | 1.4.0-rc01 | - | 1.5.0-alpha01 |
Teste de dispositivo
A CameraX é testada em vários dispositivos no nosso laboratório. Para ver uma lista dos dispositivos no laboratório atualmente, consulte Dispositivos da CameraX testados no laboratório.
Declarar dependências
Para adicionar uma dependência à CameraX, é preciso adicionar o repositório Maven do Google ao projeto. Leia Repositório Maven do Google para ver mais informações.
Adicione as dependências dos artefatos necessários no arquivo build.gradle
para seu app ou módulo:
Groovy
dependencies { // CameraX core library using the camera2 implementation def camerax_version = "1.5.0-alpha01" // The following line is optional, as the core library is included indirectly by camera-camera2 implementation "androidx.camera:camera-core:${camerax_version}" implementation "androidx.camera:camera-camera2:${camerax_version}" // If you want to additionally use the CameraX Lifecycle library implementation "androidx.camera:camera-lifecycle:${camerax_version}" // If you want to additionally use the CameraX VideoCapture library implementation "androidx.camera:camera-video:${camerax_version}" // If you want to additionally use the CameraX View class implementation "androidx.camera:camera-view:${camerax_version}" // If you want to additionally add CameraX ML Kit Vision Integration implementation "androidx.camera:camera-mlkit-vision:${camerax_version}" // If you want to additionally use the CameraX Extensions library implementation "androidx.camera:camera-extensions:${camerax_version}" }
Kotlin
dependencies { // CameraX core library using the camera2 implementation val camerax_version = "1.5.0-alpha01" // The following line is optional, as the core library is included indirectly by camera-camera2 implementation("androidx.camera:camera-core:${camerax_version}") implementation("androidx.camera:camera-camera2:${camerax_version}") // If you want to additionally use the CameraX Lifecycle library implementation("androidx.camera:camera-lifecycle:${camerax_version}") // If you want to additionally use the CameraX VideoCapture library implementation("androidx.camera:camera-video:${camerax_version}") // If you want to additionally use the CameraX View class implementation("androidx.camera:camera-view:${camerax_version}") // If you want to additionally add CameraX ML Kit Vision Integration implementation("androidx.camera:camera-mlkit-vision:${camerax_version}") // If you want to additionally use the CameraX Extensions library implementation("androidx.camera:camera-extensions:${camerax_version}") }
Feedback
Seu feedback ajuda a melhorar o Jetpack. Avise se você descobrir novos problemas ou tiver ideias para melhorar esta biblioteca. Consulte os problemas conhecidos nesta biblioteca antes de criar um novo. Adicione seu voto a um problema clicando no botão de estrela.
Consulte a documentação do Issue Tracker para saber mais.
Camera Viewfinder: versão 1.0 do Compose
Versão 1.0.0-alpha02
12 de junho de 2024
Lançamento de androidx.camera:camera-viewfinder-compose:1.0.0-alpha02
. A versão 1.0.0-alpha02 contém estas confirmações.
Versão 1.0.0-alpha01
14 de maio de 2024
Lançamento de androidx.camera:camera-viewfinder-compose:1.0.0-alpha01
. A versão 1.0.0-alpha01 contém estas confirmações.
Novos recursos
- Nova biblioteca. Essa biblioteca apresenta um elemento combinável de visor nativo do Compose, que pode ser usado com o CameraX e o Camera2. O visor combinável oferece suporte a diferentes proporções e processamento de eventos de toque.
Visor da câmera versão 1.4
Versão 1.4.0-alpha07
12 de junho de 2024
Lançamento de androidx.camera:camera-viewfinder:1.4.0-alpha07
e androidx.camera:camera-viewfinder-core:1.4.0-alpha07
. A versão 1.4.0-alpha07 contém estas confirmações.
Versão 1.4.0-alpha06
14 de maio de 2024
Lançamento de androidx.camera:camera-viewfinder:1.4.0-alpha06
e androidx.camera:camera-viewfinder-core:1.4.0-alpha06
. A versão 1.4.0-alpha06 contém estas confirmações.
Mudanças na API
- Renomeação de tipos enumerados
ImplementationMode
deViewfinder
para refletir melhor as implementações subjacentes e adicionar constantes fixas paraTransformationInfo.sourceRotation
(Ic6149). ZoomGestureDetector.ZoomEvent
foi adicionado para encapsular os estados de um gesto de zoom. (I84cdf).
Camera versão 1.5
Versão 1.5.0-alpha01
4 de setembro de 2024
Lançamento de androidx.camera:camera-*:1.5.0-alpha01
. A versão 1.5.0-alpha01 contém estas confirmações.
Mudanças na API
- Fornece uma API para definir configurações de composição para captura de vídeo com duas câmeras simultâneas. As configurações incluem o valor Alfa para mesclagem, deslocamento nas coordenadas X e Y, escala da largura e altura da janela de exibição do frame da câmera. O deslocamento, a largura e a altura são especificados em coordenadas de dispositivo normalizadas. (Ia2b8a).
CameraProvider.getCameraInfo
foi exposto para ser uma API formal. (I901cd).- A API
PendingRecording.withAudioEnabled(boolean initialMuted)
foi adicionada para controlar o estado inicial de silenciamento. (I635c3, b/354829267).
Correções de bugs
- A falha quando
bindToLifecycle
é invocada com umaLifecycleOwner
destruída foi corrigida (I6e6d8). - A prévia fixa mostra uma tela preta na câmera frontal ao vincular com
VideoCapture
no Motorola Edge 20 Fusion. (I1fe88). - A configuração foi otimizada para detectar gestos de zoom em
PreviewView
e melhorar a suavidade. (I04ffc).
Camera versão 1.4
Versão 1.4.0-rc01
7 de agosto de 2024
Lançamento de androidx.camera:camera-*:1.4.0-rc01
. A versão 1.4.0-rc01 contém estas confirmações.
Novos recursos
- Adição experimental
CameraInfo.getCameraInfo
para fornecer informações específicas da câmera sem a necessidade de vincular casos de uso à câmera (I550d1).
Mudanças na API
- Adição das APIs
PreviewView.getScreenFlash
ePreviewView.setScreenFlashOverlayColor
para casos em queScreenFlashView
não é adicionado explicitamente (I43945).
Correções de bugs
- Correção de problemas de exposição e tonalidade de cor quando a imagem capturada com flash ativado sob pouca luz e com limite de caso de uso da VideoCapture. (Ic9814).
- Corrija o problema em que a interrupção de uma solicitação
takePicture
com extensões ativadas causa falha em gerar um resultado, e a próxima solicitaçãotakePicture
pode não funcionar mais. (Iae78f). - Correção de um problema de vazamento de memória que ocorre quando as extensões estão ativadas. (Iab276).
- Resolução de uma falha nas extensões do CameraX em dispositivos como Pixel 7/8 e Samsung Galaxy da série S24. O erro, decorrente de um problema de conversão de
Camera2OutputConfigImpl
no modo de lançamento, surgiu após fazer upgrade do AGP para a versão 8.5.1 e ativar a minificação. (I99598, b/354824993).
Versão 1.4.0-beta02
12 de junho de 2024
Lançamento de androidx.camera:camera-*:1.4.0-beta02
. A versão 1.4.0-beta02 contém estas confirmações.
Mudanças na API
- Semelhante a
VideoCapture
, adicionesetMirrorMode
para o caso de uso de Prévia. Ele vai oferecer suporte ao modo espelhado ativado e desativado para o stream de pré-visualização viaOutputConfiguration.setMirrorMode
da API 33 e mais recentes. Para APIs mais antigas, ele não vai ter operação. (I821f4).
Correções de bugs
- Foi corrigido o problema que impedia os apps de tirar fotos no Samsung Tab A8 quando
ImageCapture
selecionava 1920 x 1080 na combinaçãoPreview
+VideoCapture
+ImageCapture
UseCase
(I5a463, b/336925549). - Correção da gravação persistente que pode falhar em continuar gravando depois de trocar de câmera (Icb0a1).
Versão 1.4.0-beta01
14 de maio de 2024
Lançamento de androidx.camera:camera-*:1.4.0-beta01
. A versão 1.4.0-beta01 contém estas confirmações.
Mudanças na API
ZoomGestureDetector.ZoomEvent
foi adicionado para encapsular os estados de um gesto de zoom. (I84cdf).
Correções de bugs
- Foi corrigido um bug que ainda capturava e o "toque para focar" não usava os valores do modo de estabilização/QPS de solicitação repetida, o que poderia recriar a sessão de captura e causar problemas de latência ou congelamento da visualização em alguns dispositivos (I7dc0b).
- Correção de um bug em que as resoluções de alta resolução não eram selecionadas quando o
CameraEffect
estava ativado em alguns dispositivos. (por exemplo, 4000 x 3000 no Samsung A32 5G). (Ie3ed3, b/337336152). - Correção de uma falha ao tirar fotos com a visualização.
ImageCapture
eVideoCapture(UHD)
estão vinculados à API 29 do Pixel 4XL. (I5b288). - Suporte a dispositivos virtuais: o contexto transmitido para
ProcessCameraProvider
vai preservar o ID do dispositivo para garantir a funcionalidade em um ambiente de dispositivo virtual. (I5ba48).
Versão 1.4.0-alpha05
17 de abril de 2024
Lançamento de androidx.camera:camera-*:1.4.0-alpha05
. A versão 1.4.0-alpha05 contém estas confirmações.
Novos recursos
- Conversão de
ProcessCameraProvider
em implementação em Kotlin. (I46d4f). - Foram adicionadas funções de suspensão
ImageCapture.takePicture
para permitir que ela seja chamada de maneira idiomática para o Kotlin. (I920be).
Mudanças na API
- Adicionamos APIs de formato de saída a
ImageCapture
e o métodogetSupportedOutputFormats
aImageCaptureCapabilities
para consultar a capacidade do dispositivo. O valor do formato de saída padrão éOUTPUT_FORMAT_JPEG
, que captura imagens SDR em formato JPEG. Se o dispositivo tiver suporte a Ultra HDR e o formato de saída estiver definido comoOUTPUT_FORMAT_JPEG_ULTRA_HDR
, o CameraX vai capturar imagens compactadas em Ultra HDR usando o formato de imagem JPEG/R. O formato é compatível com versões anteriores do formato SDR JPEG e oferece suporte à renderização de conteúdo HDR. Isso significa que em aplicativos ou dispositivos mais antigos, as imagens aparecem perfeitamente como JPEG normal; em apps e dispositivos que foram atualizados para oferecer suporte total ao formato, as imagens vão aparecer como HDR. (I5de50). - Adição de
PhysicalCameraInfo
emCameraInfo
para consultar informações da câmera física e adicionar setter/getter do ID da câmera física emCameraSelector
(Ic5b90). CameraController#COORDINATE_SYSTEM_VIEW_REFERENCED
foi substituída porImageAnalysis#COORDINATE_SYSTEM_VIEW_REFERENCED
. O valor da constante permanece o mesmo. Isso serve para consolidar todas as constantes em um só lugar. (I890bb).- A nova API
RetryPolicy
permite que os desenvolvedores personalizem o comportamento de repetição para a inicialização do CameraX. (I36dd2). - A criação do objeto
ImageCaptureLatencyEstimate
foi ativada para ajudar na capacidade de teste (Iaba99). - Adicione um
ImageAnalysis#COORDINATE_SYSTEM_SENSOR
. Quando usado, oMlKitAnalyzer
retorna coordenadas no sistema de coordenadas do sensor da câmera. (I3ec61). - API de metadados de extensões expostas. As novas interfaces
CameraExtensionsInfo
eCameraExtensionsControl
permitem que os aplicativos monitorem e ajustem as configurações de força da extensão. Os aplicativos podem buscar a instânciaCameraExtensionsInfo
ouCameraExtensionsControl
usando os métodosExtensionsManager#getCameraExtensionsInfo()
ouExtensionsManager#getCameraExtensionsControl()
recém-adicionados. (I28e1a). - Adição de
ProcessCameraProvider.awaitInstance
, que é uma versão de suspensão deProcessCameraProvider.getInstance
(Ib22b9). - Adicione uma API
PreviewView#getSensorToViewTransform()
. A matriz representa a transformação das coordenadas do sensor da câmera para as coordenadas dePreviewView
. Isso pode ser usado para transformar coordenadas de umaUseCase
para outra. Por exemplo, a transformação das coordenadas dos objetos detectados emImageAnalysis
em uma sobreposição dePreviewView
. (I947ab). - Torne a API
camera-viewfinder-core
mais genérica para que possa ser usada porcamera-viewfinder
ecamera-viewfinder-compose
. (I1e295). - Adicione a função
getSurface
aViewfinderSurfaceRequest
. (I781a0). - Use
camera-viewfinder-core
emcamera-viewfinder
e descontinueViewfinderSurfaceRequest
eCameraViewfinder
. (I6198c). - Adição de
ZoomGestureDetector
, que interpreta gestos de dimensionamento configurados especificamente para a atividade de pinça para aplicar zoom. (Ifafbf).
Correções de bugs
- Correção de
ImageAnalysis
min problema de seleção de resolução relacionado à configuração de resolução de destino padrão do analisador: a resolução alvo foi mantida incorretamente como 640 x 480, mesmo que os aplicativos tenham definido uma configuração de resolução padrão do analisador. Se os aplicativos tiverem esse problema (1.3.0 a 1.3.2) e não puderem fazer upgrade para usar as versões mais recentes que contêm a solução, defina diretamente umaResolutionSelector
com a resolução preferencial e umaAspectRatioStrategy
correspondente àUseCase
ImageAnalysis
. (I81f72, b/330091012). - Correção de um problema em que a solicitação
takePicture
na fila pode não ser executada se a solicitação atual falhar. (Ie0801). - Faça a verificação de dados JPEG inválidos aplicada aos dispositivos Vivo X60 e X60 Pro. Isso pode corrigir problemas de imagem muito grandes nesses dispositivos. (I82247, b/288828159).
- Correção do problema de metadados de imagem JPEG incorretos em dispositivos Samsung A24 Com a correção, o CameraX pode salvar a imagem JPEG ou objetos bitmap corretos podem ser retornados ao chamar a função
ImageProxy.toBitmap()
em dispositivos Samsung A24. (I8d6eb, b/309005680). - Faça a verificação de dados JPEG inválidos se ela for maior que 10 MB em todos os dispositivos Samsung. Isso pode corrigir problemas de imagens extraordinariamente grandes em dispositivos Samsung. (Ic2a65, b/288828159).
- O suporte a
ImageAnalysis
foi removido nas extensões do CameraX em todos os OEMs As implementações de extensões não funcionam bem comImageAnalysis
e podem causar problemas inconsistentes. (I2d926).
Versão 1.4.0-alpha04
24 de janeiro de 2024
Lançamento de androidx.camera:camera-*:1.4.0-alpha04
. A versão 1.4.0-alpha04 contém estas confirmações.
Novos recursos
- Novo artefato: efeitos de câmera: uma biblioteca para aplicar efeitos em tempo real à saída da CameraX, incluindo
Preview
,VideoCapture
e/ouImageCapture
. Esse artefato contém implementações OpenGL da APICameraEffect
que manipula a saída da câmera de forma eficiente. OverlayEffect
: para desenhar sobreposições com a API Canvas do Android. Isso permite que o app aplique uma marca-d'água ou destaque objetos detectados nas saídas da câmera.- APIs
DynamicRange
para o caso de uso de visualização: o intervalo dinâmico agora pode ser definido no caso de uso de visualização, independentemente do caso de uso de vídeo. Isso permite faixas dinâmicas em HDR, como HLG10, apenas para visualização. Novas APIs também estão disponíveis noCameraInfo
para consultar quais intervalos dinâmicos são compatíveis com cada câmera.
Mudanças na API
ScreenFlashUiCompleter
foi renomeado comoScreenFlashListener
, eScreenFlashUiCompleter#getExpirationTimeMillis
foi movido para o parâmetroexpirationTimeMillis
deScreenFlash#apply
. (I13944).- Novas APIs adicionadas para permitir que o intervalo dinâmico seja definido no caso de uso da Prévia e para consultar intervalos dinâmicos compatíveis com cada câmera. Isso permite que os intervalos dinâmicos de HDR, como HLG10, sejam usados apenas com o caso de uso da Preview, não exigem mais que um
VideoCapture
seja vinculado ao mesmo tempo. (If25e3). getMirroring()
foi renomeado comoisMirroring()
(I47063).- Adição de suporte à estimativa de latência de captura estática em tempo real no CameraX. As extensões de câmera permitem que os aplicativos usem uma API que fornece uma estimativa de quanto tempo uma captura levará. A estimativa leva em conta as condições atuais do ambiente, o estado da câmera e inclui o tempo gasto no processamento de solicitações de captura de vários frames e o tempo adicional para codificar os buffers processados, se necessário. (I05c3a).
ScreenFlashUiControl
foi renomeado comoScreenFlash
,ScreenFlashUiControl#applyScreenFlashUi
comoScreenFlash#apply
,ScreenFlashUiControl#clearScreenFlashUi
comoScreenFlash#clear
e o métodogetScreenFlashUiApplyTimeoutSeconds
foi adicionado em vez de exporSCREEN_FLASH_UI_APPLY_TIMEOUT_SECONDS
diretamente (Iccdd0).
Correções de bugs
- Correção de um vazamento de memória que fazia com que atividades ou fragmentos não fossem liberados quando as extensões estavam ativadas (I14215).
- Correção do problema em que
getZoomRatio
retornava incorretamente um valor reduzido ao aplicar uma proporção de zoom crescente (I4aa0d, b/317543616). - O evento
ImageCapture#ScreenFlash#clear
é invocado imediatamente quandoImageCapture
é desvinculado ou a câmera é fechada. Isso também corrige alguns bugs em que ele nunca é invocado, já que as capturas não são concluídas corretamente nesses cenários. (If99f9). - Foi corrigida a falha que ocorre quando o ciclo de vida é interrompido antes da conclusão da solicitação
takePicture
(Idf017, b/306202751). - Foi corrigido o problema em que a visualização da câmera ficava preta quando as extensões eram ativadas em alguns dispositivos (I1ffd0).
- Corrigimos a duração incorreta da gravação de vídeo em dispositivos que usavam o SoC Snap Dragon 778G. (If6aa7, b/316057919).
Versão 1.4.0-alpha03
13 de dezembro de 2023
Lançamento de androidx.camera:camera-*:1.4.0-alpha03
. A versão 1.4.0-alpha03 contém estas confirmações.
Novos recursos
CameraInfo.mustPlayShutterSound
foi adicionado para informar se o som de um obturador precisa ser reproduzido de acordo com as restrições regionais. (Ifda84).OnImageCapturedCallback.onCaptureStarted
eOnImageSavedCallback.onCaptureStarted
foram adicionados para notificar quando a câmera começou a expor um frame. É recomendável reproduzir o som ou a animação do obturador nesse momento. (Ic49b3).- Foi adicionado suporte ao recurso Flash da tela no CameraX para captura de imagem da câmera frontal. O CameraX cuidará do processamento da API do lado do framework e sincronizará o tempo com as mudanças da interface do aplicativo conforme necessário (por exemplo, o acionador de pré-captura AE após a mudança de cor/brilho da tela do app). Os apps só vão precisar adicionar as implementações da interface na interface
ScreenFlashUiControl
fornecida ao CameraX. (I8ae84). - Foi adicionado suporte à implementação da interface do recurso Screen Flash no CameraX. Os apps vão ter uma implementação básica de
ImageCapture.ScreenFlashUiControl
usando oPreviewView
ou aScreenFlashView
recém-adicionada, que vai adicionar uma visualização de sobreposição monocolorida e maximizar o brilho da tela durante a captura de fotos com flash da tela. (I1810e).
Mudanças na API
- Suporte a novos recursos de extensões(postview e captura do progresso do processo): foram adicionadas APIs
ImageCapture#getImageCaptureCapabilities()
para que os apps consultem os recursos da pós-visualização e capturem o callback do progresso do processo. Os apps podem ativar a pós-visualização usando aImageCapture.Builder#setPostviewEnabled()
. O tamanho da pós-visualização pode ser selecionado usandoImageCapture.Builder#setPostviewResolutionSelector()
. Ao invocartakePicture()
,onPostviewBitmapAvailable
eonCaptureProcessProgressed
podem ser implementados emOnImageSavedCallback
ouOnImageCapturedCallback
para receber a pós-visualização e a notificação de progresso do processo, se houver suporte. (I5cd88). - APIs para calcular a transformação de coordenadas do sensor para o buffer atual, com uma sinalização indicando se a Surface contém as informações de orientação da câmera. (I59096).
- A API foi exposta para consultar
PreviewCapabitlity
na visualizaçãoUseCase
. (Ie5b6c). - Foram adicionadas APIs para oferecer suporte a mais qualidades para
VideoCapture
.Recorder.Builder#setVideoCapabilitiesSource(int)
pode ser usado comVIDEO_CAPABILITIES_SOURCE_CODEC_CAPABILITIES
para criar uma instância deRecorder
que ofereça suporte a mais qualidades do queVIDEO_CAPABILITIES_SOURCE_CAMCORDER_PROFILE
. Um caso de uso comum é quando o aplicativo tenta gravar vídeos em Ultra HD sempre que possível, mas oCamcorderProfile
do dispositivo não inclui configurações UHD, mesmo que o codec seja capaz de gravar vídeos em Ultra HD. (Iedbe2, b/263961771). - Adição de getter/setter do formato de saída
ImageAnalysis
aCameraController
(I9a96c, b/308240643).
Correções de bugs
- Da Câmera
1.3.1
: melhoramos o desempenho doProcessCameraProvider#bindToLifecycle()
. A principal mudança é otimizar o processo de identificação das combinações de tamanho mais adequadas paraUseCases
. Os resultados ideais variam de acordo com as combinações específicas deUseCase
e o número de tamanhos de saída compatíveis com os dispositivos de destino. (I454f2). - Permitir o uso de
VideoCapture
quando as extensões estiverem ativadas. (I91f32). - Corrigimos o problema de imagem JPEG grande capturada em dispositivos Samsung A71 e M51. As imagens JPEG capturadas contêm dados de preenchimento redundantes de 0 no segmento de dados compactado com JFIF. Isso faz com que as imagens capturadas tenham um tamanho de arquivo extremo. Esses dados de preenchimento do 0 redundante serão removidos para fazer com que as imagens capturadas tenham tamanhos de arquivo de imagem normais. (I01afc, b/288828159).
- Desative o suporte a
ImageAnalysis
nos Pixels para evitar o bug no Pixel que retorna acidentalmente os tamanhos com suporte deImageAnalysis
não vazios. (I7ec31). - Corrigimos o problema de desempenho em que o carregamento da CPU e o consumo de energia aumentavam quando as extensões estavam ativadas. (Ibdccb).
- O Snap Dragon 480 foi adicionado ao
CameraUseInconsistentTimebaseQuirk
. Isso corrige um problema no Android 12 em dispositivos que usam esse chipset, em que o áudio nas gravações é compensado pela quantidade de tempo que o dispositivo fica no estado suspenso. (I58010).
Versão 1.4.0-alpha02
18 de outubro de 2023
Lançamento de androidx.camera:camera-*:1.4.0-alpha02
. A versão 1.4.0-alpha02 contém estas confirmações.
Mudanças na API
- Renomeie a API como
setCameraOpenRetryMaxTimeoutInMillisWhileResuming
e o argumento. (I72370). - APIs foram adicionadas para consultar a capacidade do dispositivo e ativar a estabilização de vídeo/visualização. (I87544).
- Fornece uma API para personalizar o tempo limite máximo de abertura da câmera. (I0c642).
- A
ProcessCameraProvider.shutdownAsync
foi lançada como uma API de teste pública para permitir que o provedor de câmera de processo seja usado em conjuntos de testes que podem precisar inicializar o CameraX de maneiras diferentes entre os testes. (I9eca7). - Foram adicionadas APIs para configurar o intervalo dinâmico de captura de vídeo, o frame rate e o modo espelhado. (Ifb8f7).
- Descontinuação do uso do
OutputSize
e o substitua porResolutionSelector
.ResolutionSelector
é uma maneira mais abrangente de selecionar resoluções e compatível com a API Camera-Core. (I93abd, b/286801438).
Correções de bugs
- Foi corrigido o problema de visualização preta no Samsung Galaxy S23 Ultra 5G quando o Extensions Bokeh ou o retoque facial estava ativado com
ImageAnalysis
na câmera traseira (I2e8b1). - Correção de problemas de visualização e
VideoCapture
estendidos no Moto E5 Play. (73dce2).
Versão 1.4.0-alpha01
20 de setembro de 2023
Lançamento de androidx.camera:camera-*:1.4.0-alpha01
. A versão 1.4.0-alpha01 contém estas confirmações.
Mudanças na API
- Foi adicionada uma nova API para acessar informações de amplitude de áudio durante a gravação. (Id4925).
Correções de bugs
- Melhore a estabilidade das extensões, garantindo que os eventos de inicialização e desinicialização sejam acionados na ordem correta. (Ib3b8e).
- Foi corrigida a falha na configuração da sessão de captura por exceder a combinação de superfícies com suporte devido à adição de mais superfícies repetidas internamente (Id718c).
- Correção do problema de imagem JPEG grande capturada no dispositivo Vivo S16 As imagens JPEG capturadas contêm dados de preenchimento redundantes de 0 no segmento de dados compactado com JFIF. Isso faz com que as imagens capturadas tenham um tamanho de arquivo grande. Esses dados de preenchimento do 0 redundante serão removidos para fazer com que as imagens capturadas tenham tamanhos de arquivo de imagem normais. (I79505, b/299069235).
- Foi corrigido o problema em que
ImageAnalysis
não podia ser vinculado aImageCapture
e a uma visualização quando alguns modos de extensão estavam ativados em alguns dispositivos A correção vai retornar o valor correto quando os apps consultarem a disponibilidade doImageAnalysis
usandoExtensionsManager#isImageAnalysisSupported()
. (I7d538). - Atualize o JavaDoc para corresponder ao comportamento. Em vez de concluir imediatamente,
#setZoomRatio
,#setLinearZoom
e#enableTorch
aguardam até que a câmera esteja pronta. Também adicionamos informações sobre como conseguir o campo de visão máximo com a API#takePicture
. (I23588).
Versão 1.3
Versão 1.3.4
12 de junho de 2024
Lançamento de androidx.camera:camera-*:1.3.4
. A versão 1.3.4 contém estas confirmações.
Correções de bugs
- Correção do problema em que
getZoomRatio
retornava incorretamente um valor reduzido ao aplicar uma proporção de zoom crescente (I4aa0d, b/317543616). - Correção da captura/toque para focar sem usar os valores do modo de estabilização/QPS de solicitação repetida, que podem recriar a sessão de captura e causar problemas de latência ou congelamento da visualização em alguns dispositivos (I7dc0b).
- Correção do problema em que o frame rate era definido como um valor mais baixo ao chamar
setTargetFrameRate
comFRAME_RATE_RANGE_UNSPECIFIED
(I78c61).
Versão 1.3.3
17 de abril de 2024
Lançamento de androidx.camera:camera-*:1.3.3
. A versão 1.3.3 contém estas confirmações.
Correções de bugs
- Correção de
ImageAnalysis
min problema de seleção de resolução relacionado à configuração de resolução de destino padrão do analisador: a resolução alvo foi mantida incorretamente como 640 x 480, mesmo que os aplicativos tenham definido uma configuração de resolução padrão do analisador. Se os aplicativos tiverem esse problema (1.3.0 a 1.3.2) e não puderem fazer upgrade para usar as versões mais recentes que contêm a solução, defina diretamente umResolutionSelector
com a resolução preferencial e umAspectRatioStrategy
correspondente ao caso de usoImageAnalysis
. (I81f72, b/330091012).
Versão 1.3.2
6 de março de 2024
Lançamento de androidx.camera:camera-*:1.3.2
. A versão 1.3.2 contém estas confirmações.
Correções de bugs
- Correção de um problema com metadados JPEG em dispositivos Samsung A24. O CameraX agora salva imagens com precisão, e a função
ImageProxy.toBitmap()
retorna os objetos Bitmap corretos. (I8d6eb, b/309005680). - A opção de resolução de 9280 x 6944 foi removida dos dispositivos Redmi Note 9 Pro devido a problemas. (Ia23da).
Versão 1.3.1
13 de dezembro de 2023
Lançamento de androidx.camera:camera-*:1.3.1
. A versão 1.3.1 contém estas confirmações.
Correções de bugs
Melhoria no desempenho de ProcessCameraProvider#bindToLifecycle()
. A principal mudança é otimizar o processo de identificação das combinações de tamanho mais adequadas para UseCases
. Os resultados ideais variam de acordo com as combinações específicas de UseCase
e o número de tamanhos de saída compatíveis com os dispositivos de destino. (I454f2).
Aqui estão alguns resultados de referência para vários cenários:
Quatro
UseCases
:Preview
+ImageCapture
+ImageAnalysis
+VideoCapture
- Google Pixel 7: aproximadamente de 430 ms a 60 ms
- Samsung Galaxy S23 Ultra: aproximadamente 540 ms a 45 ms
- Samsung A53 5G: aproximadamente 115 ms a 70 ms
Três
UseCases
:Preview
+ImageCapture
+ImageAnalysis
- Google Pixel 7: aproximadamente 9 ms a 7 ms
- Samsung Galaxy S23 Ultra: aproximadamente de 6 ms a 5 ms
- Samsung A53 5G: aproximadamente 32 ms a 12 ms
O Snap Dragon 480 foi adicionado ao
CameraUseInconsistentTimebaseQuirk
. Isso corrige um problema no Android 12 em dispositivos que usam esse chipset, em que o áudio nas gravações é compensado pela quantidade de tempo que o dispositivo fica no estado suspenso. (I58010).
Versão 1.3.0
18 de outubro de 2023
Lançamento de androidx.camera:camera-*:1.3.0
. A versão 1.3.0 contém estas confirmações.
Mudanças importantes desde a versão 1.2.0
- Recursos de vídeo, incluindo HDR de 10 bits, corte, espelhar/não espelhar, desativar/desativar som, frame rate definido e muito mais.
- Câmera dupla simultânea
- Biblioteca de efeitos
- Seletor de resolução
- Ultragrande e Seleção de câmera telescópica
- Troca de câmera durante a gravação de vídeo (recurso experimental)
Versão 1.3.0-rc02
20 de setembro de 2023
Lançamento de androidx.camera:camera-*:1.3.0-rc02
. A versão 1.3.0-rc02 contém estas confirmações.
Correções de bugs
- Melhore a estabilidade das extensões, garantindo que os eventos de inicialização e desinicialização sejam acionados na ordem correta. Isso corrigiu alguns problemas de visualização preta ao trocar de modo de extensão ou de câmera. (Iddaac).
- Foi corrigido o problema em que
ImageAnalysis
não podia ser vinculado aImageCapture
e a uma visualização quando alguns modos de extensão estavam ativados em alguns dispositivos A correção vai retornar o valor correto quando os apps consultarem a disponibilidade doImageAnalysis
usandoExtensionsManager#isImageAnalysisSupported()
. (I7d538). - Corrigimos o problema em que o áudio e o vídeo gravados ficavam dessincronizados quando o modo de espelhamento era ativado na NFC do Xiaomi Poco X3. (I20b4c).
Versão 1.3.0-rc01
23 de agosto de 2023
Lançamento de androidx.camera:camera-*:1.3.0-rc01
. A versão 1.3.0-rc01 contém estas confirmações.
Mudanças na API
PendingRecording.asPersistentRecording
foi adicionado para permitir que uma gravação seja gravada continuamente enquanto oVideoCapture
em que o Gravador está conectado é revinculado. (I517c6).
Correções de bugs
- Correção de uma falha quando um stream é compartilhado com o
VideoCapture
e a visualização. Também corrigimos uma tela preta em dispositivos LEGADO quando o compartilhamento de stream está ativado. - Foi corrigido o problema de imagem JPEG grande capturada em dispositivos Samsung S7 (SM-G930T, SM-G930V). As imagens JPEG capturadas contêm dados de preenchimento redundantes de 0 no segmento de dados compactado com JFIF. Isso faz com que as imagens capturadas tenham um tamanho de arquivo grande. Esses dados de preenchimento do 0 redundante serão removidos para fazer com que as imagens capturadas tenham tamanhos de arquivo de imagem normais. (I407b0, b/288828159).
- Foi corrigido o problema de imagem JPEG capturada grande em dispositivos das séries Samsung S22 (SM-S901B, SM-S901B/DS) e S22+ (SM-S906B). As imagens JPEG capturadas contêm dados de preenchimento redundantes de 0 no segmento de dados compactado com JFIF. Isso faz com que as imagens capturadas tenham um tamanho de arquivo grande, com cerca de 13 MB, no dispositivo S22 SM-S901B/DS. Esses dados de preenchimento do 0 redundante serão removidos para fazer com que as imagens capturadas tenham tamanhos de arquivo de imagem normais. (I73be9, b/288828159).
- Corrigimos o problema de imagem JPEG grande capturada em dispositivos Samsung A5, A52, A70 e A72. As imagens JPEG capturadas contêm dados de preenchimento redundantes de 0 no segmento de dados compactado com JFIF. Isso faz com que as imagens capturadas tenham um tamanho de arquivo extremo (por exemplo, cerca de 32 MB ou até mesmo 96 MB). Esses dados de preenchimento do 0 redundante serão removidos para fazer com que as imagens capturadas tenham tamanhos de arquivo de imagem normais. (I97c4d, b/288828159).
- Correção da falha nativa ao tirar fotos com extensões ativadas (I698f5).
Versão 1.3.0-beta02
26 de julho de 2023
Lançamento de androidx.camera:camera-*:1.3.0-beta02
. A versão 1.3.0-beta02 contém estas confirmações.
Correções de bugs
- A lanterna é usada como flash nas variantes do Pixel 4 e 5 para melhorar a qualidade de captura em ambientes com pouca luz (I56ff5, b/280221967).
- Correção do problema de imagem JPEG grande capturada em dispositivos da série Samsung A5 (2017). As imagens JPEG capturadas contêm dados de preenchimento redundantes de 0 no segmento de dados compactado com JFIF. Isso faz com que as imagens capturadas tenham cerca de 32 MB de tamanho de arquivo. Esses dados de preenchimento do 0 redundante serão removidos para fazer com que as imagens capturadas tenham tamanhos de arquivo de imagem normais. (I29837, b/288828159).
- Foi corrigida a nova tentativa que não acionava corretamente o acionamento em caso de falha de captura em dispositivos problemáticos mencionados em
CaptureFailedRetryQuirk
. (I7b589).
Versão 1.3.0-beta01
21 de junho de 2023
Lançamento de androidx.camera:camera-*:1.3.0-beta01
. A versão 1.3.0-beta01 contém estas confirmações.
Mudanças na API
- O nome da função
ResolutionSelector.Builder#setHighResolutionEnabledFlag(int)
foi renomeado comosetAllowedResolutionMode
e as constantesResolutionSelector#HIGH_RESOLUTION_FLAG_OFF
/ON
foram renomeadas comoPREFER_CAPTURE_RATE_OVER_HIGHER_RESOLUTION
/PREFER_HIGHER_RESOLUTION_OVER_CAPTURE_RATE
. (If84e8). - As APIs descontinuadas
ImageAnalysis.setTargetRotationDegrees(int)
,ImageCapture.setTargetRotationDegrees(int)
eVideoCapture.setTargetRotationDegrees(int)
foram removidas. (Id8e77). - A classe
DynamicRange
representa o intervalo dinâmico de imagens. Isso pode ser usado para selecionar formatos de High Dynamic Range como a saída deVideoCapture
aVideoCapture.Builder#setDynamicRange()
. (Ib0377). - Foi adicionada uma API
isImageAnalysisSupported
aoExtensionsManager
, que apps podem determinar se um caso de uso deImageAnalysis
pode ser vinculado à visualização e àImageCapture
quando as extensões estão ativadas (I1bc63). - A nova classe
VideoCapabilities
extraída doRecorder
pode ser usada para consultar os intervalos dinâmicos e as qualidades compatíveis para gravação de vídeo no dispositivo. Os métodosgetSupportedQualities()
eisQualitySupported()
deQualitySelector
estão sendo descontinuados. Use os métodosgetSupportedQualities()
eisQualitySupported()
deVideoCapabilities
. (I04014). CameraController#setVideoCaptureTargetQuality()
foi renomeado comosetVideoCaptureQualitySelector
e recebe o argumentoQualitySelector
, que oferece mais flexibilidade para a configuração da qualidade de vídeoCameraController#getVideoCaptureTargetQuality()
é mudado paragetVideoCaptureQualitySelector
adequadamente. (I520ed).- A anotação experimental foi removida dos recursos de vídeo. Os recursos de vídeo agora estão estáveis. (I1a113).
Correções de bugs
- Use a lanterna como flash nos modelos Samsung SM-A320 para melhorar a velocidade e a qualidade da imagem capturada com pouca luz. (I6a022, b/286190938).
- Foi adicionado suporte ao formato
ImageFormat.JPEG
paraImageProxy.toBitmap()
. Se a matriz de bytes JPEG não puder ser decodificada, umaUnsupportedOperationException
será gerada. (I81958, b/282057603).
Versão 1.3.0-alpha07
24 de maio de 2023
Lançamento de androidx.camera:camera-*:1.3.0-alpha07
. A versão 1.3.0-alpha07 contém estas confirmações.
Novos recursos
- A nova API
VideoCapture.Builder# setTargetFrameRate(Range)
permite que gravações de vídeo sejam capturadas em outros frame rates além do padrão do dispositivo. Os frame rates disponíveis para gravações podem ser consultados com a nova APICameraInfo#getSupportedFrameRates()
.
Mudanças na API
- Renomeação das constantes
ResolutionSelector#HIGH_RESOLUTION_FLAG_OFF
/ON
paraALLOWED_RESOLUTIONS_NORMAL
/SLOW
e do nome da funçãosetHighResolutionEnabledFlag
do builder parasetAllowedResolutionMode
(Iae817). CameraInfo#getSupportedFrameRateRanges()
agora retorna umSet
em vez de umaList
para representar melhor que os intervalos não estão ordenados. (I02f43).- Foi adicionado um listener de erro ao
CameraEffect
para processar erros irrecuperáveis (Ice471). - Foi adicionado um construtor público em
ResolutionInfo
para melhorar a capacidade de teste (If6d1c). - Uma API
UseCase.snapToSurfaceRotation(int)
foi fornecida para substituir o uso desetTargetRotationDegrees
e descontinuar as APIsImageAnalysis.setTargetRotationDegrees(int)
,ImageCapture.setTargetRotationDegrees(int)
eVideoCapture.setTargetRotationDegrees(int)
. (Ia9010). - As novas APIs
Preview#getTargetFrameRate
ePreview.Builder#setTargetFrameRate
foram adicionadas para poder definir e recuperar o frame rate desejado para o caso de uso da prévia (If4f22). VideoRecordEvent.Finalize
agora será concluído com o código de erroERROR_RECORDING_GARBAGE_COLLECTED
quando o objetoRecording
for interrompido devido à coleta de lixo. (Iba974).
Correções de bugs
NullPointerException
foi corrigido quando os tamanhos de saída armazenados em cache emStreamConfigurationMapCompat
são nulos. (Idf124, b/282025204).- Correção do problema em que
Preview.setSurfaceProvider(null)
não pausava a visualização em extensões (Ia903e). - Correção de um problema em que
ConcurrentModificationException
era gerado durante a abertura da câmera quandoVideoCapture
era vinculado. (Ic8ac4).
Versão 1.3.0-alpha06
19 de abril de 2023
Lançamento de androidx.camera:camera-*:1.3.0-alpha06
. A versão 1.3.0-alpha06 contém estas confirmações.
Novos recursos
- Câmera simultânea é um novo recurso introduzido a partir do Android 11, que oferece suporte ao streaming simultâneo de dispositivos com câmera. Por exemplo, ele permite que um dispositivo tenha as câmeras frontal e traseira funcionando ao mesmo tempo. No momento, o CameraX só é compatível com câmeras simultâneas, o que permite que duas câmeras funcionem ao mesmo tempo, com no máximo dois {@link UseCase}s vinculados para cada uma. A resolução máxima é de 720p ou 1440p. Confira mais detalhes no link a seguir: CameraManager#getConcurrentCameraIds()
- Introdução da nova API
ResolutionSelector
, que abrange os seguintes recursos:- Os aplicativos podem especificar estratégias de proporção e resolução para selecionar a melhor resolução para suas necessidades.
- Todos os tamanhos e parâmetros de proporção são expressos nas coordenadas do sensor do dispositivo da câmera.
- Os aplicativos podem implementar um filtro de resolução personalizada para organizar os tamanhos compatíveis na ordem desejada.
- Os aplicativos também podem ativar a captura de alta resolução para obter imagens de resolução mais alta. No entanto, usar uma resolução alta pode resultar em tempos de captura mais lentos.
- Foram adicionadas APIs de espelhamento de
VideoCapture
. Os vídeos gravados peloVideoCapture
não são espelhados por padrão. No entanto, a visualização da câmera é espelhada na câmera frontal por padrão. As APIs de espelhamento deVideoCapture
permitem o alinhamento com a visualização da câmera ao usar a câmera frontal. Há três opções:MirrorMode
,OFF
,ON
eON_FRONT_ONLY
. Para alinhar à visualização da câmera, é recomendável usarON_FRONT_ONLY
. Isso significa que o espelhamento não está ativado para a câmera traseira, mas está ativado para a câmera frontal.
Mudanças na API
- A nova API
ResolutionSelector
foi exposta. Para alcançar os resultados desejados, os apps podem especificar estratégias de proporção e resolução com regras substitutas ou um filtro de resolução personalizado. Os aplicativos podem especificar um sinalizador para ativar a captura em alta resolução. Isso vai permitir que o CameraX selecione resoluções mais altas ao tirar fotos ou gravar vídeos. No entanto, usar uma resolução alta pode resultar em tempos de captura mais lentos. (Ibed95). - Os intervalos de QPS compatíveis com o algoritmo AE agora podem ser consultados via
CameraInfo#getSupportedFrameRateRanges()
. (Iaa67f). - Consolide os nomes de todos os métodos de frame rate usando o "FrameRate". Corrigir o erro do Java no
VideoCapture#getTargetFrameRate()
(I83304). - As APIs
setTargetAspectRatio
esetTargetResolution
legadas foram descontinuadas. Use a nova APIResolutionSelector
. (I542c3). - Adicionadas APIs públicas para câmeras duplas simultâneas, incluindo:
List<List<CameraInfo>> getAvailableConcurrentCameraInfos()
ConcurrentCamera bindToLifecycle(@NonNull ConcurrentCameraConfig concurrentCameraConfig)
boolean isConcurrentCameraModeOn()
eConcurrentCameraConfig
,SingleCameraConfig
eConcurrentCamera
(Iab1c1).
- Tornar
ImageProcessor.Response#getOutputImage
não nulo (Ib9c60). - Foram adicionadas APIs de espelhamento de
VideoCapture
, incluindoVideoCapture.Builder.setMirrorMode(int)
eVideoCapture.getMirrorMode()
. As APIs são úteis para aplicativos que exigem que a gravação de vídeo seja consistente com o comportamento comum de visualização da câmera, ou seja, a visualização da câmera traseira não é espelhada, mas a visualização da câmera frontal. (I713b6, b/194634656). - A API
setTargetFrameRate()
foi adicionada às APIsVideoCapture.Builder
egetTargetFramerate()
emVideoCapture
(I109d4). - Agora,
SurfaceOutput
estende Closable e oculta o construtor público de SurfaceOutput.Event
. (I60ea8). Recording.mute
foi adicionado para desativar ou ativar o som de uma gravação em processamento de forma dinâmica.RecordingStats
conteráAudioStats.AUDIO_STATE_MUTED
quando o som da gravação em processamento for explicitamente desativado. (Ie17fc).- O parâmetro
#setEffects()
passou a ser não nulo. Adicione uma API#clearEffects()
para limpar os efeitos. O app precisa chamar#clearEffects()
para remover os efeitos. (I4b4d9). - Foi adicionado um segundo construtor para
ViewfinderSurfaceRequest.Builder
a fim de usar um builder para o construtor de cópia (I621a7).
Correções de bugs
- Correção do problema em que os apps que invocavam a API Extensions podiam falhar ao fechar a câmera (Ib27e5).
- Correção de um problema em que o
VideoCapture
não funcionava com a câmera frontal em alguns dispositivos. Por exemplo, no Samsung Galaxy S23 e no Xiaomi 2107113SG. (Ibec7e, b/270656244). - Correção do problema que falhava ao tirar fotos usando "Arquivo" na pasta pública de armazenamento externo no Android 10 ou versões mais recentes No Android 10, para tirar fotos usando o arquivo na pasta pública de armazenamento externo, também é necessário definir
requestLegacyExternalStorage
como verdadeiro na tag do aplicativo. (I11b2c). - Foi corrigida uma falha
RejectedExecutionException
emDefaultSurfaceProcessor
A falha pode acontecer quandoVideoCapture
está vinculado e a atividade é pausada. (Idb46a, b/273713906).
Versão 1.3.0-alpha05
22 de março de 2023
Lançamento de androidx.camera:camera-*:1.3.0-alpha05
. A versão 1.3.0-alpha05 contém essas confirmações.
Mudanças na API
- Foram adicionadas APIs de rotação
VideoCapture
, incluindoVideoCapture.Builder.setTargetRotation(int)
,VideoCapture.setTargetRotation(int)
,VideoCapture.setTargetRotationDegrees(int)
eVideoCapture.getTargetRotation()
. As APIs são úteis para aplicativos que bloqueiam a orientação do dispositivo.ImageCapture.setTargetRotationDegrees(int)
eImageAnalysis.setTargetRotationDegrees(int)
também foram adicionados. (Id3ffe, b/205242781). - Permitir
VIDEO_CAPTURE
ePREVIEW|VIDEO_CAPTURE
como destino dos efeitos. Os efeitos direcionados aVIDEO_CAPTURE
serão aplicados ao caso de uso deVideoCapture
. Os efeitos direcionados aPREVIEW|VIDEO_CAPTURE
serão aplicados a um stream compartilhado antes de serem copiados para a visualização e oVideoCapture
. (Iee6f3).
Correções de bugs
- Na Câmera
1.2.2
: foi corrigido o problema em que as extensões do CameraX não funcionavam corretamente quando o Proguard estava ativado em alguns dispositivos, como o Pixel (I90aa2). - Correção de um bug
PreviewView
que, se o app processasse a orientação da tela, a visualização pode ficar distorcida após a rotação. Isso só acontece em alguns dispositivos. Ele pode ser reproduzido no Pixel a4, Pixel 5 e Pixel 6a. (I14340, b/223488673).
Versão 1.3.0-alpha04
22 de fevereiro de 2023
Lançamento de androidx.camera:camera-*:1.3.0-alpha04
. A versão 1.3.0-alpha04 contém essas confirmações.
Novos recursos
Um novo recurso que oferece suporte a combinações de plataforma anteriormente sem suporte ao compartilhar um fluxo para vários casos de uso.
- Anteriormente, o CameraX gerava
IllegalArgumentException
ao vincular "Preview, VideoCapture, ImageAnalysis" no nível de hardware da câmera FULL e abaixo, ou ao vincular "Preview, VideoCapture, ImageCapture" no nível de hardware LEGACY. - Agora, as vinculações vão funcionar sem gerar exceções. Em vez disso, o CameraX usará o OpenGL para copiar um stream compartilhado para a visualização e a captura de vídeo.
- Como custo da cópia do buffer, o app poderá ter um aumento na latência e no consumo de energia.
Mudanças na API
- Uma API foi adicionada para converter
ImageProxy
emBitmap
. O formato deImageProxy
com suporte éImageFormat.YUV_420_888
ePixelFormat.RGBA_8888
. Se o formato for inválido, será gerado umIllegalArgumentException
(Ic7110). CoroutineCameraViewfinder
foi adicionado para oferecer suporte à configuração do visor usando funções de suspensão em Kotlin (I657bc).- Foi adicionado um novo construtor público para
ViewfinderSurfaceRequest
. Ele oferece a flexibilidade quando o usuário não pode fornecerCameraCharacteristics
(Ie6549).
Correções de bugs
- Foi corrigida a falha de extensões que ocorria em alguns dispositivos Samsung ao pausar/retomar o app muito rapidamente (Iaca26).
Versão 1.3.0-alpha03
25 de janeiro de 2023
Lançamento de androidx.camera:camera-*:1.3.0-alpha03
. A versão 1.3.0-alpha03 contém essas confirmações.
Mudanças na API
CameraInfo.getIntrinsicZoomRatio
foi adicionado para fornecer informações de ângulo de visualização em relação à câmera padrão (Ib300c).CameraInfo.getLensFacing
foi adicionado para fornecer informações voltadas para a lente.CameraSelector#LENS_FACING_EXTERNAL
foi adicionado como um recurso experimental para selecionar câmeras externas (Icaf3e).- Adicione
#setEffect()
aCameraController
, que permite adicionar efeitos à saída da câmera (I1d21f). - Adicione o método
invalidate()
aSurfaceRequest
. O provedor pode notificar que a plataforma fornecida anteriormente não é mais válida (Idc649). - Adicione uma API
ImageProcessor
. Essa interface serve para injetar efeitos de pós-processamento no pipelineImageCapture
(I575c6). - Foi adicionada a API
Recorder.Builder.setAspectRatio()
, que pode ser combinada comQualitySelector
para oferecer suporte a mais resoluções de vídeo (I8a082). Recorder.Builder#setTargetVideoEncodingBitRate
foi adicionado para definir a codificação de vídeo de destinoBitRate
, eRecorder#getTargetVideoEncodingBitRate
foi adicionado para receber a taxa de bits de codificação de vídeo de destino (I5984d).
Correções de bugs
- A falha de
ImageCapture
que ocorria quando não havia unidade de flash e o modo de flash estava ativado foi corrigida (I9e8b4, b/263391112). - O problema de corrupção de imagens JPEG ao gravar dados de local Exif em alguns dispositivos Samsung Android 12 foi corrigido (Ib7086, b/263747161, b/263289024).
- Ao definir a lanterna/zoom antes dos componentes de inicialização da câmera, como ao chamar
CameraController#enableTorch
, a ação pendente será armazenada em cache e enviada quando a inicialização for acionada (I11e92, b/264157663).
Versão 1.3.0-alpha02
7 de dezembro de 2022
Lançamento de androidx.camera:camera-*:1.3.0-alpha02
. A versão 1.3.0-alpha02 contém estas confirmações.
Mudanças na API
- nova API para aplicar o efeito pós-processamento à saída da visualização (Ic17d5).
OutputOptions.getDurationLimit
foi renomeado comoOutputOptions.getDurationLimitMillis
, eOutputOptions.setDurationLimit
foi renomeado comoOutputOptions.setDurationLimitMillis
(I91f0c).- A classe
AudioConfig
foi adicionada para processar a configuração de áudio ao gravar vídeos. A anotação@RequiresPermission
foi movida das funçõesstartRecording
paraAudioConfig
para evitar solicitações de permissão desnecessárias nos casos em que o áudio não é necessário (I28755). - Remoção das classes Metadata,
OnVideoSavedCallback
,OutputFileOptions
eOutputFileResults
que não são mais usadas após a aplicação da nova API de captura de vídeo (I38cd8). - Aplicação da nova API de captura de vídeo. Os métodos
getVideoCaptureTargetSize
esetVideoCaptureTargetSize
foram substituídos pelos métodosgetVideoCaptureTargetQuality
esetVideoCaptureTargetQuality
, já que não há mais suporte parasetTargetResolution
(I2a1d5).
Correções de bugs
- A API descontinuada
core.VideoCapture
foi removida (I531e0). - Correção do problema em que o callback
onError
não era chamado ao tirar fotos sem a permissão de armazenamento (I936db, b/244807669). - Melhoria na qualidade e a confiabilidade das extensões da câmera. As extensões da câmera estão desativadas nos dispositivos Motorola com extensões de câmera v1.1.0 ou mais antigas devido a problemas com o suporte ao Bokeh, captura de imagens e visualização não retomada (Id3ce3).
- Correção da falha nativa quando o corte de vídeo via
ViewPort
está ativado em dispositivos legados (I16b8a, b/251357665).
Versão 1.3.0-alpha01
9 de novembro de 2022
Lançamento de androidx.camera:camera-*:1.3.0-alpha01
. A versão 1.3.0-alpha01 contém estas confirmações.
Novos recursos
- O
Camera-viewfinder
foi publicado oficialmente. OCamera-viewfinder
fornece um widget de visor básico que pode mostrar a transmissão da Camera2. Confira este exemplo de código.
Mudanças na API
- Foi adicionado
OutputOptions.setDurationLimit
para permitir a configuração do limite da duração do vídeo. A gravação será finalizada de forma automática quando exceder o limite de duração especificado (I902a0). - Foi adicionado o estado de erro
AudioStats.AUDIO_STATE_SOURCE_ERROR
do áudio da gravação de vídeo. Ele é enviado quando a configuração da fonte de áudio falha ou ocorre algum erro (I37410).
Correções de bugs
- Foi adicionada peculiaridade para permitir que alguns dispositivos problemáticos tentem repetir a captura uma vez ao encontrar falhas (Id4795).
- Correção do problema de tela preta da implementação da
PreviewView
eSurfaceView
emViewPager2
. Como parte da correção,PreviewView
vai reutilizar aSurfaceView
se a resolução solicitada não mudar (Ib3f27). - Suporte ao corte de vídeo (recurso WYSIWYG) quando a API
ViewPort
ouCameraController
é usada (Ifbba8, b/201085351). - Correção do problema que ocorria quando o vídeo capturado com a câmera frontal não era gravado no Huawei P40 Lite (I87c57, b/250807400).
Versão 1.2
Versão 1.2.3
24 de maio de 2023
Lançamento de androidx.camera:camera-*:1.2.3
. A versão 1.2.3 contém estas confirmações.
Correções de bugs
- Correção de um problema em que o
VideoCapture
não funcionava com a câmera frontal em alguns dispositivos. Por exemplo, no Samsung Galaxy S23 e no Xiaomi 2107113SG. (Ibec7e, b/270656244).
Versão 1.2.2
22 de março de 2023
Lançamento de androidx.camera:camera-*:1.2.2
. A versão 1.2.2 contém estas confirmações.
Correções de bugs
- Foi corrigido o problema em que as extensões do CameraX não funcionavam corretamente quando o ProGuard estava ativado em alguns dispositivos, como o Pixel (I90aa2).
Versão 1.2.1
25 de janeiro de 2023
Lançamento de androidx.camera:camera-*:1.2.1
. A versão 1.2.1 contém estas confirmações.
Correções de bugs
- Corrija o problema de corrupção de imagens JPEG ao gravar dados de local Exif em alguns dispositivos Samsung Android 12 (b/263289024).
Versão 1.2.0
7 de dezembro de 2022
Lançamento de androidx.camera:camera-*:1.2.0
. A versão 1.2.0 contém estas confirmações.
Mudanças importantes desde a versão 1.1.0
- Nova biblioteca camera-mlkit-vision. Integração fácil da CameraX usando vários recursos do MLKit, como a leitura de código de barras, detecção facial, detecção de texto etc. Adicionamos
MLKitAnalyzer
como novas APIs. - Nova API Zero-Shutter Lag experimental. Otimização do pipeline de captura para ter uma latência melhor, mantendo uma boa qualidade da imagem. Quando o modo de captura é definido como
CAPTURE_MODE_ZERO_SHUTTER_LAG
, a latência entre o momento em que o botão do obturador é acionado e em que a foto tirada será menor em comparação com outros modos de captura. Em dispositivos sem suporte para oZERO_SHUTTER_LAG
, ele será substituído porCAPTURE_MODE_MINIMIZE_LATENCY
. - O uso de
android.camera.core.VideoCapture
foi descontinuado. - A
setStreamUseCase()
foi adicionada como uma APICamera2Interop
pública. - Novo requisito de nível de API para
setOutputImageRotationEnabled
. ImageAnalysis.Analyzer#getTargetResolutionOverride()
foi renomeado comoImageAnalysis.Analyzer#getDefaultTargetResolution()
- Adicionamos a API para definir metadados de local do vídeo salvo.
- Correção de uma taxa de frames baixa ao usar os casos de uso de
VideoCapture
e de visualização com proporção de 16:9 - Foi corrigido o problema de visualização preta que acontecia quando a extensão BOKEH estava ativada em alguns dispositivos Samsung e o usuário trocava de câmera.
- Correção dos problemas de esticamento da
Preview/VideoCapture
no Samsung J7 Prime (SM-G610M) e no J7 (SM-J710MN) em dispositivos com API de nível 27. - A solução alternativa para virar a região de AF horizontalmente de câmeras frontais do Samsung Android T foi desativada, uma vez que o problema foi corrigido.
Versão 1.2.0-rc01
24 de outubro de 2022
Lançamento de androidx.camera:camera-*:1.2.0-rc01
. A versão 1.2.0-rc01 contém estas confirmações.
Mudanças na API
- Adição da API
setStreamUseCase
paraOutputConfiguration
O usuário pode especificar o caso de uso da sessão de stream, substituindo as lógicas internas da CameraX para escolher o caso de uso de stream a fim de otimizar de acordo com a necessidade (Ib1a95).
Correções de bugs
- Correção dos problemas de esticamento da
Preview/VideoCapture
no Samsung J7 Prime (SM-G610M) e no J7 (SM-J710MN) em dispositivos com API de nível 27. A resolução de 1.920 x 1.080 faz com que as imagensPreview/VideoCapture
sejam esticadas. Adição de solução alternativa para não selecionar a resolução de 1.920 x 1.080 para visualização ouVideoCapture
para evitar o problema de imagem esticada (I0e04e). - Correção de uma taxa de frames baixa ao usar os casos de uso
VideoCapture
e de visualização com proporção de 16:9 em alguns dispositivos Huawei (If8c88, b/223643510). - Correção da falha ao abrir a câmera quando o
SurfaceProvider
da visualização não é definido. Como parte da correção, a visualização semSurfaceProvider
definido não vai ser mais configurada na sessão de captura de câmera (I99681).
Versão 1.2.0-beta02
21 de setembro de 2022
Lançamento de androidx.camera:camera-*:1.2.0-beta02
. A versão 1.2.0-beta02 contém estas confirmações.
Mudanças na API
- Foi adicionado um requisito de nível da API para
setOutputImageRotationEnabled
(I26e3e, b/240993561).
Correções de bugs
- A solução alternativa para virar a região de AF horizontalmente de câmeras frontais do Samsung Android T foi desativada, uma vez que o problema foi corrigido (I05f69).
- Foi corrigido o problema de visualização preta que acontecia quando a extensão
BOKEH
estava ativada em alguns dispositivos Samsung e o usuário trocava de câmera (If6168).
Versão 1.2.0-beta01
24 de agosto de 2022
Lançamento de androidx.camera:camera-*:1.2.0-beta01
. A versão 1.2.0-beta01 contém estas confirmações.
Novos recursos
- Nova biblioteca
camera-mlkit-vision
. Integre a CameraX com facilidade usando vários recursos do MLKit, como a leitura de código de barras, detecção facial, detecção de texto etc. Clique aqui (link em inglês) para ver o exemplo de código. - Nova API Zero-Shutter Lag experimental. Otimiza o pipeline de captura para ter uma latência melhor, mantendo uma boa qualidade da imagem. Quando o modo de captura é definido como CAPTURE_MODE_ZERO_SHUTTER_LAG, a latência entre o momento em que o botão do obturador é acionado e em que a foto tirada é minimizada em comparação com outros modos de captura. Em dispositivos que não têm suporte a ZERO_SHUTTER_LAG, ele vai ser substituído por CAPTURE_MODE_MINIMIZE_LATENCY.
- A
ImageAnalysis.Analyzer
eMLKitAnalyzer
se tornaram APIs oficiais. - A API é exposta para definir metadados de local do vídeo salvo.
- O
ImageAnalysis.Analyzer#getTargetResolutionOverride()
foi renomeado comoImageAnalysis.Analyzer#getDefaultTargetResolution()
.
Correções de bugs
- Correção do problema de captura de imagem no Alps k61v1_basic_ref. As imagens JPEG capturadas da HAL têm metadados EXIF incorretos. Os metadados EXIF não têm a tag 0xffd9 ou 0xffda para que a
ExifInterface
analise corretamente os atributos. Capture as imagens no formato YUV e as compacte em imagens de saída JPEG para resolver esse problema (I45abb).
Versão 1.2.0-alpha04
27 de julho de 2022
Lançamento de androidx.camera:camera-*:1.2.0-alpha04
. A versão 1.2.0-alpha04 contém estas confirmações.
Mudanças na API
- O
ImageAnalysis.Analyzer#getTargetResolutionOverride()
foi renomeado comoImageAnalysis.Analyzer#getDefaultTargetResolution()
. O comportamento também mudou para que o valor retornado por esse método possa ser substituído pelo valor deImageAnalysis#setTargetResolution()
(If1d36). - A API é exposta para definir metadados de local do vídeo salvo. Um objeto
android.location.Location
pode ser definido com a nova APIandroidx.camera.video.OutputOptions.Builder.setLocation(Location)
(I313a0, b/204197544).
Correções de bugs
- Correção do problema ao tirar fotos com a prévia de desvinculação (Ie70b6, b/235119898).
- Correção de uma falha no
Recorder
que ocorria ao tentar gravar enquanto a fonte de áudio estava indisponível (I9f652).
Versão 1.2.0-alpha03
29 de junho de 2022
androidx.camera:camera-*:1.2.0-alpha03
é lançado. A versão 1.2.0-alpha03 contém estas confirmações.
Mudanças na API
- A anotação experimental do
ImageAnalysis.Analyzer
eMLKitAnalyzer
foi removida (I0ff22).
Correções de bugs
- Adicionamos um tempo limite padrão para o foco automático de 5.000 ms, que vai concluir a parte de AF com
isFocusSuccessful
como falso se aFocusMeteringAction
não for cancelada e a parte de AF não for convergida na duração (Ibc2e3). - Corrigimos o problema ao tirar fotos com a visualização de desvinculação (I1d3a2, b/235119898).
- A implementação avançada do extensor foi ativada, e a versão da interface de extensões de suporte da CameraX foi atualizada para 1.2 (I92256).
Versão 1.2.0-alpha02
1º de junho de 2022
Lançamento de androidx.camera:camera-*:1.2.0-alpha02
. A versão 1.2.0-alpha02 contém estas confirmações.
Novos recursos
- A API CameraX Zero-Shutter Lag foi exposta como experimental.
Mudanças na API
- Foi adicionado um novo modo de captura
CAPTURE_MODE_ZERO_SHUTTER_LAG
emImageCapture
. Também adicionamosisZslSupported
emCameraInfo
para consultar a capacidade do dispositivo. O modoCAPTURE_MODE_ZERO_SHUTTER_LAG
tem como objetivo fornecer a latência mínima para a captura instantânea. Ele é implementado com base em um buffer de anel, que armazena os resultados de captura intermediários em cache para reprocessamento posterior quando o usuário pressiona botões para tirar fotos. Se {@link VideoCapture} estiver vinculado, o modo de flash não estiver desativado ou a extensão OEM estiver ativada, esse modo vai ser desativado automaticamente (I9ae74). - O método
ImageAnalysis.getBackgroundExecutor()
foi adicionado (Icc945).
Correções de bugs
- O método takePicture de
ImageCapture
, que desativa a lanterna nos dispositivos informados, foi corrigido (Ib5eb5, b/228272227). - Um bug em que o
AssertionError
não era processado ao receber a característicaCONTROL_ZOOM_RATIO_RANGE
foi corrigido (/Ia248a, b/231701345).
Versão 1.2.0-alpha01
18 de maio de 2022
androidx.camera:camera-*:1.2.0-alpha01
é lançado. A versão 1.2.0-alpha01 contém estas confirmações.
Novos recursos
- Lançamento da nova biblioteca camera-mlkit-vision
Correções de bugs
- Foi corrigida a falha em que
QualitySelector
não gravava um vídeo em UHD quando uma estratégia de substituição estava ativada. O problema ocorre quando aVideoCapture
está vinculada àImageCapture
e à visualização em um dispositivo de câmera com nível de hardware FULL ou superior. Uma estratégia de substituição deQualitySelector
faz com queVideoCapture
receba incorretamente uma resolução FHD. Essa combinação de uso oferece suporte à resolução UHD e precisa ser adotada (I0e788, b/230651237). - A
NullPointerException
foi corrigida emImageCapture.takePicture()
(I92366, b/230454568, b/229766155). - Correção do comportamento de pausa assíncrona de
androidx.camera.video.Recorder
(Ia8ce8).
Camera-Camera2, Camera-Core, Camera-Lifecycle e Camera-Video: versão 1.1.0
Versão 1.1.0
29 de junho de 2022
androidx.camera:camera-*:1.1.0
é lançado. A versão 1.1.0 contém estas confirmações.
Mudanças importantes desde a versão 1.0.0
- Bibliotecas de visualização de imagens, extensão e captura de vídeos como a primeira versão RC. A partir da versão 1.1.0-beta01, todas as bibliotecas da CameraX vão ter o mesmo número de versão. Com isso, os desenvolvedores podem rastrear versões com muito mais facilidade, além de reduzir a complexidade de matrizes de compatibilidade de versões grandes.
- Lançamos novos recursos e APIs públicas, incluindo:
- Adicionamos a biblioteca oficial camera-video para oferecer suporte aos casos de uso de captura de vídeo.
- Recurso de conversão e rotação de YUV para RGB (
ImageAnalysis.Builder.setOutputImageRotationEnabled
esetOutputImageFormat
). - Adicionamos suporte ao modo de várias janelas, permitindo que os aplicativos da CameraX retomem a câmera quando ela for interrompida por outro app e retornar ao foco inicial.
- Corrigimos alguns problemas de visualização para garantir que a CameraX funcione bem em dispositivos dobráveis.
- Adicionamos uma API
CameraState
que vai ser exposta pelo CameraInfo. - Adicionamos uma API
ProcessCameraProvider.getAvailableCameraInfos()
para recuperar diretamente informações sobre as câmeras disponíveis. - Formato JPEG de saída para
ImageCapture#OnImageCapturedCallback
quando as extensões estão ativadas. - Adicionamos uma API
isFocusMeteringSupported
aCameraInfo
, que permite que os aplicativos confirmem se aFocusMeteringAction
fornecida oferece suporte à câmera atual ou não. - A API
getResolutionInfo
foi exposta para fornecer as informações de resolução para Preview,ImageCapture
eImageAnalysis
- Adicionamos uma nova API
ImageCapture.Builder#setJpegQuality
para permitir a mudança da qualidade da compactação de imagens JPEG de saída ao tirar fotos. - Adicionamos
CameraSelector#filter
à API pública para filtrar uma lista deCameraInfos
com base em umCameraSelector
. - Adicionamos
Camera2CameraControl.clearCaptureRequestOptions
para limpar as opções de solicitação de captura já existentes. - Adicionamos uma API experimental para usar
CameraController
com bibliotecas de processamento de imagens externas, como a MLKit. - Adicionamos a API experimental
CameraInfo#getCameraSelector()
que retorna umCameraSelector
exclusivo para a câmera. - Várias APIs experimentais foram promovidas para APIs formais públicas.
- A anotação
@Experimental
foi substituída por@RequiresOptIn
para APIs experimentais. Para chamar APIs experimentais, use androidx.annotation.OptIn em vez de androidx.annotation.experimental.UseExperimental. - As seguintes APIs experimentais foram promovidas a APIs oficiais:
CameraXConfig.Builder#setAvailableCamerasLimiter()
,CameraXConfig.Builder#setMinimumLoggingLevel()
,CameraXconfig.Builder#setSchedulerHandler()
,CameraXConfig#getAvailableCamerasLimiter()
,CameraXConfig#getMinimumLoggingLevel()
,CameraXConfig#getCameraExecutor()
eCameraXConfig#getSchedulerHandler()
. - APIs
@ExperimentalCameraFilter
. - APIs experimentais de compensação de exposição.
- A API
UseCaseGroup
experimental foi promovida para camera-core, camera-lifecycle e camera-video. Os elementosViewPort#getLayoutDirection
,ViewPort.Builder#setLayoutDirection
eViewPort.Builder#setScaleType
foram adicionados para personalizar a janela de visualização. - O
ExperimentalUseCaseGroupLifecycle
foi promovido para APIs formais públicas. - Mudanças nas APIs atuais.
Renamed MediaStoreOutputOptions.getCollection
comoMediaStoreOutputOptions.getCollectionUri
.- A classe
ActiveRecording
foi renomeada como "Recording" para diminuir a verbosidade. - A API criadora
QualitySelector
foi mudada para uma API baseada em lista.
Correções de bugs
- Foi corrigido o problema da
EOFException
doYuvToJpegProcessor
quando o modo de extensão era ativado e o modoImageCapture#CAPTURE_MODE_MAX_QUALITY
estava definido. - Corrigimos a falha da configuração do codec porque a gravação de vídeo foi encerrada.
- A proporção de visualização/vídeo estendido ao gravar em FHD foi corrigida.
- Corrigimos o áudio/vídeo fora de sincronia após a pausa e retomada em alguns dispositivos.
- Foi corrigido o problema em que o flash era acionado durante o Toque para focar (
startFocusAndMetering
) quando o modo flash estava no automático ou sempre ativado em ambientes com pouca luz.
Versão 1.1.0-rc02
1º de junho de 2022
Lançamento de androidx.camera:camera-*:1.1.0-rc02
. A versão 1.1.0-rc02 contém estas confirmações.
Correções de bugs
- A
NullPointerException
foi corrigida emImageCapture.takePicture()
(I92366, b/230454568, b/229766155). - Foi corrigido um bug em que o
AssertionError
não era processado ao receber a característicaCONTROL_ZOOM_RATIO_RANGE
(Ia248a, b/231701345).
Versão 1.1.0-rc01
11 de maio de 2022
Lançamento de androidx.camera:camera-*:1.1.0-rc01
. A versão 1.1.0-rc01 contém estas confirmações.
Novos recursos
- Lançamento da primeira versão RC para camera-video, camera-view e camera-extension.
Correções de bugs
- Foi corrigido um problema em que o codec de vídeo não era lançado quando o
VideoCapture<Recorder>
era desvinculado, fazendo com que os usos subsequentes doVideoCapture<Recorder>
falhasssem na gravação com umaMediaCodec.CodecException
, especialmente em dispositivos com APIs 21 e 22 (Ie7f68). - Correção de um problema em que imagens capturadas da
CameraExtensionsActivity
não eram excluídas emImageCaptureTest
.
Versão 1.1.0-beta03
6 de abril de 2022
Lançamento de androidx.camera:camera-*:1.1.0-beta03
. A versão 1.1.0-beta03 contém estas confirmações.
Mudanças na API
- O construtor
CaptureRequestOptions
foi restringido (I261b6). - Foi adicionada uma API experimental para usar
CameraController
com bibliotecas de processamento de imagens externas, como a MLKit (I4ea71).
Correções de bugs
- Correção do problema em que a visualização se tornava lateral na
PreviewView
quando a atividade não era reiniciada depois que os dispositivos eram girados no modo de várias janelas (I1ea36, b/223488673). - Foi corrigido um problema de várias janelas em que, no retorno do foco para o app, havia uma falha ao retomar a câmera quando (1) outro app de alta prioridade abria uma câmera diferente e (2) o dispositivo era um Samsung com Android 12 (I7e9f2).
- Solução alternativa incluída para dispositivos que falham ao verificar a disponibilidade do flash. A lanterna não estará disponível nesses dispositivos (If26a3, b/216667482).
- Correção do problema
AbstractMethodError
que ocorria quando os apps usavam extensões e ativavam o ProGuard (I7cbaf, b/222726805). - O modo de extensão bokeh no dispositivo Motorola Razr 5G foi desativado à força, o que causa um problema de tela preta na visualização (I35d49).
- Correção de áudio/vídeo fora de sincronia após a pausa e a retomada em alguns dispositivos Samsung com API de níveis anteriores ao 29 (I64622, b/202798609, b/202798572).
- Correção de áudio/vídeo fora de sincronia após a pausa e retomada no Sony G3125 (I2a1a5, b/202799148).
- Correção de uma falha quando o Gravador encontrava uma
InvalidConfigException
. Essa correção apenas evita que o app falhe, mas não resolve a causa daInvalidConfigException
. Se ainda não for possível configurar oRecorder
, os apps vão receber um callback de erro quando a gravação for iniciada (I89c29, b/213617227).
Contribuição externa
- Atualização da API :compose:ui-ui-test (updateApi) devido à migração de test-coroutines-lib (I3366d).
Versão 1.1.0-beta02
23 de fevereiro de 2022
androidx.camera:camera-*:1.1.0-beta02
é lançado. A versão 1.1.0-beta02 contém estas confirmações.
Mudanças na API
- Foi adicionada a capacidade de especificar o ID da câmera física usando Camera2Interop (I5aed8).
Correções de bugs
- Correção do problema de visualização esticada no Oppo Find N (I7d004).
- Correção de um problema no Galaxy J7 Prime em que a visualização ficava distorcida (I4c500).
- É possível usar uma taxa de bits compatível para encontrar o codificador de vídeo (d969052).
Versão 1.1.0-beta01
26 de janeiro de 2022
Lançamento de androidx.camera:camera-*:1.1.0-beta01
. A versão 1.1.0-beta01 contém estas confirmações.
Novos recursos
- A partir da versão 1.1.0-beta01, todas as bibliotecas da CameraX vão ter o mesmo número de versão. Com isso, os desenvolvedores podem rastrear versões com muito mais facilidade, além de reduzir a complexidade da matriz de compatibilidade de versões grandes.
Mudanças na API
Camera2CameraControl.clearCaptureRequestOptions
foram adicionadas para limpar as opções de solicitação de captura já existentes (Ifa07d).
Correções de bugs
- Corrigida a falha ao gravar o vídeo em alguns dispositivos anteriores ao Android O(API 26) (I88fdf, b/212328261).
- Corrigido o problema de região de AF incorreta ao usar
cameraControl#startFocusAndMetering()
na câmera frontal para lentes em dispositivos Samsung (Ifbf59, b/210548792). - A lanterna é usada como flash no Pixel 3a/Pixel 3a XL para melhorar a velocidade e a qualidade da imagem capturada no escuro (Ib12b6, b/211474332).
- Aplicativos foram ativados para retomar a câmera quando ela for interrompida por outro aplicativo de prioridade mais alta no modo de várias janelas e o foco mudar de volta para o app inicial. Talvez haja alguma latência (de 1 a 10 segundos ou mais) entre as mudanças de foco e a câmera ser reaberta devido a algum problema no framework (I4d092).
Versão 1.1.0-alpha12
15 de dezembro de 2021
Lançamento de androidx.camera:camera-*:1.1.0-alpha12
. A versão 1.1.0-alpha12 contém estas confirmações.
Mudanças na API
- Remoção de anotações
@RequiresApi(21)
desnecessárias das classes/interfaces internas (I8e286, b/204917951). - As constantes de qualidade e de estratégia de substituição da classe
QualitySelector
mudou para serem representadas por objetos de classe. Por exemplo, aQualitySelector.QUALITY_HD
é mudada paraQuality.HD
, eQualitySelector.FALLBACK_STRATEGY_LOWER
é mudada para a instância retornada porFallbackStrategy.lowerQualityOrHigherThan(Quality)
. A API usada para criar aQualitySelector
mudou para uma API baseada em lista. A nova APIQualitySelector.fromOrderedList(List<Quality>)
vai fazer referência à ordem da lista de qualidade de entrada em vez da ordem criada porQualitySelector.Procedure
. A classeQualitySelector.Procedure
foi removida (I43343). - O
PendingRecording.withEventListener()
foi removido, e o listener de eventos agora precisa ser transmitido paraPendingRecording.start()
. Esse requisito do listener de eventos serve para incentivar o processamento de erros assíncronos que são informados no eventoVideoRecordEvent.Finalize
(I1e71d). - A classe
ActiveRecording
foi renomeada comoRecording
para diminuir a verbosidade (I77ceb).
Correções de bugs
- Correção do problema que fazia com que as fotos capturadas no modo
FLASH_AUTO
ficassem subexpostas em condições escuras no Pixel 3a e no Pixel 3a XL (I13f19, b/205373142). - O tamanho de exibição mais recente sempre é usado para determinar a
Resolution
de visualização (I4a694). - Remoção de câmeras que não têm
REQUEST_AVAILABLE_CAPABILITIES_BACKWARD_COMPATIBLE
. Câmeras comREQUEST_AVAILABLE_CAPABILITIES_BACKWARD_COMPATIBLE
têm o conjunto mínimo de recursos aos quais todos os dispositivos de câmera oferecem suporte. Uma câmera semREQUEST_AVAILABLE_CAPABILITIES_BACKWARD_COMPATIBLE
pode oferecer suporte a uma função especial, mas não à saída de cor padrão. ACameraX
não oferece suporte aos casos de usoPreview
,ImageCapture
,ImageAnalysis
ouVideoCapture
dessas câmeras. Por isso, é necessário remover essas câmeras para evitar o uso incorreto (Ib8cda). - O elemento
CameraSelector#filter
não gera mais umaIllegalArgumentException
quando o conjunto de resultados está vazio (I27804). - Heurísticas mais inteligentes agora são usadas para selecionar as configurações do codificador com base em perfis especificados pelo OEM (Iaeef0).
- A visualização fixa terá linhas de cores entrelaçadas após iniciar a gravação de vídeo em UHD no Pixel1 (I833c6, b/205340278).
Versão 1.1.0-alpha11
17 de novembro de 2021
androidx.camera:camera-*:1.1.0-alpha11
é lançado. A versão 1.1.0-alpha11 contém estas confirmações.
Mudanças na API
- CameraSelector#filter foi adicionado à API pública para filtrar uma lista de CameraInfos com base em um CameraSelector (I105d0).
A API setOutputImageRotationEnabled foi adicionada à configuração do ImageAnalysis. O usuário pode ativar a rotação para o buffer de imagem YUV/RGB. O grau de rotação é uma rotação relativa calculada com base na rotação do sensor e na rotação desejada para manter a imagem antecipadamente.
A API setOutputImageRotationEnabled foi adicionada à configuração do ImageAnalysis. O usuário pode ativar a rotação para o buffer de imagem YUV/RGB. O grau de rotação é uma rotação relativa calculada com base na rotação do sensor e na rotação desejada para manter a imagem antecipadamente.
A API
getSensorToBufferTransformMatrix
foi adicionada ao ImageInfo. A matriz retornada é um mapeamento das coordenadas do sensor para as coordenadas do buffer, ou seja, do valor deCameraCharacteristics.SENSOR_INFO_ACTIVE_ARRAY_SIZE
para(0, 0, image.getWidth, image.getHeight)
. A matriz pode ser usada para mapear as coordenadas de um {UseCase} para outro. Por exemplo, mapeamento de coordenadas do rosto detectado com o ImageAnalysis para visualização prévia (I9ff1e).Uma nova API ImageCapture.Builder#setJpegQuality foi adicionada para permitir a mudança da qualidade de compactação de imagens JPEG de saída ao tirar fotos (I8dcf4).
Renomeação de MediaStoreOutputOptions.getCollection como MediaStoreOutputOptions.getCollectionUri (I16639).
Correções de bugs
- Foi corrigido o problema em que o flash era acionado durante o Toque para focar (startFocusAndMetering) quando o modo flash estava no automático ou sempre ativado em ambientes com pouca luz (Id4c11).
- O HDR+ foi desativado no Pixel 2 XL / Pixel 3 XL no modo MINIMIZE_LATENCY para reduzir a latência (Ib6270, b/203505523).
Contribuição externa
Versão 1.1.0-alpha10
13 de outubro de 2021
androidx.camera:camera-*:1.1.0-alpha10
é lançado. A versão 1.1.0-alpha10 contém estas confirmações.
Novos recursos
- Lançamento de
androidx.camera:camera-video:1.1.0-alpha10
como a primeira versão Alfa oficial para Video. Vários problemas conhecidos serão corrigidos nas próximas versões.
Mudanças na API
- A anotação
@RequiresApi(21)
foi adicionada a todas as classes da CameraX e a minSdkVersion foi descartada do AndroidManifest.xml. Isso permitirá que o camera-core seja facilmente integrado a aplicativos que têm uma minSdkVersion menor que 21, mas querem usar caminhos de código que dependem da API 21 e versões mais recentes condicionalmente. Em aplicativos com a minSdkVersion 21 ou versões mais recentes, nenhuma ação é necessária (Ie7f2e, b/200599470).
Correções de bugs
- Uma InitializationException foi gerada para que o app possa processar adequadamente o AssertionError ocorrido durante a criação de CameraCharacteristics (Ibec79).
Versão 1.1.0-alpha09
29 de setembro de 2021
Lançamento de androidx.camera:camera-camera2:1.1.0-alpha09
, androidx.camera:camera-core:1.1.0-alpha09
e androidx.camera:camera-lifecycle:1.1.0-alpha09
. A versão 1.1.0-alpha09 contém estas confirmações.
Mudanças na API
- A anotação ExperimentalUseCaseGroup foi removida agora que as APIs não são mais experimentais (I01ef5).
Correções de bugs
- Correção do problema em que as fotos capturadas ficam desfocadas
no modo
MAXIMIZE_QUALITY
(I173a9, b/193823892). - Correção de um problema do Samsung Galaxy J5 em que a câmera travava depois de tirar fotos com flash ativado/automático em ambiente escuro (I3aab9).
- Quando o corte é necessário para a ImageCapture, a imagem cortada é compactada com o nível de qualidade JPEG especificado de acordo com o modo de captura definido. Se o modo de captura for
CAPTURE_MODE_MINIMIZE_LATENCY
, a qualidade da compactação de JPEG será 95. Se o modo de captura forCAPTURE_MODE_MAXIMIZE_QUALITY
, a qualidade da compactação de JPEG será 100 (Ieb37c, b/142856426).
Versão 1.1.0-alpha08
18 de agosto de 2021
Lançamento de androidx.camera:camera-camera2:1.1.0-alpha08
, androidx.camera:camera-core:1.1.0-alpha08
e androidx.camera:camera-lifecycle:1.1.0-alpha08
. A versão 1.1.0-alpha08 contém estas confirmações.
Novos recursos
- Nova API setOutputImageFormat para a configuração de análise de imagem. O usuário pode selecionar ImageAnalysis.OUTPUT_IMAGE_FORMAT_YUV_420_888 ou ImageAnalysis.OUTPUT_IMAGE_FORMAT_RGBA_8888. Por padrão, ImageAnalysis.OUTPUT_IMAGE_FORMAT_YUV_420_888 é selecionada (I7902d).
Mudanças na API
- A anotação ExperimentalUseCaseGroupLifecycle foi removida, agora que as APIs não são mais experimentais (I17b85).
Correções de bugs
- A tela de visualização fixa é muito clara no Huawei P20 Lite. Esse problema só ocorre quando determinadas resoluções especiais de visualização são usadas com um valor maior de zoom (Idefce, b/192129158).
- Correção de um problema em que o flash não funcionava em alguns dispositivos ao configurar o modo flash para FLASH_MODE_ON logo após tirar fotos (Ieb49b).
- Foi corrigido o problema em que, se a VideoCapture, a ImageCapture e a visualização estivessem vinculadas, a visualização parava por um tempo ao tirar fotos (I56197, b/193864120).
- Agora o ImageAnalysis pode selecionar uma resolução maior que 1.080 pixels. Um dispositivo com o nível limitado acima pode oferecer suporte a uma resolução de tamanho RECORD para a ImageAnalysis quando ela está vinculada à Preview e à ImageCapture. A desvantagem é que a resolução selecionada para a ImageCapture também precisará ser de tamanho RECORD. Para selecionar uma resolução de tamanho RECORD para a ImageAnalysis, é preciso definir esse tipo de resolução na ImageCapture e na ImageAnalysis. Isso indica que o aplicativo entende claramente a desvantagem e prefere que a ImageAnalysis tenha uma resolução maior do que a ImageCapture para ter uma resolução MAXIMUM. Para ver as definições de RECORD, os tamanhos de MAXIMUM e mais detalhes, consulte https://developer.android.com/reference/android/hardware/camera2/CameraDevice#regular-capture. O tamanho RECORD se refere à resolução máxima de gravação com suporte no dispositivo de câmera, conforme determinado pelo CamcorderProfile. O tamanho MAXIMUM se refere à resolução máxima de saída do dispositivo da câmera para esse formato ou destino de StreamConfigurationMap.getOutputSizes(int) (I1ee97, b/192911449).
- As informações Exif foram adicionadas à imagem capturada (I01ff0, b/193342619).
- Na ImageCapture, o URI da imagem salva será retornado se o local de salvamento for File (Ib5b49, b/149241379).
- Correção de um problema em que imagens capturadas com flash ficavam escuras em muitos dispositivos (I4e510).
Versão 1.1.0-alpha07
21 de julho de 2021
Lançamento de androidx.camera:camera-camera2:1.1.0-alpha07
, androidx.camera:camera-core:1.1.0-alpha07
e androidx.camera:camera-lifecycle:1.1.0-alpha07
. A versão 1.1.0-alpha07 contém estas confirmações.
Correções de bugs
- Foi corrigido um problema do Samsung Galaxy Note 5 em que a câmera travava depois de tirar fotos com flash ativado/automático em ambientes escuros (If6871).
- Foi corrigido um problema da EOFException
YuvToJpegProcessor
quando o modo de extensão era ativado e o modoImageCapture#CAPTURE_MODE_MAX_QUALITY
estava definido (I538bd, b/192017012).
Versão 1.1.0-alpha06
30 de junho de 2021
Lançamento de androidx.camera:camera-camera2:1.1.0-alpha06
, androidx.camera:camera-core:1.1.0-alpha06
e androidx.camera:camera-lifecycle:1.1.0-alpha06
. A versão 1.1.0-alpha06 contém estas confirmações.
Mudanças na API
- As APIs experimentais de compensação de exposição do núcleo da câmera foram promovidas (I08ee8).
- Uma API isFocusMeteringSupported foi adicionada a CameraInfo, que permite que os aplicativos verifiquem se FocusMeteringAction oferece suporte à câmera atual ou não (Ib45ae, b/188606490).
- A API getResolutionInfo foi exposta para fornecer as informações de resolução para Preview, ImageCapture e ImageAnalysis (I2b613, b/188600718).
- As APIs experimentais abaixo foram promovidas a APIs oficiais: CameraXConfig.Builder#setAvailableCamerasLimiter(), CameraXConfig.Builder#setMinimumLoggingLevel(), CameraXconfig.Builder#setSchedulerHandler(), CameraXConfig#getAvailableCamerasLimiter(), CameraXConfig#getMinimumLoggingLevel(), CameraXConfig#getCameraExecutor(), CameraXConfig#getSchedulerHandler() (I2ade2).
- Aa interface CameraProvider foi exposta para fornecer acesso a um conjunto de câmeras (I1a7b1).
- A API UseCaseGroup experimental foi promovida para camera-core, camera-lifecycle e camera-video. Os elementos
ViewPort#getLayoutDirection
,ViewPort.Builder#setLayoutDirection
eViewPort.Builder#setScaleType
foram adicionados para personalizar a janela de visualização (I7cee8).
Versão 1.1.0-alpha05
2 de junho de 2021
Lançamento de androidx.camera:camera-camera2:1.1.0-alpha05
, androidx.camera:camera-core:1.1.0-alpha05
e androidx.camera:camera-lifecycle:1.1.0-alpha05
. A versão 1.1.0-alpha05 contém estas confirmações.
Mudanças na API
- Classe
Camera2CameraFilter
removida. Sugerimos que você selecione a câmera pelo CameraFilter e extraia as CameraCharacteristics ou outras informações relacionadas da Camera2 usando Camera2CameraInfo, se necessário (Ib887c). - As APIs
ExperimentalCameraFilter
agora estão fora do estágio experimental e se tornaram APIs formais. Elas podem ser usadas sem a anotação OptIn (I4bc94). - Foi adicionada uma API de estado da câmera que é exposta pelo
CameraInfo#getCameraState()
(Ia86b4). - Adição da API experimental
CameraInfo#getCameraSelector()
que retorna um CameraSelector exclusivo para a câmera (I77f9f).
Correções de bugs
- Correção do problema em que o ListenableFuture retornado por setZoomRatio, e setLinearZoom não podia ser concluído em alguns dispositivos Android 11 (I716d7).
- A alternância entre câmeras foi acelerada, e a taxa de ocorrência de erros do dispositivo foi reduzida (I34c99).
- ExperimentalUseCaseGroupLifecycle foi substituído por ExperimentalUseCaseGroup (I3b2ef, b/159033688).
Versão 1.1.0-alpha04
21 de abril de 2021
Lançamento de androidx.camera:camera-camera2:1.1.0-alpha04
, androidx.camera:camera-core:1.1.0-alpha04
e androidx.camera:camera-lifecycle:1.1.0-alpha04
. A versão 1.1.0-alpha04 contém estas confirmações.
Correções de bugs
- Correção de um vazamento de memória causado por várias linhas de execução que acessam simultaneamente a mesma coleção. O vazamento de memória pode fazer com que a atividade ou o fragmento seja retido por uma instância de visualização prévia (I7b4b8)
- A anotação
@Experimental
foi substituída por@RequiresOptIn
para APIs experimentais. Para chamar APIs experimentais, useandroidx.annotation.OptIn
em vez deandroidx.annotation.experimental.UseExperimental
, que foi descontinuado (Iff226). - Correção da ImageCapture com o flash Ligado/Automático que tira imagens desbotadas no Samsung Galaxy S7 (I30001).
- Foi adicionada uma API CameraState que será exposta pela CameraInfo (I75392).
Versão 1.1.0-alpha03
24 de março de 2021
Lançamento de androidx.camera:camera-camera2:1.1.0-alpha03
, androidx.camera:camera-core:1.1.0-alpha03
e androidx.camera:camera-lifecycle:1.1.0-alpha03
. A versão 1.1.0-alpha03 contém estas confirmações.
Correções de bugs
- Formato JPEG de saída para
ImageCapture#OnImageCapturedCallback
quando o modo Extensões foi ativado (I0d7b1). - Corrigida falha de inicialização em dispositivos UMIDIGI BISON (I57d9e, b/180818665).
- A visualização esticada no Samsung A3 foi corrigida no PreviewView (Iacb30, b/180121821).
Versão 1.1.0-alpha02
24 de fevereiro de 2021
Lançamento de androidx.camera:camera-camera2:1.1.0-alpha02
, androidx.camera:camera-core:1.1.0-alpha02
e androidx.camera:camera-lifecycle:1.1.0-alpha02
. A versão 1.1.0-alpha02 contém estas confirmações.
Mudanças na API
- Adicionada uma API
ProcessCameraProvider.getAvailableCameraInfos()
para recuperar diretamente informações sobre as câmeras disponíveis, que são todas as câmeras do dispositivo ou as selecionadas peloCameraSelector
fornecido emCameraXConfig.Builder.setAvailableCamerasLimiter(CameraSelector)
(Ieac08).
Correções de bugs
- A CameraX agora tenta forçar a abertura de uma câmera na primeira tentativa. Isso pode fazer com que ela roube a câmera de outros clientes quando o app tiver uma prioridade maior (Iab069, b/175820568).
- Correção da falha de teste Robolectric quando setAvailableCamerasLimiter é usado em CameraXConfig (Ice307).
- Essa mudança captura a exceção quando a fila de imagens é esgotada em ImageAnalysis. Por isso, em vez de uma falha, você pode notar que outros casos de uso apresentam congelamento ou lentidão. Por exemplo, visualização congelada/lenta (Ic12da, b/175851631).
- Correção de ExtensionsErrorListener para informar erros quando apenas a visualização ou a ImageCapture está vinculada (I5ae39).
- Foi corrigida a regressão de performance da ImageCapture, removendo a validação do local salvo da imagem antes de tirar uma foto. Após essa mudança, se o destino de salvamento for inválido, vai levar mais tempo para receber uma resposta de falha, já que ele vai tentar salvar a imagem depois que a foto for tirada (I1fd4e, b/177061560).
- Correção da regressão de desempenho ImageCapture com OutputFileOptions do tipo "File" (I5164a, b/177061560).
- Documentação atualizada para não recomendar o uso de
ProcessCameraProvider.configureInstance(...)
do código da biblioteca (Ib8a9f).
Versão 1.1.0-alpha01
27 de janeiro de 2021
Lançamento de androidx.camera:camera-camera2:1.1.0-alpha01
, androidx.camera:camera-core:1.1.0-alpha01
e androidx.camera:camera-lifecycle:1.1.0-alpha01
. A versão 1.1.0-alpha01 contém estas confirmações.
Correções de bugs
- Solução alternativa incluída para dados de imagem corrompidos de forma intermitente em JPEGs na câmera traseira do SM-G930T (I52001, b/159831206).
- Foi corrigido o problema
IllegalArgumentException
que ocorria quando todos os tamanhos com suporte para a visualização eram menores que 640 x 480 e o tamanho da tela era maior que 640 x 480 (I2a63c, b/150506192). - Os recursos em bibliotecas que não são explicitamente declarados públicos (por exemplo, via public.xml) agora são particulares por padrão (Ia1dcc, b/170882230).
Camera-Camera2, Camera-Core e Camera-Lifecycle: versão 1.0.2
Versão 1.0.2
29 de setembro de 2021
Lançamento de androidx.camera:camera-camera2:1.0.2
, androidx.camera:camera-core:1.0.2
e androidx.camera:camera-lifecycle:1.0.2
. A versão 1.0.2 contém estas confirmações.
Correções de bugs
- Correção do problema em que as fotos capturadas ficam desfocadas
no modo
MAXIMIZE_QUALITY
(I173a9, b/193823892). - Correção de um problema em que a imagem capturada com flash fica escura em muitos dispositivos (I4e510).
Camera-Camera2, Camera-Core e Camera-Lifecycle: versão 1.0.1
Versão 1.0.1
21 de julho de 2021
Lançamento de androidx.camera:camera-camera2:1.0.1
, androidx.camera:camera-core:1.0.1
e androidx.camera:camera-lifecycle:1.0.1
. A versão 1.0.1 contém estas confirmações.
Correções de bugs
Foi corrigido o problema em que
ListenableFuture
retornava emsetZoomRatio
e osetLinearZoom
não podia ser concluído em alguns dispositivos Android 11 (I716d7).Foi corrigido o problema em que a câmera travava ao fechar o estado em alguns dispositivos e causava visualização preta (I34c99).
Camera-Camera2, Camera-Core e Camera-Lifecycle: versão 1.0.0
Versão 1.0.0
5 de maio de 2021
Lançamento de androidx.camera:camera-camera2:1.0.0
, androidx.camera:camera-core:1.0.0
e androidx.camera:camera-lifecycle:1.0.0
. A versão 1.0.0 contém estas confirmações.
Principais recursos de 1.0.0
- A CameraX oferece suporte para Preview, ImageCapture e Analysis.
- A CameraX gerencia o ciclo de vida da câmera em uma API fácil de usar.
- A CameraX tem como objetivo fornecer uma camada de compatibilidade que corrige muitos problemas do ecossistema de câmera do Android.
Problemas conhecidos
- Consulte a lista de problemas conhecidos
Versão 1.1.0-rc05
21 de abril de 2021
Lançamento de androidx.camera:camera-camera2:1.0.0-rc05
, androidx.camera:camera-core:1.0.0-rc05
e androidx.camera:camera-lifecycle:1.0.0-rc05
. A versão 1.0.0-rc05 contém estas confirmações.
Correções de bugs
- Correção da ImageCapture com o flash Ligado/Automático que tira imagens desbotadas no Samsung Galaxy S7 (I30001).
Versão 1.0.0-rc04
24 de março de 2021
Lançamento de androidx.camera:camera-camera2:1.0.0-rc04
, androidx.camera:camera-core:1.0.0-rc04
e androidx.camera:camera-lifecycle:1.0.0-rc04
. A versão 1.0.0-rc04 contém estas confirmações.
Correções de bugs
- Corrigida falha de inicialização em dispositivos UMIDIGI BISON (I57d9e, b/180818665).
Versão 1.0.0-rc03
24 de fevereiro de 2021
Lançamento de androidx.camera:camera-camera2:1.0.0-rc03
, androidx.camera:camera-core:1.0.0-rc03
e androidx.camera:camera-lifecycle:1.0.0-rc03
. A versão 1.0.0-rc03 contém estas confirmações.
Correções de bugs
- Corrigir erro de formato no documento de
ProcessCameraProvider#getInstance
. - Correção da falha de teste Robolectric quando o setAvailableCamerasLimiter é usado no CameraXConfig.
- Foi corrigida a regressão de performance da ImageCapture, removendo a validação do local salvo da imagem antes de tirar uma foto. Após essa mudança, se o destino de salvamento for inválido, vai levar mais tempo para receber uma resposta de falha, já que ele vai tentar salvar a imagem depois que a foto for tirada.
- Essa mudança captura a exceção quando a fila de imagens é esgotada em ImageAnalysis. Por isso, em vez de uma falha, você pode notar que outros casos de uso apresentam congelamento ou lentidão. Por exemplo, visualização congelada/lenta.
- Solução alternativa incluída para dados de imagem corrompidos de forma intermitente em JPEGs na câmera traseira do SM-G930T (I52001, b/159831206).
- Essa mudança captura a exceção quando a fila de imagens é esgotada em ImageAnalysis. Por isso, em vez de uma falha, você pode notar que outros casos de uso apresentam congelamento ou lentidão. Por exemplo, visualização congelada/lenta (Ic12da, b/175851631).
- Correção da falha de teste Robolectric quando setAvailableCamerasLimiter é usado em CameraXConfig (Ice307).
- Foi corrigida a regressão de performance da ImageCapture, removendo a validação do local salvo da imagem antes de tirar uma foto. Após essa mudança, se o destino de salvamento for inválido, vai levar mais tempo para receber uma resposta de falha, já que ele vai tentar salvar a imagem depois que a foto for tirada (I1fd4e, b/177061560).
- Correção da regressão de desempenho ImageCapture com OutputFileOptions do tipo "File" (I5164a, b/177061560).
Versão 1.0.0-rc02
27 de janeiro de 2021
Lançamento de androidx.camera:camera-camera2:1.0.0-rc02
, androidx.camera:camera-core:1.0.0-rc02
e androidx.camera:camera-lifecycle:1.0.0-rc02
. A versão 1.0.0-rc02 contém estas confirmações.
Correções de bugs
- Foi corrigido o problema IllegalArgumentException, que ocorria quando todos os tamanhos com suporte para a visualização eram menores que 640 x 480 e o tamanho da tela era maior que 640 x 480 (b/150506192).
Limite o número de tentativas de reabertura da câmera. Ao tentar se recuperar de alguns problemas ao abrir a câmera, a CameraX não vai mais tentar abri-la indefinidamente. Em vez disso, ela vai parar depois de 10 segundos (I435d2).
Foi corrigido o problema
IllegalArgumentException
que ocorria quando todos os tamanhos com suporte para a visualização eram menores que 640 x 480 e o tamanho da tela era maior que 640 x 480 (I2a63c, b/150506192).
Versão 1.0.0-rc01
16 de dezembro de 2020
Lançamento de androidx.camera:camera-camera2:1.0.0-rc01
, androidx.camera:camera-core:1.0.0-rc01
e androidx.camera:camera-lifecycle:1.0.0-rc01
. A versão 1.0.0-rc01 contém estas confirmações.
Mudanças na API
- Mudança de CameraFilter e Camera2Filter para assumir CameraInfo (I6883d).
- Adição da classe experimental Camera2CameraControl para permitir a interoperação com as APIs Camera2 dinamicamente (I45cf3).
- Renomeação de Camera2CameraInfo#fromCameraInfo para #from (Ia2bd6).
- Adição de uma API setAvailableCamerasLimiter experimental ao CameraXConfig para permitir que os apps otimizem a latência de inicialização, evitando a inicialização de câmeras não usadas (I6cf88).
- Adição do método experimental
CameraXConfig.Builder#setMinimumLoggingLevel()
para permitir a definição de um nível mínimo de geração de registros da CameraX. Quando não definido, o padrão éLog#DEBUG
(Ic3245).
Correções de bugs
- Solução alternativa incluída para dados de imagem corrompidos de forma intermitente em JPEGs na câmera traseira do SM-G930V (I5aca5, b/159831206).
- Ao tirar fotos com dispositivos Samsung SM-A716, se o flash estivesse sempre/ativado e o ambiente estivesse escuro, os resultados não apareciam. Esse problema foi corrigido. (If98b2, b/172036589).
- Correção do problema em que a visualização não podia ser interrompida ao chamar
Preview.setSurfaceProvider(null)
(I3ac18). - Correção do problema de orientação ao capturar imagens de 4:3 em alguns dispositivos (I0e3fb, b/171492111).
Camera Camera2, Core e Lifecycle: versão 1.0.0-beta12
11 de novembro de 2020
Lançamento de androidx.camera:camera-camera2:1.0.0-beta12
, androidx.camera:camera-core:1.0.0-beta12
e androidx.camera:camera-lifecycle:1.0.0-beta12
. A versão 1.0.0-beta12 contém estas confirmações.
Correções de bugs
- O flash automático foi desativado nos dispositivos Samsung A3 para corrigir a falha que ocorria ao tirar uma foto com o modo AE Flash automático nos dispositivos Samsung A3 (Ia5fe3, b/157535165).
- Foi corrigido um problema em que a visualização era esticada em dispositivos Nexus 4 que executam o Android L (API de nível 21 e 22) (I4d407, b/158749159).
- A implementação da classe base
OnImageCapturedCallback#onCaptureSuccess
não fecha mais a imagem. Isso serve para evitar comportamentos inesperados pelos desenvolvedores. Os desenvolvedores não precisam depender de super.onCaptureSuccess para fechar a imagem (Ifbf9c). - A variante androidx da anotação Experimental foi descontinuada para fornecer paridade com o Kotlin. Ela foi substituída pela anotação RequiresOptIn, e a inspeção do Java foi atualizada para oferecer suporte às novas anotações do Kotlin e à nova variante do AndroidX (I52495, b/151331381).
Camera-Camera2: versão 1.0.0-beta11
14 de outubro de 2020
Lançamento do androidx.camera:camera-camera2:1.0.0-beta11
. A versão 1.0.0-beta11 contém estas confirmações.
Novos recursos
- Suporte para a API
CONTROL_ZOOM_RATIO
do Android 11 para aumentar o zoom em dispositivos com Android 11 ou mais recentes que contêmCONTROL_ZOOM_RATIO_RANGE
válido (I62cc6).
Correções de bugs
- Correção do problema NumberFormatException que ocorria quando o ID de câmera não é um número inteiro (Ib2228).
- Melhoria na latência de inicialização da CameraX e bindToLifecycle (I61dc5).
- A criação de UseCases não exige a inicialização da CameraX
para ser concluída. Todas as configurações específicas de implementação são definidas em
UseCase quando ele é anexado a uma instância de Camera, que na API
pública é
ProcessCameraProvider.bindToLifecycle()
(Ia5411). <UseCase>.getTargetRotation()
vai retornarSurface.ROTATION_0
se for chamado antes de ser anexado a uma instância de Camera, a menos que um targetRotation tenha sido definido no Builder ou UseCase (I80fcd).
Camera-Core: versão 1.0.0-beta11
14 de outubro de 2020
Lançamento do androidx.camera:camera-core:1.0.0-beta11
. A versão 1.0.0-beta11 contém estas confirmações.
Novos recursos:
compatível com a API CONTROL_ZOOM_RATIO
do Android 11 para aumentar o zoom
em dispositivos Android 11 ou versões mais recentes que contêm CONTROL_ZOOM_RATIO_RANGE
válido. (I62cc6).
Correções de bugs
- Correção do problema NumberFormatException que ocorria quando o ID de câmera não é um número inteiro (Ib2228).
- A criação de UseCases não exige a inicialização da CameraX
para ser concluída. Todas as configurações específicas de implementação são definidas em
UseCase quando ele é anexado a uma instância de Camera, que na API
pública é
ProcessCameraProvider.bindToLifecycle()
(Ia5411). <UseCase>.getTargetRotation()
vai retornarSurface.ROTATION_0
se for chamado antes de ser anexado a uma instância de Camera, a menos que um targetRotation tenha sido definido no Builder ou UseCase (I80fcd).
Camera-Core versão 1.0.0-beta10
23 de setembro de 2020
Lançamento do androidx.camera:camera-core:1.0.0-beta10
. A versão 1.0.0-beta10 contém estas confirmações.
Correções de bugs
- Correção do bug na validação do destino de salvamento de arquivo para capturas de imagem (I8c565, b/167697553).
Camera-Camera2: versão 1.0.0-beta10
23 de setembro de 2020
Lançamento do androidx.camera:camera-camera2:1.0.0-beta10
. A versão 1.0.0-beta10 contém estas confirmações.
Correções de bugs
- Lançamento do suporte à Camera-Core 1.0.0-beta10.
Camera-Camera2 versão 1.0.0-beta09
16 de setembro de 2020
Lançamento do androidx.camera:camera-camera2:1.0.0-beta09
. A versão 1.0.0-beta09 contém estas confirmações.
Mudanças na API
- Em vez de fornecer métodos estáticos, a Camera2CameraInfo usa uma instância da CameraInfo ao ser criada para acessar informações relacionadas à Camera2 (I5b844).
Correções de bugs
- Correção de um problema com a proporção desejada em tablets. Selecione um tamanho 16:9 quando a proporção desejada estiver definida como
AspectRatio.RATIO_16_9
(Ib7fcf, b/151969438). - Uma
InitializationException
foi gerada para que o app possa processar adequadamente o AssertionError ocorrido durante a criação de CameraCharacteristics (I89c8c, b/160524721). - Adição de interfaces experimentais para ExposureCompensation (If96c7).
Camera-Core: versão 1.0.0-beta09
16 de setembro de 2020
Lançamento do androidx.camera:camera-core:1.0.0-beta09
. A versão 1.0.0-beta09 contém estas confirmações.
Mudanças na API
- Correção do bug em que a janela de visualização era marcada como não nula em UseCaseGroup. Os desenvolvedores precisam ser capazes de criar uma janela de visualização sem definir uma (Ie3d2e).
- Adição de interfaces experimentais para
ExposureCompensation
(If96c7). - Permissão de rotação desejada arbitrária para o Preview. As informações de transformação são calculadas e retornadas dinamicamente ao usuário por um novo callback
TranformationInfoListener
(I21470).
Correções de bugs
- Foi corrigido o problema em que o flash em alguns dispositivos não desligava. Isso acontece quando o modo flash está definido como
FLASH_MODE_ON
para tirar uma foto e é modificado paraFLASH_MODE_OFF
quando ele é acionado. Esse sintoma é semelhante à ativação do modo lanterna (Ib4451, b/162568128). - O PreviewView é forçado a usar TextureView se o efeito de extensão está ativado e a implementação da biblioteca do fornecedor precisa executar um processo especial na plataforma de saída (I0c3cc).
- Correção do vazamento de atividades/fragmentos quando um contexto de atividade/fragmento é transmitido para
ProcessCameraProvider.getInstance(Context)
.
Problemas conhecidos
- Quando o ViewPort estiver definido, o retângulo cortado de ImageCapture poderá estar incorreto em dispositivos que giram o buffer de imagem na HAL. Isso será corrigido na próxima versão.
Camera-Camera2 versão 1.0.0-beta08
19 de agosto de 2020
Lançamento do androidx.camera:camera-camera2:1.0.0-beta08
. A versão 1.0.0-beta08 contém estas confirmações.
Correções de bugs
- bindToLifecycle foi otimizado para ser executado rapidamente na linha de execução principal (I1d57e).
- DisplayOrientedMeteringPointFactory usa uma instância de CameraInfo, em vez de CameraSelector, para que haja um mapeamento direto para que Camera vai gerar pontos. Todas as classes que usam DisplayOrientedMeteringPointFactory também aceitam uma instância de CameraInfo em vez de CameraSelector (I400c1).
- Foi corrigido o problema de agrupamento do tamanho da proporção de resolução automática em que um tamanho de 16:9 mod16 (864x480) era selecionado quando a configuração de resolução de destino era 2016x1080 e havia outro tamanho de 1920x1080 16:9 com suporte (I53167, b/159363774).
- Correção do problema de CameraControl em que ele não funciona durante uma disputa (I2279f, b/152333890, b/160714166).
Camera-Core: versão 1.0.0-beta08
19 de agosto de 2020
Lançamento do androidx.camera:camera-core:1.0.0-beta08
. A versão 1.0.0-beta08 contém estas confirmações.
Mudanças na API
DisplayOrientedMeteringPointFactory
usa uma instância deCameraInfo
, em vez deCameraSelector
, para que haja um mapeamento direto para a Camera que vai receber os pontos gerados. Todas as classes que usamDisplayOrientedMeteringPointFactory
também aceitam uma instância deCameraInfo
em vez deCameraSelector
(I400c1).
Correções de bugs
- Para captura de imagens, substitua a sinalização de virar para a horizontal nos metadados com base na direção da câmera (I28499).
- A inicialização não deve mais falhar ao usar um Context
que não retorna um objeto da Application de
Context.getApplicationContext()
(I3d3c9, b/160817073).
Camera-Camera2 versão 1.0.0-beta07
22 de julho de 2020
Lançamento do androidx.camera:camera-camera2:1.0.0-beta07
. A versão 1.0.0-beta07 contém estas confirmações.
Correções de bugs
- Corrigido o problema em que a visualização fica esticada em dispositivos legados do Android 5.0 (I0c03a).
- Alguns tamanhos com suporte para JPEG foram excluídos porque causam um problema de WYSIWYG em alguns dispositivos (Ib5128).
Camera-Core: versão 1.0.0-beta07
22 de julho de 2020
Lançamento do androidx.camera:camera-core:1.0.0-beta07
. A versão 1.0.0-beta07 contém estas confirmações.
Mudanças na API
- Os estilos fit
FIT_CENTER
,FIT_START
eFIT_END
foram mesclados comFIT
.FIT
significa que o retângulo cortado retornado terá o tamanho máximo possível do sensor (Ia73c3). - A visualização do retângulo cortado é configurada pela janela de visualização. Somente a área abrangida pelo corte deve ficar visível para os usuários finais (I142a4).
Correções de bugs
- Corrigido o problema em que a visualização fica esticada em dispositivos legados do Android 5.0 (I0c03a).
- Foi corrigido o problema de exceção
ConcurrentModificationException
ao desvincular casos de uso (I371c0).
Camera-Camera2 versão 1.0.0-beta06
24 de junho de 2020
Lançamento do androidx.camera:camera-camera2:1.0.0-beta06
. A versão 1.0.0-beta06 contém estas confirmações.
Mudanças na API
- Foram adicionadas interfaces experimentais para filtrar câmeras por ID e características da câmera (I28f61, link em inglês).
Correções de bugs
- Correção do problema em que startFocusAndMetering falha ao se concentrar no Samsung Galaxy S7 (If3be7, b/159039233, links em inglês).
- Foi corrigido o problema em que não era possível fechar a câmera depois de sair do app (I7a7b3).
- Foi corrigida a falha na visualização em que a câmera mudava repetidas vezes ao usar a implementação SurfaceView da PreviewView (I920ce).
CameraControl#startFocusAndMetering
vai falhar se nenhum dos MeteringPoint especificados puder gerar retângulos de medição válidos (Id53ce, link em inglês).
Camera-Core: versão 1.0.0-beta06
24 de junho de 2020
Lançamento do androidx.camera:camera-core:1.0.0-beta06
. A versão 1.0.0-beta06 contém estas confirmações.
Mudanças na API
- Foram adicionadas interfaces experimentais para filtrar câmeras por ID e características da câmera (I28f61, link em inglês).
Correções de bugs
- A CameraX agora pode ser configurada com
ProcessCameraProvider#configureInstance()
antes de chamarProcessCameraProvider#getInstance()
. Isso permite a personalização doCameraXConfig
sem precisar da implementação deCameraXConfig.Provider
na classe Application do app (Ia1a8d, link em inglês). CameraControl#startFocusAndMetering
vai falhar se nenhum dos MeteringPoint especificados puder gerar retângulos de medição válidos (Id53ce, link em inglês).
Camera-Camera2 versão 1.0.0-beta05
10 de junho de 2020
Lançamento do androidx.camera:camera-camera2:1.0.0-beta05
. A versão 1.0.0-beta05 contém estas confirmações.
Correções de bugs
- Foi corrigida a falha no app ao inicializar a CameraX enquanto o smartphone estava no modo não perturbe. Uma
InitializationException
contém umaCameraUnavailableException
que vai ser definida como oListenableFuture
do resultado da inicialização em vez de causar a falha do aplicativo (I9909a, b/149413835, links em inglês) - Correção da falha ao chamar
startFocusAndMetering
em dispositivos em queCONTROL_AF_STATE
é nulo. (Ife55e, b/157084254, links em inglês)
Camera-Core: versão 1.0.0-beta05
10 de junho de 2020
Lançamento do androidx.camera:camera-core:1.0.0-beta05
. A versão 1.0.0-beta05 contém estas confirmações.
Mudanças na API
- Foi corrigida a falha no app ao inicializar a CameraX enquanto o smartphone estava no modo não perturbe. Um
InitializationException
contém umCameraUnavailableException
que vai ser definido como oListenableFuture
do resultado da inicialização, em vez de causar falhas no aplicativo (I9909a, b/149413835, links em inglês).
Correções de bugs
- Atualização do Javadocs de
setTargetResolution
esetTargetRotation
. (Ia16f, link em inglês)
Camera-Camera2: versão 1.0.0-beta04
27 de maio de 2020
Lançamento do androidx.camera:camera-camera2:1.0.0-beta04
. A versão 1.0.0-beta04 contém estas confirmações.
Correções de bugs
- Permissão para aplicativos definirem qualquer parâmetro de solicitação de captura da Camera2 via
Camera2Interop
sem causar uma falha. Observe se ocorrem problemas como resultado da modificação de parâmetros. A estabilidade e o comportamento não são garantidos ao modificar parâmetros usando o Camera2Interop (Ibe5a1, b/149103700, links em inglês). - Correção da inicialização automática ao usar um app em um dispositivo usando uma pseudolocalidade. (I3bef3, b/154767663, links em inglês).
- Conversão de erros de registro relacionados ao caso de uso de remoções na depuração de registro no Camera2CameraImpl (I1a565, b/154422490, links em inglês)
- Correção do problema em que a imagem capturada fica muito escura, mesmo quando o flash é disparado (I5d9fa, b/149729613).
- Foi corrigido o bug em que o buffer em
ImageProxy
deImageCapture
não era retrocedido (I0c455, b/153249512). - Foram corrigidos os problemas em que a vinculação da ImageCapture apenas: (1) falhava ao tirar fotos com MAX_QUALITY; (2) gerava uma imagem de baixa qualidade porque a exposição automática não funcionava (I17782, b/145326998, links em inglês)
- Melhoria da confiabilidade da reabertura da câmera quando a CameraX é desconectada por outro processo ou caminho de código "roubando" a câmera (I1fbc3, b/153714651).
Camera-Core: versão 1.0.0-beta04
27 de maio de 2020
Lançamento do androidx.camera:camera-core:1.0.0-beta04
. A versão 1.0.0-beta04 contém estas confirmações.
Mudanças na API
- Adicionamos uma API experimental,
CameraXConfig.Builder#setSchedulerHandler()
, para definir o gerenciador usado internamente pela pilha de câmera da CameraX. Essa nova API junto aCameraXConfig.Builder#setCameraExecutor()
precisa permitir controle total sobre as linhas de execução usadas pela pilha de câmera da CameraX (I7bf32, b/121160431, links em inglês)
Correções de bugs
- Foram corrigidas falhas em
ImageAnalysis
, em que oImageProxy
era acessado após oImageReaderProxy
ser fechado. Isso também faz com que todos osImageProxy
recebidos peloAnalyzer
precisem estar fechados antes de oImageReaderProxy
ser fechado (I4b299, b/145956416, b/154155377, b/156357269). - Remoção do parâmetro
CameraInfo
dePreviewView#createSurfaceProvider()
. Agora,PreviewView
o recupera internamente deSurfaceRequest
(If18f0, b/154652477, links em inglês) - Correção da inicialização automática ao usar um app em um dispositivo usando uma pseudolocalidade. (I3bef3, b/154767663, links em inglês).
- Correção do problema em que a imagem capturada fica muito escura, mesmo quando o flash é disparado (I5d9fa, b/149729613).
- Correção do problema com
ImageAnalysis
em que várias chamadas para setAnalyzer/clearAnalyzer resultavam no não recebimento de imagens para análise (I6169f, b/151605317, b/153514544). - Foi corrigido o bug em que o buffer em
ImageProxy
deImageCapture
não era retrocedido (I0c455, b/153249512). - Foi corrigido o problema em que a primeira câmera na lista de recursos do
CameraManager
com suporte nem sempre estava selecionada para uso (I4c624, b/153418028, links em inglês) - Correção da falha intermitente causada pela configuração de
Preview.SurfaceProvider
que antes não liberava a superfície solicitada“java.lang.IllegalStateException: Camera surface session should only fail with request cancellation”
(I8e4e7, b/155936225, links em inglês)
Camera-Camera2 versão 1.0.0-beta03
15 de abril de 2020
Lançamento do androidx.camera:camera-camera2:1.0.0-beta03
. A versão 1.0.0-beta03 contém estas confirmações.
Correções de bugs
- Correções para oferecer suporte ao lançamento de
camera-core
.
Camera-Core: versão 1.0.0-beta03
15 de abril de 2020
Lançamento do androidx.camera:camera-core:1.0.0-beta03
. A versão 1.0.0-beta03 contém estas confirmações.
Correções de bugs
- Correção da regressão de beta03 em casos em que chamar
bindToLifecycle()
semUseCase
geraria uma exceção. Isso impediu a recuperação de umaCamera
sem vincular umUseCase
.
Camera-Camera2: versão 1.0.0-beta02
1º de abril de 2020
Lançamento do androidx.camera:camera-camera2:1.0.0-beta02
. A versão 1.0.0-beta02 contém estas confirmações.
Correções de bugs
- O
ImageInfo.getRotationDegrees()
doImageProxy
produzido porImageCapture
foi corrigido para corresponder ao valor de orientação rotacional EXIF (Id4281, b/150802561, links em inglês) - A solicitação explícita de dependências da CameraX no
build.gradle
não é mais necessária para usar a implementação padrão da CameraX/Camera2. Agora, para casos em que a declaração de dependências estritas é obrigatória, todas as dependências da CameraX podem ser incluídas no arquivo de compilação. (I46e88, link em inglês) - Correção do problema
IllegalArgumentException
que acontecia nos dispositivos em que o tamanho da tela é menor que 640 x 480. (Ife3f2, b/150506192, links em inglês) - O
bindToLifecycle
foi corrigido para que só modifique o UseCase se a vinculação for realizada. Antes, ao chamarbindToLifecycle
para fazer cálculos de resolução, o UseCase era atualizado. Agora, não é mais necessário atualizar o UseCase para fazer os cálculos (I78d9e, link em inglês)
Camera-Core: versão 1.0.0-beta02
1º de abril de 2020
Lançamento do androidx.camera:camera-core:1.0.0-beta02
. A versão 1.0.0-beta02 contém estas confirmações.
Correções de bugs
- O
ImageInfo.getRotationDegrees()
doImageProxy
produzido porImageCapture
foi corrigido para corresponder ao valor de orientação rotacional EXIF (Id4281, b/150802561, links em inglês) - O
bindToLifecycle
foi corrigido para que só modifique o UseCase se a vinculação for realizada. Antes, ao chamarbindToLifecycle
para fazer cálculos de resolução, o UseCase era atualizado. Agora, não é mais necessário atualizar o UseCase para fazer os cálculos (I78d9e, link em inglês) - Foi corrigido um problema em que a sessão de captura do caso de uso
Preview
não estava sendo atualizada quando a superfície de visualização mudava após chamarPreview.setSurfaceProvider()
mais de uma vez.
Camera-Camera2 versão 1.0.0-beta01
26 de fevereiro de 2020
Lançamento do androidx.camera:camera-camera2:1.0.0-beta01
. A versão 1.0.0-beta01 contém estas confirmações.
Correções de bugs
SurfaceRequest.setSurface(Surface)
foi renomeado comoSurfaceRequest.provideSurface(Surface)
, eSurfaceRequest.setWillNotComplete()
foi renomeado comoSurfaceRequest.willNotProvideSurface()
(I224fe).- Foi corrigido um problema com a proporção de uma imagem salva, que ficava errada
após mudar o valor de rotação desejado usando
ImageCapture.setTargetRotation()
(I474ea, b/148763432) - A inicialização de variantes do app com o ProGuard ativado foi corrigida, preservando a sinalização que define o provedor
CameraXConfig
padrão (I2d6c1).
Camera-Core versão 1.0.0-beta01
26 de fevereiro de 2020
Lançamento do androidx.camera:camera-core:1.0.0-beta01
. A versão 1.0.0-beta01 contém estas confirmações.
Mudanças na API
- Em
SurfaceRequest.provideSurface()
,ListenableFuture
foi substituído porExecutor
eCallback
. Isso simplifica a API ao não exigir mais o processamento de exceções emprovideSurface()
e faz com que o callbackprovideSurface()
não possa ser cancelado. O objetivo é evitar falhas em dispositivos mais antigos, causadas pelo lançamento prematuro de plataformas. O objetoSurfaceRequest.Result
agora é usado para rastrear como umaSurfaceRequest
usa aSurface
fornecida. (I7854b). SurfaceRequest.setSurface(Surface)
foi renomeado comoSurfaceRequest.provideSurface(Surface)
, eSurfaceRequest.setWillNotComplete()
foi renomeado comoSurfaceRequest.willNotProvideSurface()
(I224fe).
Correções de bugs
- Foi corrigido um problema com a proporção de uma imagem salva, que ficava errada
após mudar o valor de rotação desejado usando
ImageCapture.setTargetRotation()
(I474ea, b/148763432) - A inicialização de variantes do app com o ProGuard ativado foi corrigida, preservando a sinalização que define o provedor
CameraXConfig
padrão (I2d6c1). - Atualização da documentação das APIs no modo flash para incluir valores possíveis (I4a3ec).
Camera-Camera2: versão 1.0.0-alpha10
10 de fevereiro de 2020
Lançamento do androidx.camera:camera-camera2:1.0.0-alpha10
. A versão 1.0.0-alpha10 contém estas confirmações.
Correções de bugs
- Aprimoramento da estabilidade em dispositivos
INFO_SUPPORTED_HARDWARE_LEVEL_LEGACY
, garantindo queSurface
s sejam retidas somente durante o uso da Camera2 (I9dac2, link em inglês) - Correção do problema de visualização com pouca exposição em dispositivos LEGACY, ajustando
CONTROL_AE_TARGET_FPS_RANGE
corretamente (1224638, link em inglês)
Camera-Core: versão 1.0.0-alpha10
10 de fevereiro de 2020
Lançamento do androidx.camera:camera-core:1.0.0-alpha10
. A versão 1.0.0-alpha10 contém estas confirmações.
Mudanças na API
- Atualização de
ImageCapture
para que seja possível salvar imagens emUri
eOutputStream
. Os métodostakePicture
sobrecarregados foram unificados em apenas um. Atualização do app de teste para usarUri
como exemplo canônico (Ia3bec, link em inglês) Preview.PreviewSurfaceProvider
foi renomeado comoPreview.SurfaceProvider
. OsSurfaceProvider
s não exigem mais que os desenvolvedores criem o próprioListenableFuture
, e aSurface
agora é fornecida por um novo objetoSurfaceRequest
. O métodoPreview.getPreviewSurfaceProvider()
foi removido devido ao potencial de uso indevido quandoPreview
está pareado com outras classes, comoPreviewView
(I20105, link em inglês)getTargetRotation()
egetTargetName()
foram adicionados aPreview
(Iceee7).getTargetRotation()
,getBackpressureStrategy()
egetImageQueueDepth()
foram adicionados aImageAnalysis
(I9d6d9, link em inglês)getTargetRotation()
egetCaptureMode()
foram adicionados aImageCapture()
(I5bc17).- Os argumentos que anteriormente eram transmitidos em
ImageCapture.OnImageSavedCallback.onError()
eImageCapture.OnImageCapturedCallback.onError()
foram substituídos por um único argumentoImageCaptureException
, que ainda contém todas as informações transmitidas anteriormente. - O argumento do arquivo anteriormente transmitido em
ImageCapture.OnImageSavedCallback.onImageSaved()
foi removido (I750d2, link em inglês) - As classes
Preview
eImageCapture
agora são marcadas como finais. (I2500b, link em inglês). - A API foi atualizada com os métodos
getZoomRatio()
,getMaxZoomRatio()
,getMinZoomRatio()
egetLinearZoom()
de junção daCameraInfo
emgetZoomState()
, que retorna uma instânciaZoomState
(Ib19fe). - Os campos de API
OPTION_TARGET_CLASS
eOPTION_TARGET_NAME
deCameraXConfig
foram removidos, já que são destinados apenas para uso de biblioteca interna. Remoção do construtor deCameraXConfig.Builder
(I96912, link em inglês) - Remoção da exigência de que o app inclua
Application
para inicializar a CameraX. A CameraX agora vai ser inicializada com uma configuração Camera2 padrão, desde que o artefatocamera-camera2
esteja incluído nobuild.gradle
do aplicativo (I58ff5, b/146923574).
Camera-Camera2 versão 1.0.0-alpha09
22 de janeiro de 2020
Lançamento do androidx.camera:camera-camera2:1.0.0-alpha09
. A versão 1.0.0-alpha09 contém estas confirmações.
Mudanças na API
Adição de caminho de interoperabilidade de camera2 para extração de um ID de câmera Camera2. Você pode extrair o ID de câmera de
CameraInfo
usandoCamera2CameraInfo.extractCameraId()
. O exemplo de código a seguir mostra como fazer isso:Camera camera = provider.bindToLifecycle(...); String cameraId = Camera2CameraInfo.extractCameraId(camera.getCameraInfo());
A classe
Camera2CameraInfo
precisa da markerClassExperimentalCamera2Interop
.
Camera-Core versão 1.0.0-alpha09
22 de janeiro de 2020
Lançamento do androidx.camera:camera-core:1.0.0-alpha09
. A versão 1.0.0-alpha09 contém estas confirmações.
Mudanças na API
- O parâmetro
SurfaceOrientedMeteringPointFactory
useCaseForSurface
foi renomeado comouseCaseForAspectRatio
, e a documentação de referência foi expandida. - Os métodos
FocusMeteringAction.Builder.from()
foram substituídos pelos construtoresFocusMeteringAction.Builder()
. - A função
DisplayOrientedMeteringPointFactory(android.content.Context, androidx.camera.core.CameraSelector, float, float)
foi removida. Os aplicativos precisam usar o construtor que aceita um parâmetroDisplay
e transmitir a exibição atual. - O Javadoc foi melhorado para APIs de foco e medição relacionadas a
MeteringMode
, sinalizações 3A e ao uso do parâmetroDisplay
. - Expansão da documentação de referência para
setZoomRatio
esetLinearZoom
.
Correções de bugs
- Correção de problemas ao fechar e abrir câmeras, que resultam em falha na verificação de "pré-condição".
- Correção de uma
ConcurrentModificationException
que podia ocorrer ao usar as APIs de lanterna e zoom. - Correção do problema para selecionar resoluções mais próximas da solicitada quando um tamanho de dimensões mod16 está disponível.
- As APIs
startFocusMetering
ecancelFocusMetering
agora se comportam conforme documentadas, com o tempo correto e possivelmente retornando erros quando ocorrem. - Foi corrigido o problema que ocorria quando uma resolução específica era solicitada com uma proporção de corte em um dispositivo que não oferecia suporte para aquele tamanho. Agora, um tamanho não cortado de resolução suficiente será selecionado, quando disponível, para vincular a solicitação original.
Camera-Camera2 versão 1.0.0-alpha08
18 de dezembro de 2019
Lançamento do androidx.camera:camera-camera2:1.0.0-alpha08
. A versão 1.0.0-alpha08 contém estas confirmações.
Problemas conhecidos
- Nem todas as opções de solicitação de captura de Camera2 funcionam ao usar a interoperabilidade de Camera2. Se não houver suporte para a opção solicitada, a sessão não vai ser iniciada, resultando possivelmente em um erro como este:
09-09 14:04:13.643 10117 26020 26036 E AndroidRuntime: java.lang.IllegalArgumentException: Unsupported session configuration combination
Correções de bugs
- Foi corrigido um problema em que uma tela preta de visualização aparecia após girar ou alternar a câmera para os níveis de API 21 e 22.
Mudanças na API
- Experimental: adição de um caminho de interoperabilidade de camera2 para extrair o ID da câmera.
Camera-Core Versão 1.0.0-alpha08
18 de dezembro de 2019
Lançamento do androidx.camera:camera-core:1.0.0-alpha08
. A versão 1.0.0-alpha08 contém estas confirmações.
Problemas conhecidos
- Os apps que usam
PreviewView
ouCameraView
podem ter uma proporção incorreta na visualização. Isso acontece depois de uma pausa ou retomada em alguns dispositivos FULL, como o Pixel2.
Correções de bugs
- Atualização da documentação de
FocusMeteringAction
eCameraControl
. - Implementação de
TorchControl
paraenableTorch()
egetTorchState()
.
Mudanças na API
- IntDefs foram ocultadas, e constantes de IntDef foram removidas da definição de IntDef.
rotationDegrees
movido da classeOnImageCaptureCallback
paraImageInfo
.rotationDegrees
movido da classeAnalyzer
paraImageInfo
.
Camera-Camera2 Versão 1.0.0-alpha07
4 de dezembro de 2019
Lançamento do androidx.camera:camera-camera2:1.0.0-alpha07
. A versão 1.0.0-alpha07 da camera-camera2 contém estas confirmações (link em inglês).
Camera2Config
agora está disponível para uso na inicialização e na configuração de uma implementação baseada na Camera2 para a CameraX. Mais detalhes sobre como usar esse recurso na inicialização podem ser encontrados na seção camera-core das notas da versão.- A funcionalidade de interoperabilidade da camera2 agora está marcada como experimental e foi movida para um pacote separado,
androidx.camera.camera2.interop.
.
Camera-Core Versão 1.0.0-alpha07
4 de dezembro de 2019
Lançamento do androidx.camera:camera-core:1.0.0-alpha07
. A versão 1.0.0-alpha07 da camera-core contém estas confirmações (link em inglês).
Observe que há algumas mudanças significativas nessa versão Alfa conforme nos preparamos para a versão Beta. Recomendamos que você analise as mudanças e deixe seu feedback no Grupo do Google sobre CameraX. Para os desenvolvedores que usam a CameraX em apps que estão na Play Store, recomendamos esperar a versão Beta formal antes de fazer o upgrade da biblioteca nos aplicativos.
Mudanças na API
Importante: a inicialização da CameraX mudou. Os aplicativos precisam implementar
CameraXConfig.Provider
e usar aCamera2Config
padrão fornecida porandroidx.camera.camera2
. Veja um uso típico:import androidx.camera.camera2.Camera2Config import androidx.camera.core.CameraXConfig public class MyCameraXApplication : Application(), CameraXConfig.Provider { override fun getCameraXConfig(): CameraXConfig { return Camera2Config.defaultConfig(this) } }
A classe CameraX foi removida.
bindToLifecycle()
,unbind()
,unbindAll()
,isBound()
ehasCamera()
, anteriormente fornecidos pela chamada de classe da CameraX, agora estão disponíveis peloProcessCameraProvider
.Uma instância por processo de
ProcessCameraProvider
é recebida de maneira assíncrona usando o método estáticoProcessCameraProvider.getInstance()
, que retorna um futuro audível, que, por sua vez, fornece oProcessCameraProvider
na conclusão. Aqui, ele é mostrado emonCreate()
em um uso típico. Você pode fazer chamadas paragetInstance()
posteriormente no ciclo de vida da atividade para adiar a latência de inicialização. Por exemplo, para quando uma ação do usuário abrir a interface de uma câmera.import androidx.camera.lifecycle.ProcessCameraProvider import com.google.common.util.concurrent.ListenableFuture class MainActivity : AppCompatActivity() { private lateinit var cameraProviderFuture : ListenableFuture<ProcessCameraProvider> override fun onCreate(savedInstanceState: Bundle?) { cameraProviderFuture = ProcessCameraProvider.getInstance(this); }
Um listener pode ser adicionado ao
ListenableFuture
retornado porgetInstance()
. Isso garante que o provedor da câmera possa ser recuperado doFuture
sem bloqueio emFuture.get()
cameraProviderFuture.addListener(Runnable { val cameraProvider = cameraProviderFuture.get() cameraProvider.bindToLifecycle(...) }, ContextCompat.getMainExecutor(this))
A seleção da câmera agora é feita por um seletor de câmera, e não mais por caso de uso.
val cameraSelector = CameraSelector.Builder().requireLensFacing(LensFacing.BACK).build()
CameraProvider.bindToLifecycle
recebe o proprietário do ciclo de vida, o seletor de câmera e casos de uso, que são vinculados ao proprietário do ciclo de vida e executados para a câmera selecionada.cameraProvider.bindToLifecycle(this as LifecycleOwner, cameraSelector, preview, imageAnalysis)
As classes "Config" de caso de uso foram removidas. Em vez disso, crie casos de uso diretamente, definindo opções em cada builder de casos de uso. Por exemplo:
preview = Preview.Builder().setTargetAspectRatio(AspectRatio.RATIO_16_9).build()
O caso de uso da visualização foi atualizado para aceitar uma superfície criada e gerenciada pelo aplicativo a fim de garantir as práticas recomendadas do Android. É altamente recomendável usar a classe de visualização
PreviewView
fornecida no pacote camera-view.preview.setPreviewSurfaceProvider(previewView.previewSurfaceProvider)
Consulte a documentação para anexar uma superfície gerenciada pelo aplicativo. Nesses casos, o app gerencia o ciclo de vida da superfície.
Importante: a implementação do método Analyzer
ImageAnalysis
precisa chamarimage.close()
nas imagens recebidas quando terminar o uso delas. Caso contrário, novas imagens podem não ser recebidas ou a câmera pode travar, dependendo da configuração de pressão de retorno. Consulte os documentos de referência para ver detalhes.ImageAnalysis ImageReaderMode
foi mudado para uma estratégia de pressão de retornointdef
.ImageProxy.getImage()
está marcado como experimental. Os aplicativos precisam anotar o uso, por exemplo, com@androidx.camera.core.ExperimentalGetImage
.O requisito de anotação
UIThread
para oAnalyzer
foi removido.A função
ImageAnalysis.clearAnalyzer()
é adicionada para remover um analisador.Os listeners com mais de um método foram renomeados para Callback:
ImageCapture.OnImageCapturedListener
agora éImageCapture.OnImageCapturedCallback
ImageCapture.OnImageSavedListener
agora éImageCapture.OnImageSavedCallback
VideoCapture.OnVideoSavedListener
agora éVideoCapture.OnVideoSavedCallback
Enums foram mudados para IntDef.
Controles de zoom foram adicionados:
CameraControl.setLinearZoom()
CameraControl.setZoomRatio()
CameraInfo.getLinearZoom()
CameraInfo.getMaxZoomRatio()
CameraInfo.getZoomRatio()
CameraInfo.hasFlashUnit()
foi adicionado para determinar se o hardware de flash/lanterna está presente.O
CameraInfo.isFlashAvailable()
foi removido. A lanterna substitui a funcionalidade do flash. Mais detalhes estão incluídos na documentação de referência.Os campos
ImageCapture.Metadata
foram substituídos por acessadores get/set/is.startFocusMetering
ecancelFocusMetering
agora retornamListenableFutures
, que representam a operação assíncrona da chamada.MeteringPoints
agora funcionam como identificadores para ações de medição e são produzidos por fábricas. Os apps devem usar as fábricas já existentes, em vez de fábricas personalizadas.
Problemas corrigidos
- Correção do problema ao tirar uma foto depois da retomada. Após uma pausa, a foto ficava pendente.
- Problema conhecido:
CameraControl.enableTorch()
é funcional, mas oListenableFuture<Void>
retornado é sempre um futurocomplete(success)
imediato, mesmo sem uma unidade de flash. As próximas versões vão corrigir esse problema no comportamento final: quando não houver unidade de flash,enableTorch(true)
vai falhar imediatamente (não enviando a solicitação paraCaptureSession
) eTorchState
vai permanecer desativado. - Problema conhecido:
startFocusAndMetering
ecancelFocusAndMetering
iniciam e cancelam a medição de foco, mas retornam um futurocompleted (success)
imediato que não representa o comportamento documentado. OFocusMeteringResult
deListenableFuture<FocusMeteringResult> CameraControl.startFocusAndMetering()
é um resultado falso queisFocusSuccessful()
e é sempre "false", diferentemente do comportamento documentado e pretendido. - Problema conhecido: uma fábrica de pontos de medição para uso com eventos de toque
PreviewView
está sendo desenvolvida. Por enquanto, os apps que conectam superfícies gerenciadas personalizadas podem usar as fábricas de pontos de medição já existentes. Caso contrário, nenhuma funcionalidade de toque de foco vai estar disponível paraPreviewView
.
Camera-Camera2 e Camera-Core Versão 1.0.0-alpha06
9 de outubro de 2019
Lançamento de androidx.camera:camera-camera2:1.0.0-alpha06
e androidx.camera:camera-core:1.0.0-alpha06
. Estas são as confirmações incluídas em camera-camera2:1.0.0-alpha06
e estas são as confirmações incluídas em camera-core:1.0.0-alpha06
.
Novos recursos
Mudanças nas proporções de configuração:
setTargetAspectRatioMode()
foi adicionado e aceita um argumento enum. Isso define o modo de proporção com as opçõesRATIO_4_3
ouRATIO_16_9
em vez de uma proporção arbitrária. Isso reflete o fato de que apenas certas proporções são fornecidas pela câmera, em vez de proporções arbitrárias.- Atualmente, as únicas proporções disponíveis são 16:9 e 4:3. No caso de dispositivos 1:1, apenas alguns dispositivos têm essa opção disponível na câmera e apenas em resoluções limitadas. Os aplicativos que projetam uma interface 1:1 ou processamento individual precisam usar as opções mais flexíveis 16:9 ou 4:3 e cortar a exibição ou processar uma sub-região.
- Essas proporções são orientadas para usar a área máxima do sensor.
getTargetAspectRatio()
foi adicionado para usar as APIs de configuração de caso de uso, retornando a proporção destinada para a saída de caso de uso.- O método
setTargetAspectRatio(Rational aspectRatio)
foi modificado para ImageCapture parasetTargetAspectRatioCustom(Rational aspectRatio)
. Quando definido, a saída de ImageCapture será cortada da forma correta.
APIs Executor
- As funções a seguir aceitam um parâmetro de executor, que permite ao app controlar em qual executor a função vai ser executada.
- API
Preview.setOnPreviewOutputUpdateListener()
. Se o executor não estiver presente para essa função, ele vai ser executado na linha de execução principal. Preview.setOnPreviewOutputUpdateListener
FocusMeteringAction.Builder.setAutoFocusCallback
ImageAnalysis.setAnalyzer
ImageCapture.takePicture
CameraView.takePicture
CameraView.startRecording
VideoCapture.startRecording
- API
CameraInfo adicionada com Check Flash disponível e APIs de rotação do sensor
Adicionamos
CameraInfo
e um métodogetCameraInfo
, que permite que os apps verifiquem se uma lente com a CameraInfo está disponível e se há um flash disponível na câmera. Por exemplo:try { CameraInfo cameraInfo = CameraX.getCameraInfo(currentCameraLensFacing); LiveData<Boolean> isFlashAvailable = cameraInfo.isFlashAvailable(); flashToggle.setVisibility(isFlashAvailable.getValue() ? View.VISIBLE : View.INVISIBLE); } catch (CameraInfoUnavailableException e) { Log.w(TAG, "Cannot get flash available information", e); flashToggle.setVisibility(View.VISIBLE); }
Adição de
CameraInfo.getSensorRotationDegrees()
Ele fornece a orientação do sensor da câmera em relação à orientação natural do dispositivo, ou para conveniência, em relação a uma orientação descrita por uma rotação de superfície (que descreve uma orientação relativa à orientação natural).
Mudanças na API e correções de bugs
- Proporções: para cada caso de uso, é preciso que os aplicativos chamem apenas um de
setTargetResolution()
ousetTargetAspectRatio()
. Chamar ambos no mesmo builder retornará um erro.- Em geral, recomenda-se usar
setTargetAspectRatio()
com base no design da interface do aplicativo. Resoluções específicas serão baseadas no caso de uso. Por exemplo, a visualização vai ser próxima a resoluções de tela, e a captura de imagem vai fornecer imagens estáticas de alta resolução. Consulte a tabela de resoluções automáticas para ter mais informações. - Use
setTargetResolution()
para casos mais específicos, por exemplo, quando as resoluções mínimas (para salvar o cálculo) ou máximas (para detalhes de processamento) forem necessárias.
- Em geral, recomenda-se usar
- API Executor: a chamada
setCallbackHandler()
foi removida das APIs de configuração de casos de uso. Em vez disso, os aplicativos podem definir o executor como um parâmetro em várias outras APIs que definem um callback. - Anotações nulas atualizadas para várias funções.
- Correção de um problema que fazia com que
java.lang.IllegalStateException at Camera$StateCallback.onError
fosse gerado ao abrir a câmera. - Foi corrigido o problema que selecionava resoluções muito pequenas (menos de 640 x 480) quando o app solicitava resoluções maiores ou padrão, resultando em uma imagem de visualização bloqueada ou desfocada. Os aplicativos que precisam especificamente de resoluções menores podem solicitá-los explicitamente.
- Correção de um problema em que a câmera mostrava uma tela preta (falha ao iniciar a câmera) após retornar de uma intent que acionou outro aplicativo de câmera.
- Correção de um bug que gerava o seguinte erro quando os apps eram iniciados ou interrompidos várias vezes:
java.lang.IllegalArgumentException: CaptureRequest contains unconfigured Input/Output Surface!
- Correção do seguinte erro que ocorre ao desativar a ImageAnalysis:
java.lang.IllegalStateException: maxImages (4) has already been acquired, call #close before acquiring more.
- Foram adicionamos mais testes para o fluxo de desconexão da câmera.
- Mais robustez do sistema de testes ao realizar testes consecutivos de câmera.
Camera-Camera2 e Camera-Core Versão 1.0.0-alpha05
5 de setembro de 2019
Lançamento de androidx.camera:camera-camera2:1.0.0-alpha05
e androidx.camera:camera-core:1.0.0-alpha05
. Estas são as confirmações incluídas em camera-camera2:1.0.0-alpha05, e estas são as confirmações incluídas em camera-core:1.0.0-alpha05.
Mudança da API: variáveis de erro de caso de uso renomeadas:
ImageCapture.UseCaseError
foi renomeado paraImageCapture.ImageCaptureError
VideoCapture.UseCaseError
foi renomeado paraVideoCapture.VideoCaptureError
A API
CameraControl
foi adicionada às APIs do recurso Toque para focar.A API foi adicionada para receber um
CameraControl
da CameraX para uma câmera, selecionada com "lens facing":CameraX.getCameraControl(LensFacing lensFacing)
MeteringPointFactory
,MeteringPoint
,MeteringMode
eFocusMeteringAction
foram adicionados para executar o Toque para focar.MeteringPointFactory factory = new SensorOrientedMeteringPointFactory(width, height); MeteringPoint point = factory.createPoint(x, y); FocusMeteringAction action = FocusMeteringAction.Builder.from(point, MeteringMode.AF_ONLY) .addPoint(point2, MeteringMode.AE_ONLY) // could have many .setAutoFocusCallback(new OnAutoFocusListener(){ public void onFocusCompleted(boolean isSuccess) { } }) // auto calling cancelFocusAndMetering in 5 sec. .setAutoCancelDuration(5, TimeUnit.Second) .build();
Adição da API para
CameraControl
iniciar e cancelar a medição de foco:getCameraControl(lensFacing).startFocusAndMetering(action);
getCameraControl(lensFacing).cancelFocusAndMetering();
APIs foram adicionadas às Metering Point Factories que auxiliam na conversão de coordenadas de toque para coordenadas de sensor, com base nas classes de visualização:
MeteringPointFactory factory = new TextureViewMeteringPointFactory(textureView);
MeteringPointFactory factory = new DisplayOrientedMeteringPointFactory(context, lensFacing, viewWidth, viewHeight);
Aplique chamando os seguintes métodos na linha de execução principal (interface), gerando um
IllegalStateException
quando não estiverem. Versões futuras vão permitir o uso em outras linhas de execução e garantir a serialização.CameraX.bindToLifecycle()
CameraX.unbind()
CameraX.unbindAll()
ImageAnalysis.setAnalyzer()
ImageAnalysis.getAnalyzer()
ImageAnalysis.removeAnalyzer()
Preview.removePreviewOutputListener()
Preview.getOnPreviewOutputUpdateListener()
Preview.setOnPreviewOutputUpdateListener()
Várias configurações agora aceitam parâmetros nulos, e getters correspondentes podem retornar nulo.
Foi corrigido um problema ao testar em emuladores que não oferecem suporte às configurações de AF/AE/AWB.
Correção do bug de falha na rotação durante a análise da imagem.
Correção do bug em que a visualização aparece em preto no início (sem dados da câmera), após a rotação ou alterna entre as câmeras frontal e traseira.
Remoção de testes para vários casos de uso simultâneos de análise de imagem. Para garantir a compatibilidade, os aplicativos só devem anexar um único caso de uso de análise de imagem.
Adicionados testes robolétricos iniciais para a câmera falsa no conjunto de teste de câmera (WIP).
Remoção do teste do Camera2Inititalizer porque a cobertura não era clara ou era enganosa.
Camera-Camera2 e Camera-Core Versão 1.0.0-alpha04
7 de agosto de 2019
Lançamento de androidx.camera:camera-camera2:1.0.0-alpha04
e androidx.camera:camera-core:1.0.0-alpha04
. A versão 1.0.0-alpha04 contém estas confirmações (link em inglês).
Novos recursos
Alterações na seleção de Proporção e de Resolução
O objetivo da CameraX é inicializar uma sessão de câmera. Isso significa que a CameraX vai comprometer a resolução/proporção com base na capacidade do dispositivo, a fim de iniciar uma sessão de captura como principal objetivo. Assim, é possível que as solicitações não sejam atendidas de maneira precisa. Isso pode acontecer porque:
- Os dispositivos não são compatíveis com a resolução solicitada.
- Existem problemas de compatibilidade, como em dispositivos LEGADOS, em que determinadas resoluções precisam ser usadas para um funcionamento correto.
- Em alguns dispositivos, determinados formatos estão disponíveis apenas em proporções específicas.
- Existe uma preferência por um "mod16 mais próximo" para codificação JPEG ou de vídeo. Consulte
CameraCharacteristics#SCALER_STREAM_CONFIGURATION_MAP
.
Embora a CameraX crie e gerencie a sessão, sempre verifique os tamanhos de imagem retornados na saída do caso de uso no seu código e faça as modificações necessárias.
Algumas mudanças foram feitas para definir resoluções e proporções, com o objetivo de tornar a API mais clara:
- Agora, quando nenhuma outra proporção estiver definida, o caso de uso de visualização terá uma proporção padrão de 4:3.
- Quando a CameraX considerar internamente mudanças para resoluções e proporções solicitadas com base na capacidade do dispositivo, ela tentará primeiramente manter a mesma proporção (conforme determinado por qualquer uma das chamadas
setTargetAspectRatio
ousetTargetResolution
) - Uma versão "mod16 mais próximo" da resolução é considerada como a mesma proporção.
Modo sem bloqueio do ImageAnalysis
- O comportamento de
ImageReaderMode.ACQUIRE_LATEST_IMAGE
não faz bloqueios. Ele adquire a imagem mais recente na fila, mas descarta as imagens não usadas continuamente para permitir que o pipeline da câmera evite o bloqueio. - O analisador pode manter uma única imagem indefinidamente, sem paralisar o pipeline.
- Se o aplicativo disponibilizar um executor que faça bloqueios, o caso de uso do ImageAnalysis vai ser bloqueado.
- O conjunto de executores padrão se comporta internamente como um executor sem bloqueio.
Correções de bugs
- Foram corrigidos problemas de tempo limite que aguardavam convergência 3A ao capturar imagens em dispositivos sem foco, exposição e balanço de branco automáticos.
- Correção do problema que ocorria ao tirar fotos rapidamente com o ImageCapture. Correção de erro:
java.lang.IllegalStateException: maxImages (2) has already been acquired
- Um problema que ocorria quando o atributo
setLensFacing
não era chamado para um caso de uso, resultando em umajava.lang.IllegalArgumentException: Unable to get camera ID for use case
foi corrigido. - Correção do problema que ocorria quando o dispositivo LEGADO exigia uma proporção específica como resolução JPEG máxima.
- Correção do problema que ocorria ao colocar o app em segundo plano enquanto a câmera era inicializada.
- O problema em APIs anteriores à 25 foi corrigido com a remoção do erro
checkAndUpdateEglState: invalid current EGLDisplay
. - Correção do problema ao desvincular a visualização depois de ativar e iniciar extensões.
- Artefatos de build para visualização e extensões de câmera agora são publicados como versões Alfa.
Camera-Camera2 e Camera-Core Versão 1.0.0-alpha03
2 de julho de 2019
Lançamento de androidx.camera:camera-core:1.0.0-alpha03
e androidx.camera:camera-camera2:1.0.0-alpha03
. A versão 1.0.0-alpha03 contém estas confirmações.
Mudanças na API
- Adição de esclarecimento javadoc para "target" nas chamadas de configuração setTarget.
Camera-Core
- Foi corrigida a falha de superfície de entrada/saída não configurada ao abrir/fechar ou vincular/desvincular rapidamente.
- Movimentação para novas implementações de Futures.
- Correções de teste para aumentar a robustez.
- O teste de integração do Core agora mostra o tempo de captura de fotos.
- Desenvolvimento de classe compat interna para executores.
- As imagens de captura do app de teste de tempo aguardam que as anteriores fiquem completas e com estabilidade aprimorada.
Extensões
- Adição de verificações de controle de versão
- Cobertura de teste extra: callbacks de evento de extensão
- Melhorias para imagem e metadados correspondentes internamente
- Correção da alternância de modo no app de teste
Camera-Camera2 e Camera-Core Versão 1.0.0-alpha02
5 de junho de 2019
Lançamento de androidx.camera:camera-core:1.0.0-alpha02
e androidx.camera:camera-camera2:1.0.0-alpha02
. A versão 1.0.0-alpha02 contém estas confirmações.
Correções de bugs
- Correção do problema de divisão por zero ao usar o emulador.
- Foi corrigido o erro NullPointerException/Surface Abandoned, que ocorria em alguns dispositivos ao tirar fotos rapidamente durante a desvinculação e nova vinculação de casos de uso em pouco tempo.
- Foi corrigido um problema interno para garantir que as atualizações da solicitação de captura afetem todas as superfícies de forma consistente.
- Melhorias de estabilidade ao reiniciar casos de uso em novas instâncias de apps.
- Alterações na arquitetura interna para preparar a compatibilidade com executores na API.
- Esclarecimentos extras do Javadoc sobre gerenciamento de classes e ciclos de vida da CameraX.
- Adição de teste de instrumentação para o app de teste de desempenho Antelope.
- Remoção da necessidade de "-keepattributes Signature" na configuração do Proguard para apps.
Camera-Camera2 e Camera-Core 1.0.0-alpha01
7 de maio de 2019
Lançamento de androidx.camera:camera-core:1.0.0-alpha01
e androidx.camera:camera-camera2:1.0.0-alpha01
. A versão 1.0.0-alpha01 contém estas confirmações.
Camera-Lifecycle: versão 1.0.0-beta11
14 de outubro de 2020
Lançamento do androidx.camera:camera-lifecycle:1.0.0-beta11
. A versão 1.0.0-beta11 contém estas confirmações.
Correções de bugs
<UseCase>.getTargetRotation()
vai retornarSurface.ROTATION_0
se for chamado antes de ser anexado a uma instância de Camera, a menos que um targetRotation tenha sido definido no Builder ou UseCase (I80fcd).
Camera-Lifecycle versão 1.0.0-beta10
23 de setembro de 2020
Lançamento do androidx.camera:camera-lifecycle:1.0.0-beta10
. A versão 1.0.0-beta10 contém estas confirmações.
Correções de bugs
- Lançamento do suporte à Camera-Core 1.0.0-beta10.
Camera-Lifecycle versão 1.0.0-beta09
16 de setembro de 2020
Lançamento do androidx.camera:camera-lifecycle:1.0.0-beta09
. A versão 1.0.0-beta09 contém estas confirmações.
Camera-Lifecycle versão 1.0.0-beta08
19 de agosto de 2020
Lançamento do androidx.camera:camera-lifecycle:1.0.0-beta08
. A versão 1.0.0-beta08 contém estas confirmações.
Correções de bugs
- A inicialização não deve mais falhar ao usar um Context
que não retorna um objeto da Application de
Context.getApplicationContext()
(I3d3c9, b/160817073).
Camera-Lifecycle versão 1.0.0-beta07
22 de julho de 2020
Lançamento do androidx.camera:camera-lifecycle:1.0.0-beta07
. A versão 1.0.0-beta07 contém estas confirmações.
Camera-Lifecycle versão 1.0.0-beta06
24 de junho de 2020
Lançamento do androidx.camera:camera-lifecycle:1.0.0-beta06
. A versão 1.0.0-beta06 contém estas confirmações.
Mudanças na API
- Agora, a CameraX pode ser configurada com o ProcessCameraProvider#configureInstance() antes de chamar ProcessCameraProvider#getInstance(). Isso permite a personalização do CameraXConfig sem precisar implementar CameraXConfig.Provider na classe Application do app (Ia1a8d, link em inglês).
Camera-Lifecycle versão 1.0.0-beta05
10 de junho de 2020
Lançamento do androidx.camera:camera-lifecycle:1.0.0-beta05
. A versão 1.0.0-beta05 contém estas confirmações.
Correções de bugs
- Foi corrigida a falha no app ao inicializar a CameraX enquanto o smartphone estava no modo não perturbe. Um
InitializationException
contém umCameraUnavailableException
que vai ser definido como oListenableFuture
do resultado da inicialização, em vez de causar falhas no aplicativo (I9909a, b/149413835, links em inglês)
Camera-Lifecycle: versão 1.0.0-beta04
27 de maio de 2020
Lançamento do androidx.camera:camera-lifecycle:1.0.0-beta04
. A versão 1.0.0-beta04 contém estas confirmações.
Camera-Lifecycle versão 1.0.0-beta03
15 de abril de 2020
Lançamento do androidx.camera:camera-lifecycle:1.0.0-beta03
. A versão 1.0.0-beta03 contém estas confirmações.
Correções de bugs
- Correção da regressão de beta03 em casos em que chamar
bindToLifecycle()
semUseCase
geraria uma exceção. Isso impediu a recuperação de umaCamera
sem vincular umUseCase
. - Correções para oferecer suporte ao lançamento de
camera-core
.
Camera-Lifecycle versão 1.0.0-beta01
26 de fevereiro de 2020
Lançamento do androidx.camera:camera-lifecycle:1.0.0-beta01
. A versão 1.0.0-beta01 contém estas confirmações.
Correções de bugs
- A documentação foi corrigida para mencionar que, ao receber um
ProcessCameraProvider
durante a inicialização, uma configuração padrão é usada e a extensão deApplication
é opcional (I5e395).
Camera-Lifecycle: versão 1.0.0-beta02
1º de abril de 2020
Lançamento do androidx.camera:camera-lifecycle:1.0.0-beta02
. A versão 1.0.0-beta02 contém estas confirmações.
Correções de bugs
- Atualização para oferecer suporte às correções de bugs nos artefatos
camera-camera2:1.0.0-beta02
ecamera-core:1.0.0-beta02
.
Camera-Lifecycle: versão 1.0.0-alpha10
10 de fevereiro de 2020
Lançamento do androidx.camera:camera-lifecycle:1.0.0-alpha10
. A versão 1.0.0-alpha10 contém estas confirmações.
Mudanças na API
- A anotação
@MainThread
foi adicionada aos métodos BindToLifecycle, unind e unindAll (I990d2, link em inglês)
Camera-Lifecycle versão 1.0.0-alpha03
22 de janeiro de 2020
androidx.camera:camera-lifecycle:1.0.0-alpha03
é lançado. A versão 1.0.0-alpha03 contém estas confirmações.
Atualizações
- Várias correções e atualizações compatíveis com as mudanças de Camera Core e Camera2.
Camera-Lifecycle Versão 1.0.0-alpha02
18 de dezembro de 2019
Lançamento do androidx.camera:camera-lifecycle:1.0.0-alpha02
. A versão 1.0.0-alpha02 contém estas confirmações.
Mudanças na dependência
- Atualizada para usar
androidx.camera:camera-core:1.0.0-alpha08
.
Camera-Lifecycle Versão 1.0.0-alpha01
4 de dezembro de 2019
Lançamento do androidx.camera:camera-lifecycle:1.0.0-alpha01
. A versão 1.0.0-alpha01 do camera-lifecycle contém estas confirmações (link em inglês).
Observações sobre a API
- O artefato camera-lifecycle foi adicionado, fornecendo a interface
LifeCycleCameraProvider
e uma implementação chamadaProcessCameraProvider
, que oferece muitas das funções da classe CameraX anterior no núcleo e é usada por meio do métodogetInstance()
. - Os apps precisam incluir a biblioteca camera-lifecycle para usar a CameraX.
- Veja as notas na seção camera-core sobre como inicializar a CameraX usando um
ProcessCameraProvider
.
Camera-Extensions e Camera-View: versão 1.0.0
Versão 1.0.0-alpha32
15 de dezembro de 2021
Lançamento de androidx.camera:camera-extensions:1.0.0-alpha32
e androidx.camera:camera-view:1.0.0-alpha32
. A versão 1.0.0-alpha32 contém estas confirmações.
Mudanças na API
- Remoção de anotações
@RequiresApi(21)
desnecessárias das classes/interfaces internas (I8e286, b/204917951). - Atualização de arquivos de API para o artefato camera-extensions (If683a, b/161377155).
Correções de bugs
- O app não tem mais permissão para ativar os modos de extensão ao vincular a
VideoCapture
. A CameraX Extensions oferece suporte apenas aImageCapture
ePreview
. AVideoCapture
ainda não tem suporte. Se o app vincular aVideoCapture
e ativar qualquer modo de extensão, umaIllegalArgumentException
vai ser gerada (I0d87b). - O elemento
CameraSelector#filter
não gera mais umaIllegalArgumentException
quando o conjunto de resultados está vazio (I27804). - A API
ExtensionsManager#getInstance
foi renomeada comogetInstanceAsync
porque retorna uma interfaceListenableFuture
. O sufixo "Async" do nome da função mostra claramente que essa é uma função assíncrona (I279d2). - O parâmetro de resolução da API
ExtensionsManager#getEstimatedCaptureLatencyRange
foi removido, porque os usuários não sabem quais tamanhos têm suporte do caso de usoImageCapture
e não conseguem distinguir se as informações de latência retornadas são para o tamanho máximo de saída de captura ou o parâmetro de resolução de entrada (I74bb2). - O parâmetro
CameraProvider
das funçõesExtensionsManager
foi movido para a APIgetInstance()
. Assim, os usuários não precisam inserir o parâmetroCameraProvider
todas as vezes ao chamar as funçõesExtensionsManager
(Ic7e48).
Versão 1.0.0-alpha31
17 de novembro de 2021
Lançamento de androidx.camera:camera-extensions:1.0.0-alpha31
e androidx.camera:camera-view:1.0.0-alpha31
. A versão 1.0.0-alpha31 contém estas confirmações.
Mudanças na API
- CameraSelector#filter foi adicionado à API pública para filtrar uma lista de CameraInfos com base em um CameraSelector (I105d0).
Correções de bugs
- Corrigimos uma falha que acontecia ao alternar rapidamente o modo de extensões em determinados dispositivos (Iebbef).
Versão 1.0.0-alpha30
13 de outubro de 2021
Lançamento de androidx.camera:camera-extensions:1.0.0-alpha30
e androidx.camera:camera-view:1.0.0-alpha30
. A versão 1.0.0-alpha30 contém estas confirmações.
Mudanças na API
- A anotação @RequiresApi(21) foi adicionada a todas as classes da CameraX e a minSdkVersion foi descartada do AndroidManifest.xml. Isso permitirá que o camera-core seja facilmente integrado a aplicativos que têm uma minSdkVersion menor que 21, mas querem usar caminhos de código que dependem da API 21 e versões mais recentes condicionalmente. Em aplicativos com a minSdkVersion 21 ou versões mais recentes, nenhuma ação é necessária (Ie7f2e, b/200599470).
Correções de bugs
- Foi corrigido o problema AbstractMethodError, que acontecia quando o ProGuard estava ativado (Iae468, b/201177844).
Versão 1.0.0-alpha29
29 de setembro de 2021
Lançamento de androidx.camera:camera-extensions:1.0.0-alpha29
e androidx.camera:camera-view:1.0.0-alpha29
. A versão 1.0.0-alpha29 contém estas confirmações.
Mudanças na API
- A anotação ExperimentalUseCaseGroup foi removida agora que as APIs não são mais experimentais (I01ef5).
- Remova
RotationProvider#removeAllListeners()
. Em vez disso, useRotationProvider#removeListener(...)
(Id9d4a). - Atualização da classe RotationReceiver: mudança do set/clear do Listener para add/remove/removeAll, remoção da variação setListener que usa a linha de execução principal por padrão e adição de anotação de métodos (Ib1669).
Correções de bugs
- ExtensionMode#BEAUTY foi renomeado como FACE_RETOUCH para representar corretamente o que é feito pelo modo de extensão (I61f54, b/198515274).
- Correção do problema em que a câmera era fechada inesperadamente quando vários CameraController e PreviewView eram usados em uma atividade (Ibfd18, b/197539358).
Versão 1.0.0-alpha28
18 de agosto de 2021
Lançamento de androidx.camera:camera-extensions:1.0.0-alpha28
e androidx.camera:camera-view:1.0.0-alpha28
. A versão 1.0.0-alpha28 contém estas confirmações.
Mudanças na API
- A anotação ExperimentalUseCaseGroupLifecycle foi removida, agora que as APIs não são mais experimentais (I17b85).
- RotationListener foi refatorado e renomeado como RotationProvider. Ele continua oferecendo o mesmo recurso com uma API um pouco diferente (Idffc5).
- TAP_TO_FOCUS_UNSUCCESSFUL foi renomeado como TAP_TO_FOCUS_NOT_FOCUSED, e TAP_TO_FOCUS_SUCCESSFUL foi renomeado como TAP_TO_FOCUS_FOCUSED. OutputSize finalizado (I099fa).
Correções de bugs
- As classes
<EffectName><UseCase>Extender
descontinuadas, o ExtensionsErrorListener e as APIs ExtensionsManager relacionadas foram removidos (I3b8c3).
Versão 1.0.0-alpha27
21 de julho de 2021
Lançamento de androidx.camera:camera-extensions:1.0.0-alpha27
e androidx.camera:camera-view:1.0.0-alpha27
. A versão 1.0.0-alpha27 contém estas confirmações.
Mudanças na API
- A API de janela de visualização foi promovida, deixando de ser experimental. Removida a anotação experimental da API (I717ea).
CoordinateTransform#getTransform
foi renomeado comoCoordinateTransform#transform
, e o JavaDoc foi atualizado (I864ae).
Correções de bugs
- Correção do problema de extensão do modo
PreviewView PERFORMANCE
ao usá-lo em conjunto com a interface do Compose (Ie1137, b/183864890).
Versão 1.0.0-alpha26
30 de junho de 2021
Lançamento de androidx.camera:camera-extensions:1.0.0-alpha26
e androidx.camera:camera-view:1.0.0-alpha26
. A versão 1.0.0-alpha26 contém estas confirmações.
Mudanças na API
- Foi adicionado um novo método,
CameraController#getTapToFocusState()
, que expõe o resultado mais recente do recurso Toque para focar (Iaccb0). - Mais recursos da camera-core foram adicionados ao CameraController: getters/setters para proporções de destino, resolução de destino, modo de captura, CameraControl e executores personalizados (Iea8f2).
- Uma classe RotationReceiver que recebe mudanças de rotação de Surface foi adicionada. Ela pode ser usada para definir a rotação desejada quando o dispositivo está no modo retrato/paisagem fixo (Ib278f).
- Novas APIs públicas getEstimatedCaptureLatencyRange foram expostas na classe ExtensionsManager (I6a8ec).
- ExtensionsErrorListener foi descontinuado. Atualmente, essa interface só é usada para monitorar se uma visualização ou a ImageCapture está ausente ao ativar os modos de extensão. A CameraX adicionará automaticamente uma visualização ou ImageCapture extra para que as funções de extensão funcionem bem. Depois disso, nenhum erro será informado por essa interface (I47d9e).
- ExtensionManager getInstance, isExtensionAvailable e getExtensionEnabledCameraSelector das APIs públicas foram expostos, e as classes
<EffectName><UseCase>Extender
e APIs relacionadas antigas foram descontinuadas (I329e6).
Versão 1.0.0-alpha25
2 de junho de 2021
Lançamento de androidx.camera:camera-extensions:1.0.0-alpha25
e androidx.camera:camera-view:1.0.0-alpha25
. A versão 1.0.0-alpha25 contém estas confirmações.
Mudanças na API
- As APIs ExperimentalCameraFilter agora não estão mais no estágio experimental e se tornaram APIs formais. Elas podem ser usadas sem a anotação OptIn (I4bc94).
- Um utilitário que transforma coordenadas entre casos de uso foi adicionado. Exemplo de uso: transformar as coordenadas detectadas no caso de uso da ImageAnalysis e destacar o objeto detectado na visualização (I63ab1, b/137515129).
- A
CameraView
foi removida.CameraView
foi substituída porCameraController
. Consulte o guia de migração (em inglês) para aprender a migrar: (Id5005).
Correções de bugs
ExperimentalUseCaseGroupLifecycle
foi substituído porExperimentalUseCaseGroup
(I3b2ef, b/159033688).
Versão 1.0.0-alpha24
21 de abril de 2021
Lançamento de androidx.camera:camera-extensions:1.0.0-alpha24
e androidx.camera:camera-view:1.0.0-alpha24
. A versão 1.0.0-alpha24 contém estas confirmações.
Correções de bugs
- A anotação
@Experimental
foi substituída por@RequiresOptIn
para APIs experimentais. Para chamar APIs experimentais, useandroidx.annotation.OptIn
em vez deandroidx.annotation.experimental.UseExperimental
, que foi descontinuado (Iff226). - Correção do problema estendido do PreviewView no Samsung J5 Prime (Ib10b6)
Camera Extensions e View versão 1.0.0-alpha23
24 de março de 2021
Lançamento de androidx.camera:camera-extensions:1.0.0-alpha23
e androidx.camera:camera-view:1.0.0-alpha23
. A versão 1.0.0-alpha23 contém estas confirmações.
Mudanças na API
- O uso da CameraView foi descontinuado. Em vez disso, use
LifecycleCameraController
. Consulte o guia de migração (em inglês) (Idac2c). - A anotação FloatRange foi adicionada a setLinearZoom() (I69971).
Correções de bugs
- As dependências de visualização de câmera foram fixadas para depender de artefatos da versão 1.0.0. A dependência de camera-view não vai mais fazer com que a resolução de dependência do Gradle atualize automaticamente o camera-core, o camera-camera2 e o camera-lifecycle para a versão 1.1.0 mais recente dos artefatos. Porém, a camera-view ainda é compatível com esses artefatos se estiverem explicitamente configurados para usar a versão 1.1.0 (Ic8fa1, b/181599852).
- A visualização esticada no Samsung A3 foi corrigida no PreviewView (Iacb30, b/180121821).
- Correção do problema em que o seletor da câmera não podia ser definido antes da inicialização da câmera (Ic8bd0).
Camera Extensions e View versão 1.0.0-alpha22
24 de fevereiro de 2021
Lançamento de androidx.camera:camera-extensions:1.0.0-alpha22
e androidx.camera:camera-view:1.0.0-alpha22
. A versão 1.0.0-alpha22 contém estas confirmações.
Mudanças na API
- Adição de um getter CameraInfo ao CameraController (Ib8138, b/178251727).
Correções de bugs
- Correção de ExtensionsErrorListener para informar erros quando apenas a visualização ou a ImageCapture está vinculada (I5ae39).
Camera Extensions e View versão 1.0.0-alpha21
27 de janeiro de 2021
Lançamento de androidx.camera:camera-extensions:1.0.0-alpha21
e androidx.camera:camera-view:1.0.0-alpha21
. A versão 1.0.0-alpha21 contém estas confirmações.
Lançamento para compatibilidade com outros artefatos da biblioteca da câmera.
Camera Extensions e View: versão 1.0.0-alpha20
16 de dezembro de 2020
Lançamento de androidx.camera:camera-extensions:1.0.0-alpha20
e androidx.camera:camera-view:1.0.0-alpha20
. A versão 1.0.0-alpha20 contém estas confirmações.
Lançamento para compatibilidade com outros artefatos da biblioteca da câmera.
Camera Extensions e View: versão 1.0.0-alpha19
11 de novembro de 2020
Lançamento de androidx.camera:camera-extensions:1.0.0-alpha19
e androidx.camera:camera-view:1.0.0-alpha19
. A versão 1.0.0-alpha19 contém estas confirmações.
Correções de bugs
- A anotação
@ExperimentalVideo
foi introduzida para camera-view. Essa anotação marca as APIs que expõem a funcionalidade experimental de vídeo, que está sujeita a mudanças à medida que os recursos são completamente desenvolvidos. Qualquer método que use essas APIs precisa usar a anotação@UseExperimental
comExperimentalVideo
comomarkerClass
(I6d729).
Camera-Extensions: versão 1.0.0-alpha18
14 de outubro de 2020
Lançamento do androidx.camera:camera-extensions:1.0.0-alpha18
. A versão 1.0.0-alpha18 contém estas confirmações.
Correções de bugs
- Melhoria na latência de inicialização da CameraX e bindToLifecycle (I61dc5).
<UseCase>.getTargetRotation()
vai retornarSurface.ROTATION_0
se for chamado antes de ser anexado a uma instância de Camera, a menos que um targetRotation tenha sido definido no Builder ou UseCase (I80fcd).
Camera-View: versão 1.0.0-alpha18
14 de outubro de 2020
Lançamento do androidx.camera:camera-view:1.0.0-alpha18
. A versão 1.0.0-alpha18 contém estas confirmações.
Lançamento para compatibilidade com outros artefatos da biblioteca da câmera.
Camera-Extensions versão 1.0.0-alpha17
23 de setembro de 2020
Lançamento do androidx.camera:camera-extensions:1.0.0-alpha17
. A versão 1.0.0-alpha17 contém estas confirmações.
Correções de bugs
- Lançamento do suporte à Camera-Core 1.0.0-beta10.
Camera-View: versão 1.0.0-alpha17
23 de setembro de 2020
Lançamento do androidx.camera:camera-view:1.0.0-alpha17
. A versão 1.0.0-alpha17 contém estas confirmações.
Correções de bugs
- Lançamento do suporte à Camera-Core 1.0.0-beta10.
Camera-Extensions versão 1.0.0-alpha16
16 de setembro de 2020
Lançamento do androidx.camera:camera-extensions:1.0.0-alpha16
. A versão 1.0.0-alpha16 contém estas confirmações.
Correções de bugs
- Um método foi adicionado no
ExtensionsManager
para receber um objetoExtensions
usado para ativar e consultar extensões em instâncias da Câmera (I4fb7e).
Camera-View: versão 1.0.0-alpha16
16 de setembro de 2020
Lançamento do androidx.camera:camera-view:1.0.0-alpha16
. A versão 1.0.0-alpha16 contém estas confirmações.
Mudanças na API
- Removidos
PreviewView#setDeviceRotationForRemoteDisplayMode()
ePreviewView#getDeviceRotationForRemoteDisplayMode()
. Os dois métodos são para personalizar a rotação da visualização, quando a rotação desejada não é a de exibição, como uma exibição remota. Para lidar com a rotação de visualizações que não sejam de exibição, defina a rotação desejada comPreview#setTargetRotation()
e aPreviewView#getViewPort(targetRotation)
recém-adicionada (Ib62cc). createSurfaceProvider()
foi renomeado comogetSurfaceProvider()
. O método sempre vai retornar a mesma instância de Preview.SurfaceProvider (Iff83c).
Correções de bugs
- O PreviewView é forçado a usar TextureView se o efeito de extensão está ativado e a implementação da biblioteca do fornecedor precisa executar um processo especial na plataforma de saída (I0c3cc).
- Permissão de rotação desejada arbitrária para o Preview. As informações de transformação são calculadas e retornadas dinamicamente ao usuário por um novo callback
TranformationInfoListener
(I21470).
Problemas conhecidos
- Em PreviewView,
OnClickListener#onClick()
não é invocado quando o usuário final clica em "PreviewView". O evento de toque é consumido por engano por PreviewView#onTouchEvent(). O problema será corrigido na próxima versão. - O MeteringPoint recebido de
PreviewView#getMeteringPointFactory()
poderá estar incorreto se a ViewPort for usada com PreviewView.
Camera-Extensions versão 1.0.0-alpha15
19 de agosto de 2020
Lançamento do androidx.camera:camera-extensions:1.0.0-alpha15
. A versão 1.0.0-alpha15 contém estas confirmações.
Correções de bugs
- O método
ExtensionsManager.init()
agora usa um Context como parâmetro em vez de 0 args (Ife754). A inicialização não deve mais falhar ao usar um Context que não retorna um objeto da Application de
Context.getApplicationContext()
(I3d3c9, b/160817073).Camera-View: versão 1.0.0-alpha15
19 de agosto de 2020
Lançamento do androidx.camera:camera-view:1.0.0-alpha15
. A versão 1.0.0-alpha15 contém estas confirmações.
Correções de bugs
DisplayOrientedMeteringPointFactory
usa uma instância deCameraInfo
, em vez deCameraSelector
, para que haja um mapeamento direto para a Camera que vai receber os pontos gerados. Todas as classes que usamDisplayOrientedMeteringPointFactory
também aceitam uma instância deCameraInfo
em vez deCameraSelector
(I400c1).- Contato removido:
TextureViewMeteringPointFactory
.PreviewView
fornece uma API pública (createMeteringPointFactory()
) para criar uma fábrica de ponto de medição, independentemente de usarTextureView
ouSurfaceView
(Ide693). - Os modos de implementação
SURFACE_VIEW
/TEXTURE_VIEW
do PreviewView foram renomeados comoPERFORMANCE
/COMPATIBLE
.PERFORMANCE
é o modoSURFACE_VIEW
antigo eCOMPATIBLE
é o modoTEXTURE_VIEW
antigo (I0edc2). - Para captura de imagens, substitua a sinalização de virar para a horizontal nos metadados com base na direção da câmera (I28499).
Camera-Extensions: versão 1.0.0-alpha14
22 de julho de 2020
Lançamento do androidx.camera:camera-extensions:1.0.0-alpha14
. A versão 1.0.0-alpha14 contém estas confirmações.
Camera-View: versão 1.0.0-alpha14
22 de julho de 2020
Lançamento do androidx.camera:camera-view:1.0.0-alpha14
. A versão 1.0.0-alpha14 contém estas confirmações.
Camera-Extensions versão 1.0.0-alpha13
24 de junho de 2020
Lançamento do androidx.camera:camera-extensions:1.0.0-alpha13
. A versão 1.0.0-alpha13 contém estas confirmações.
Correções de bugs
- Foram adicionadas interfaces experimentais para filtrar câmeras por ID e características da câmera (I28f61, link em inglês).
Camera-View: versão 1.0.0-alpha13
24 de junho de 2020
Lançamento do androidx.camera:camera-view:1.0.0-alpha13
. A versão 1.0.0-alpha13 contém estas confirmações.
Correções de bugs
- O CameraView não falha mais com uma IllegalArgumentException ao se vincular a um LifecycleOwner cujo ciclo de vida transita para um estado DESTROYED logo após ser vinculado. Os ciclos de vida de vinculação em um estado DESTROYED não tentarão abrir a câmera (I7c2b8, link em inglês).
- PreviewView StreamState agora está disponível por CameraView.getPreviewStreamState() (I21a2b).
Camera-Extensions versão 1.0.0-alpha12
10 de junho de 2020
Lançamento do androidx.camera:camera-extensions:1.0.0-alpha12
. A versão 1.0.0-alpha12 contém estas confirmações.
Correções de bugs
- Foi corrigida a falha no app ao inicializar a CameraX enquanto o smartphone estava no modo não perturbe. Um
InitializationException
contém umCameraUnavailableException
que vai ser definido como oListenableFuture
do resultado da inicialização, em vez de causar falhas no aplicativo (I9909a, b/149413835, links em inglês)
Camera-View: versão 1.0.0-alpha12
10 de junho de 2020
Lançamento do androidx.camera:camera-view:1.0.0-alpha12
. A versão 1.0.0-alpha12 contém estas confirmações.
Correções de bugs
- Foi adicionada a API
PreviewView#getBitmap()
para retornar uma representação de bitmap do conteúdo mostrado na superfície de visualização (I9b500, b/157659818, links em inglês)
Camera-Extensions: versão 1.0.0-alpha11
27 de maio de 2020
Lançamento do androidx.camera:camera-extensions:1.0.0-alpha11
. A versão 1.0.0-alpha11 contém estas confirmações.
Camera-View: versão 1.0.0-alpha12
10 de junho de 2020
Lançamento do androidx.camera:camera-view:1.0.0-alpha12
. A versão 1.0.0-alpha12 contém estas confirmações.
Novos recursos
Mudanças na API
Correções de bugs
- Foi adicionada a API
PreviewView#getBitmap()
para retornar uma representação de bitmap do conteúdo mostrado na superfície de visualização (I9b500, b/157659818, links em inglês)
Camera-View: versão 1.0.0-alpha11
27 de maio de 2020
Lançamento do androidx.camera:camera-view:1.0.0-alpha11
. A versão 1.0.0-alpha11 contém estas confirmações.
Mudanças na API
- Adição da API
PreviewView#getPreviewStreamState
para permitir aos apps observar se a visualização está em streaming ou não. Quando o PreviewView está no modo TEXTURA_VIEW, o estado STREAMING também garante a visibilidade da imagem de visualização (Ic0906, b/154652477, links em inglês) - A API
PreviewView#setDeviceRotationForRemoteDisplayMode()
foi adicionada para fornecer rotação de dispositivos para cálculos de transformação se o aplicativo estiver em execução no modo de exibição remota (I59b95, b/153514525, links em inglês)
Correções de bugs
- Foi corrigido o problema de distorção da visualização em câmeras
FULL/LIMITED/LEVEL_3
com o Android 7.0 e versões anteriores. Uso forçado do modoImplementationMode#TEXTURE_VIEW
quando a versão do Android é 7.0 ou anterior. (I83e30, b/155085307, links em inglês) - Remoção do parâmetro
CameraInfo
dePreviewView#createSurfaceProvider()
. Agora,PreviewView
o recupera internamente deSurfaceRequest
(If18f0, b/154652477, links em inglês) - A proporção padrão de VideoCapture foi corrigida para 16:9 na CameraView (Ie6a7b, b/153237864, links em inglês)
- Correção dos problemas de tela preta de
PreviewView
ao deslizar o fragmentoPreview
e depois de volta para o ViewPager2. Também foi corrigido o problema quandoremoveView(previewview)
e depoisaddView(previewView)
. (Iab555, b/149877652, b/147354615) - Atualize a API
CameraView#takePicture()
para que seja possível salvar imagens emUri
eOutputStream
. Atualize o app de teste para usarUri
como exemplo canônico. (Ia2459, b/153607583). - Você pode configurar o tipo de escala de PreviewView a partir de um layout XML ao definir o atributo
ScaleType
(I08565, b/153015659, link em inglês) - O
CameraView.ScaleType
foi removido. Em vez disso, usePreviewView.ScaleType
para definir/receber um tipo de escala com o CameraView (Ia8974, b/153014831, links em inglês) - Defina uma cor de plano de fundo para
PreviewView
, se ainda não tiver uma. Isso impede o conteúdo por trás dele de ser visível antes do início da visualização do stream. (I09fad, link em inglês)
Camera-Extensions versão 1.0.0-alpha10
15 de abril de 2020
Lançamento do androidx.camera:camera-extensions:1.0.0-alpha10
. A versão 1.0.0-alpha10 contém estas confirmações.
Correções de bugs
- Correções para oferecer suporte ao lançamento da Camera-Core
Camera-View: versão 1.0.0-alpha10
15 de abril de 2020
Lançamento do androidx.camera:camera-view:1.0.0-alpha010
. A versão 1.0.0-alpha10 contém estas confirmações.
Correções de bugs
- Foi corrigido um problema conhecido em que a implementação do SurfaceView de
PreviewView
não funcionava bem em alguns dispositivos e causava falha no app após retomar a visualização (I5ed6b, link em inglês)
Camera-Extensions: versão 1.0.0-alpha09
1º de abril de 2020
Lançamento do androidx.camera:camera-extensions:1.0.0-alpha09
. A versão 1.0.0-alpha09 contém estas confirmações.
Correções de bugs
- Atualização para oferecer suporte às correções de bugs nos artefatos
camera-camera2:1.0.0-beta02
,camera-core:1.0.0-beta02
ecamera-lifecycle:1.0.0-beta02
.
Camera-View versão 1.0.0-alpha09
1º de abril de 2020
Lançamento do androidx.camera:camera-view:1.0.0-alpha09
. A versão 1.0.0-alpha09 contém estas confirmações.
Problemas conhecidos
- É possível que o
ImplementationMode.SURFACE_VIEW
comPreviewView
não funcione bem em alguns dispositivos, porque aSurfaceView
usada para visualização invalida a plataforma quando o ciclo de vida da janela é interrompido. Ao reiniciar, a câmera é aberta novamente e pode tentar retomar a visualização antes que a plataforma deSurfaceView
seja válida novamente. Por enquanto, useImplementationMode.TEXTURE_VIEW
.
Mudanças na API
PreviewView.setImplementationMode()
foi renomeado comoPreviewView.setPreferredImplementationMode()
.PreviewView.getImplementationMode()
foi renomeado comoPreviewView.getPreferredImplementationMode()
.PreviewView.getSurfaceProvider()
foi substituído porPreviewView.createSurfaceProvider(CameraInfo)
, que usa uma instânciaCameraInfo
anulável para otimizar a visualização usandoImplementationMode.SURFACE_VIEW
sempre que possível. Se uma instância nula for transmitida ou o modo de implementação preferencial for definido comoImplementationMode.TEXTURE_VIEW
,ImplementationMode.TEXTURE_VIEW
vai ser usado internamente.O exemplo de código a seguir demonstra como um caso de uso de visualização era usado anteriormente com o PreviewView.
preview.setSurfaceProvider(previewView.previewSurfaceProvider) cameraProvider.bindToLifecycle(lifecycleOwner, cameraSelector, preview)
Agora, você pode escrever o seguinte:
val camera = cameraProvider.bindToLifecycle(lifecycleOwner, cameraSelector, preview) previewView.preferredImplementationMode = ImplementationMode.TEXTURE_VIEW preview.setSurfaceProvider(previewView.createSurfaceProvider(camera.cameraInfo))
A anotação
@UiThread
foi adicionada aPreviewView.getSurfaceProvider()
, o que significa que ela precisa ser chamada a partir da linha de execução principal (I192f3).Adicionamos
PreviewView.setScaleType()
, que permite definir o tipo de escala da visualização. Ele aceita um dos valores emPreviewView.ScaleType
e assumePreviewView.ScaleType.FILL_CENTER
como padrão.Adicionamos
PreviewView.getScaleType()
.Remoção do suporte à configuração do modo de implementação do
PreviewView
em um layout XML que usa o atributoimplementationMode
.Adicionamos a API
createMeteringPointFactory()
ao PreviewView para oferecer suporte à conversão (x, y) emPreviewView
paraMeteringPoint
(IB36d7).
Correções de bugs
- Correção de casos em que uma visualização incorreta é mostrada após a mudança do tamanho de
PreviewView
(I71101, link em inglês)
Camera-Extensions: versão 1.0.0-alpha08
26 de fevereiro de 2020
Lançamento do androidx.camera:camera-extensions:1.0.0-alpha08
. A versão 1.0.0-alpha08 contém estas confirmações.
Camera-View: versão 1.0.0-alpha08
26 de fevereiro de 2020
Lançamento do androidx.camera:camera-view:1.0.0-alpha08
. A versão 1.0.0-alpha08 contém estas confirmações.
Correções de bugs
- Em
SurfaceRequest.provideSurface()
,ListenableFuture
foi substituído porExecutor
eCallback
. Isso simplifica a API ao não exigir mais o processamento de exceções emprovideSurface()
e faz com que o callbackprovideSurface()
não possa ser cancelado. O objetivo é evitar falhas em dispositivos mais antigos, causadas pelo lançamento prematuro de plataformas. O objetoSurfaceRequest.Result
agora é usado para rastrear como umaSurfaceRequest
usa aSurface
fornecida. (I7854b). SurfaceRequest.setSurface(Surface)
foi renomeado comoSurfaceRequest.provideSurface(Surface)
, eSurfaceRequest.setWillNotComplete()
foi renomeado comoSurfaceRequest.willNotProvideSurface()
(I224fe).- A inicialização de variantes do app com o ProGuard ativado foi corrigida, preservando a sinalização que define o provedor
CameraXConfig
padrão (I2d6c1).
Camera-Extensions: versão 1.0.0-alpha07
10 de fevereiro de 2020
Lançamento do androidx.camera:camera-extensions:1.0.0-alpha07
. A versão 1.0.0-alpha07 contém estas confirmações.
Correções de bugs
- Os argumentos que anteriormente eram transmitidos em
ImageCapture.OnImageSavedCallback.onError()
eImageCapture.OnImageCapturedCallback.onError()
foram substituídos por um único argumentoImageCaptureException
, que ainda contém todas as informações transmitidas anteriormente. - O argumento do arquivo anteriormente transmitido em
ImageCapture.OnImageSavedCallback.onImageSaved()
foi removido (I750d2, link em inglês)
Camera-View: versão 1.0.0-alpha07
10 de fevereiro de 2020
Lançamento do androidx.camera:camera-view:1.0.0-alpha07
. A versão 1.0.0-alpha07 contém estas confirmações.
Mudanças na API
- A implementação de
TextureView
daPreviewView
agora define o tamanho daTextureView
como o tamanho de saída do sensor da câmera antes do dimensionamento para preencher aPreviewView
mãe. Caso você queira que a visualização da câmera preencha uma parte inteira da interface (a tela inteira, por exemplo), não defina o tamanho dePreviewView
como um valor fixo nem faça com que ele agrupe o conteúdo, por exemplo, usando o atributo "wrap_content
". Isso pode fazer com que a visualização da câmera só preencha parte dePreviewView
, caso o tamanho de saída do sensor da câmera seja menor. Em vez disso, defina o tamanho dePreviewView
para que seja igual ao do pai, por exemplo, usando o atributo "match_parent
". (1204869, link em inglês)
Correções de bugs
- Atualização de
ImageCapture
para que seja possível salvar imagens emUri
eOutputStream
. Os métodostakePicture
sobrecarregados foram unificados em apenas um. Atualização do app de teste para usarUri
como exemplo canônico (Ia3bec, link em inglês) Preview.PreviewSurfaceProvider
foi renomeado comoPreview.SurfaceProvider
. OsSurfaceProvider
s não exigem mais que os desenvolvedores criem o próprioListenableFuture
, e aSurface
agora é fornecida por um novo objetoSurfaceRequest
. O métodoPreview.getPreviewSurfaceProvider()
foi removido devido ao potencial de uso indevido quandoPreview
está pareado com outras classes, comoPreviewView
(I20105, link em inglês)- Os argumentos que anteriormente eram transmitidos em
ImageCapture.OnImageSavedCallback.onError()
eImageCapture.OnImageCapturedCallback.onError()
foram substituídos por um único argumentoImageCaptureException
, que ainda contém todas as informações transmitidas anteriormente. - O argumento do arquivo anteriormente transmitido em
ImageCapture.OnImageSavedCallback.onImageSaved()
foi removido (I750d2, link em inglês) - A API foi atualizada com os métodos
getZoomRatio()
,getMaxZoomRatio()
,getMinZoomRatio()
egetLinearZoom()
de junção daCameraInfo
emgetZoomState()
, que retorna uma instânciaZoomState
(Ib19fe).
Camera-Extensions versão 1.0.0-alpha06
22 de janeiro de 2020
Lançamento do androidx.camera:camera-extensions:1.0.0-alpha06
. A versão 1.0.0-alpha06 contém estas confirmações.
Atualizações
- Várias correções e atualizações compatíveis com as mudanças de Camera Core e Camera2.
Camera-View Versão 1.0.0-alpha06
22 de janeiro de 2020
Lançamento do androidx.camera:camera-view:1.0.0-alpha06
. A versão 1.0.0-alpha06 contém estas confirmações.
Atualizações
- Várias correções e atualizações compatíveis com as mudanças de Camera Core e Camera2.
Camera-Extensions Versão 1.0.0-alpha05
18 de dezembro de 2019
Lançamento do androidx.camera:camera-extensions:1.0.0-alpha05
. A versão 1.0.0-alpha05 contém estas confirmações.
Correções de bugs
- Atualizado para corresponder às APIs internas do Camera Core.
Camera-View Versão 1.0.0-alpha05
18 de dezembro de 2019
Lançamento do androidx.camera:camera-view:1.0.0-alpha05
. A versão 1.0.0-alpha05 contém estas confirmações.
Problemas conhecidos
- A proporção pode estar incorreta ao usar o PreviewView (b/146215202, link em inglês).
Novos recursos
- Foi implementada uma nova classe, chamada
PreviewView.TextureViewImplementation
, que sincroniza o ciclo de vida do SurfaceTexture com o uso da superfície TextureView pela câmera.
Camera-Extensions Versão 1.0.0-alpha04
4 de dezembro de 2019
Lançamento do androidx.camera:camera-extensions:1.0.0-alpha04
. A versão 1.0.0-alpha04 do camera-extensions contém estas confirmações (link em inglês).
Mudanças na API
A verificação de disponibilidade e a ativação de uma extensão agora aceitam
CameraSelector
como parâmetro de entrada. Ele precisa ser o mesmoCameraSelector
usado para vincular o caso de uso.val cameraSelector = CameraSelector.DEFAULT_BACK_CAMERA val builder = ImageCapture.Builder() val bokehImageCaptureExtender = BokehImageCaptureExtender.create(builder) if (bokehImageCaptureExtender.isExtensionAvailable(cameraSelector)) { bokehImageCaptureExtender.enableExtension(cameraSelector) } val imageCapture = builder.build() mCameraProvider?.bindToLifecycle(this, cameraSelector, imageCapture)
Você precisa inicializar as extensões antes de usar a biblioteca de extensões.
val availability = ExtensionsManager.init() Futures.addCallback<ExtensionsManager.ExtensionsAvailability>( availability, object : FutureCallback<ExtensionsManager.ExtensionsAvailability> { override fun onSuccess(availability: ExtensionsManager.ExtensionsAvailability?) { // Ready to make extensions calls } override fun onFailure(throwable: Throwable) { // Extensions could not be initialized } }, Executors.newSingleThreadExecutor() )
Camera-View Versão 1.0.0-alpha04
4 de dezembro de 2019
Lançamento do androidx.camera:camera-view:1.0.0-alpha04
. A versão 1.0.0-alpha04 do camera-view contém estas confirmações (link em inglês).
Mudanças na API
- Uma classe
PreviewView
é fornecida para exibir facilmente a saída do caso de uso de Preview em um aplicativo. PreviewView
pode ser incluído no layout:<androidx.camera.view.PreviewView android:id="@+id/preview_view" … />
PreviewView
fornece umPreviewSurfaceProvider
para conectar facilmente um caso de uso de Preview.preview.setPreviewSurfaceProvider(previewView.previewSurfaceProvider)
"
ZoomLevel
" agora é "ZoomRatio
" em API-naming.Alguns parâmetros de método mudaram de nulidade.
Camera-Extensions e Camera-View Versão 1.0.0-alpha03
9 de outubro de 2019
Lançamento de androidx.camera:camera-extensions:1.0.0-alpha03
e androidx.camera:camera-view:1.0.0-alpha03
. Estas são as confirmações incluídas em camera-extensions:1.0.0-alpha03
e estas são as confirmações incluídas em camera-view:1.0.0-alpha03
.
Novos recursos
- Adição do inicializador de contexto para extensões. Versão das extensões incrementada para 1.1.0
Camera-Extensions and Camera-View Versão 1.0.0-alpha02
5 de setembro de 2019
Lançamento de androidx.camera:camera-extensions:1.0.0-alpha02
e androidx.camera:camera-view:1.0.0-alpha02
. Estas são as confirmações incluídas em camera-extensions:1.0.0-alpha02, e estas são as confirmações incluídas em camera-view:1.0.0-alpha02.
- Adição de testes para verificar se
PreviewImageProcessorImpl
implementou corretamente os carimbos de data/hora. - Correção da falha de teste de
ExtensionTest
no Nexus 5 (API de nível 21) e garantia de que a visualização esteja disponível.
Camera-Extensions e Camera-View: versão 1.0.0-alpha01
7 de agosto de 2019
Lançamento de androidx.camera:camera-extensions:1.0.0-alpha01
e androidx.camera:camera-view:1.0.0-alpha01
.
Estas são as confirmações incluídas em camera-extensions:1.0.0-alpha01 e estas são as confirmações incluídas em camera-view:1.0.0-alpha01 (links em inglês).
- Nova biblioteca para futuras extensões de câmera, para acessar efeitos em dispositivos compatíveis. Essa biblioteca ainda está em andamento.
- Nova classe de visualização da câmera. Essa biblioteca ainda está em andamento.