日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學無先后,達者為師

網站首頁 編程語言 正文

Jetpack之CameraX的使用_Android

作者:幸大叔 ? 更新時間: 2022-12-04 編程語言

引入依賴

下面,就使用該庫來打造一個簡單的相機應用吧~

首先引入依賴

? ? 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
        )
    }

這樣,就完成了相機的預覽功能了。

拍攝

實現拍照功能也很簡單,只需要創建文件,然后調用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}")
                }
            })
    }

點擊按鈕時調用此方法即可

        findViewById<Button>(R.id.take).setOnClickListener {
            takePicture()
        }

注意:作為相機應用,可別忘了申請CAMERA權限哦。

這樣,一個簡單的相機應用就完成啦~

原文鏈接:https://blog.csdn.net/qq_45485851/article/details/124289947

欄目分類
最近更新