Jetpack之CameraX的使用
引入依賴
下面,就使用該庫來打造一個簡單的相機應用吧~
首先引入依賴
def camerax_version = "1.1.0-beta03"
implementation "androidx.camera:camera-core:${camerax_version}"
implementation "androidx.camera:camera-camera2:${camerax_version}"
implementation "androidx.camera:camera-lifecycle:${camerax_version}"
implementation "androidx.camera:camera-video:${camerax_version}"
implementation "androidx.camera:camera-view:${camerax_version}"
implementation "androidx.camera:camera-extensions:${camerax_version}"
預覽
將 PreviewView 添加到布局中
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity">
<androidx.camera.view.PreviewView
android:id="@+id/previewView"
android:layout_width="match_parent"
android:layout_height="match_parent" />
<Button
android:id="@+id/take"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_alignParentBottom="true"
android:text="拍照" />
</RelativeLayout>獲取 cameraProvider
val cameraProviderFuture = ProcessCameraProvider.getInstance(this)
cameraProviderFuture.addListener({
val cameraProvider = cameraProviderFuture.get()
bindViewAndLifecycle(cameraProvider)
}, ContextCompat.getMainExecutor(this))配置 ImageCapture
private val imageCapture: ImageCapture by lazy {
ImageCapture.Builder().build()
}bindViewAndLifecycle:綁定視圖和Lifecycle
private fun bindViewAndLifecycle(cameraProvider: ProcessCameraProvider) {
val previewView = findViewById<PreviewView>(R.id.previewView)
val cameraSelector = CameraSelector.Builder()
//如果是前置,可使用CameraSelector.LENS_FACING_FRONT
.requireLensFacing(CameraSelector.LENS_FACING_BACK)
.build()
val preview = Preview.Builder().build()
preview.setSurfaceProvider(previewView.surfaceProvider)
cameraProvider.bindToLifecycle(
this as LifecycleOwner,
cameraSelector,
imageCapture,
preview
)
}這樣,就完成了相機的預覽功能了。
拍攝
實現(xiàn)拍照功能也很簡單,只需要創(chuàng)建文件,然后調(diào)用imageCapture的takePicture方法。
private fun takePicture() {
val path =
getExternalFilesDir(null)?.absolutePath + File.separator + System.currentTimeMillis() + ".jpg"
val photoFile = File(path)
if (!photoFile.exists()) {
photoFile.createNewFile()
}
val fileOptions = ImageCapture.OutputFileOptions.Builder(photoFile).build()
imageCapture.takePicture(
fileOptions,
ContextCompat.getMainExecutor(this),
object : ImageCapture.OnImageSavedCallback {
override fun onImageSaved(outputFileResults: ImageCapture.OutputFileResults) {
Toast.makeText(this@MainActivity, "保存成功", Toast.LENGTH_SHORT).show()
}
override fun onError(exception: ImageCaptureException) {
Log.e(tag, "onError message:${exception.message}")
}
})
}點擊按鈕時調(diào)用此方法即可
findViewById<Button>(R.id.take).setOnClickListener {
takePicture()
}注意:作為相機應用,可別忘了申請CAMERA權限哦。
這樣,一個簡單的相機應用就完成啦~
到此這篇關于Jetpack之CameraX的使用的文章就介紹到這了,更多相關Jetpack CameraX內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Android下拉列表(Spinner)效果(使用C#和Java分別實現(xiàn))
這篇文章主要介紹了Android下拉列表(Spinner)效果(使用C#和Java分別實現(xiàn)),本文直接給出效果圖和兩種語言的實現(xiàn)代碼及布局代碼,需要的朋友可以參考下2015-06-06
圖解Windows環(huán)境下Android Studio安裝和使用教程
這篇文章主要介紹了圖解Windows環(huán)境下Android Studio安裝和使用教程的相關資料,需要的朋友可以參考下2015-12-12
Kotlin?協(xié)程異步熱數(shù)據(jù)流的設計與使用講解
這篇文章主要為大家介紹了Kotlin?協(xié)程協(xié)程異步熱數(shù)據(jù)流的設計與使用講解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-09-09
新版Android studio導入微信支付和支付寶官方Demo問題解決大全
這篇文章主要為大家詳細介紹了新版Android studio導入微信支付和支付寶官方Demo問題的解決大全,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-07-07

