Android開發(fā)中amera2 Preview使用詳解
前言
Camera2是Android新的Camera框架,整體來講Camera2為應(yīng)用程序提供了許多標(biāo)準(zhǔn)接口,使更多的功能可以通過參數(shù)控制;但是,靈活的同時(shí)也帶來了架構(gòu)的復(fù)雜。本文通過討論實(shí)現(xiàn)Camera2的Preview功能,來和大家一起探討Camera2所用到的模塊最小集合。
一、Camera2 Preview需要用到哪些模塊
總結(jié)起來,用到了如下模塊,
- SurfaceTexture之SurfaceTextureListener
- CameraManager
- CameraDevice之StateCallback
- CameraDevice之createCaptureSession
- CaptureRequest.Builder、 CaptureRequest
二、各個(gè)模塊的功能和之間的關(guān)系
下面詳細(xì)分析這幾個(gè)模塊的功能和之間的關(guān)系,
2.1 SurfaceTexture之SurfaceTextureListener
2.1.1 首先看關(guān)于SurfaceTexture的說明
主要目的是接收camera preview的數(shù)據(jù)并在UI上顯示。
Captures frames from an image stream as an OpenGL ES texture.
從圖像流捕獲幀, 作為OpenGL ES紋理.
The image stream may come from either camera preview or video decode. A android.view.Surface
created from a SurfaceTexture can be used as an output destination for the android.hardware.camera2
, android.media.MediaCodec
, android.media.MediaPlayer
, and android.renderscript.Allocation
APIs. When updateTexImage
is called, the contents of the texture object specified when the SurfaceTexture was created are updated to contain the most recent image from the image stream. This may cause some frames of the stream to be skipped.
2.1.2 SurfaceTextureListener的使用
當(dāng)與此Surface Texture關(guān)聯(lián)的表面紋理可用時(shí),可以使用此Listener來獲得通知。
當(dāng)收到SurfaceTexture可用通知的時(shí)候,執(zhí)行初始化camera的動作。
示例代碼如下,
private final SurfaceTextureListener mSurfaceTextureListener = new SurfaceTextureListener() { @Override public void onSurfaceTextureAvailable(@NonNull SurfaceTexture surface, int width, int height) { Log.i(TAG, "onSurfaceTextureAvailable: ++"); try { Log.i(TAG, "onCreate: call initCamera()"); initCamera(); } catch (CameraAccessException e) { e.printStackTrace(); } } @Override public void onSurfaceTextureSizeChanged(@NonNull SurfaceTexture surface, int width, int height) { Log.i(TAG, "onSurfaceTextureSizeChanged: ++"); } @Override public boolean onSurfaceTextureDestroyed(@NonNull SurfaceTexture surface) { Log.i(TAG, "onSurfaceTextureDestroyed: ++"); return false; } @Override public void onSurfaceTextureUpdated(@NonNull SurfaceTexture surface) { Log.i(TAG, "onSurfaceTextureUpdated: ++"); } };
2.2 CameraManager
2.2.1 CameraManager的作用
A system service manager for detecting, characterizing, and connecting to CameraDevices
.
一種系統(tǒng)服務(wù)管理器,用于檢測、表征和連接攝像設(shè)備。
2.2.2 使用CameraManager打開Camera
示例代碼如下,
注意:
openCamera的第一個(gè)參數(shù)是打開哪一個(gè)攝像頭,0代表后置攝像頭;1代表前置攝像頭;2代表外接攝像頭。這里打開的是前置攝像頭。
第二個(gè)參數(shù)是CameraDevice之StateCallback,稍后解析;
第三個(gè)參數(shù)是Handler,這里我們把Handler放在一個(gè)新創(chuàng)建的thread中;
CameraManager manager = (CameraManager) this.getSystemService(Context.CAMERA_SERVICE); manager.openCamera("1", stateCallback, mBackgroundHander);
2.3 CameraDevice之StateCallback
2.3.1 StateCallback的作用
A callback objects for receiving updates about the state of a camera device.
用于接收相機(jī)設(shè)備狀態(tài)更新的回調(diào)對象。
2.3.2 StateCallback的示例代碼
我們會在onOpened()函數(shù)中創(chuàng)建Preview Session!
CameraDevice.StateCallback stateCallback = new CameraDevice.StateCallback() { @Override public void onOpened(@NonNull CameraDevice camera) { Log.i(TAG, "onOpened: ++"); mCameraDevice = camera; createPreviewSession(); } @Override public void onDisconnected(@NonNull CameraDevice camera) { Log.i(TAG, "onDisconnected: ++"); } @Override public void onError(@NonNull CameraDevice camera, int error) { Log.i(TAG, "onError: ++"); } };
2.4 CameraDevice之createCaptureSession
2.4.1 新建CaptureRequest.Builder
A builder for capture requests.
2.4.2 新建CameraDevice之createCaptureSession
A configured capture session for a CameraDevice
, used for capturing images from the camera or reprocessing images captured from the camera in the same session previously.
2.4.3 創(chuàng)建CaptureRequest
An immutable package of settings and outputs needed to capture a single image from the camera device.
Contains the configuration for the capture hardware (sensor, lens, flash), the processing pipeline, the control algorithms, and the output buffers. Also contains the list of target Surfaces to send image data to for this capture.
這部分的示例代碼如下,
private void createPreviewSession() { SurfaceTexture surfaceTexture = mTextureView.getSurfaceTexture(); // should be preview size, will got it later surfaceTexture.setDefaultBufferSize(mTextureView.getWidth(), mTextureView.getHeight()); mImageReader = ImageReader.newInstance(mTextureView.getWidth(), mTextureView.getHeight(), ImageFormat.JPEG, /*maxImages*/2); Surface surface =new Surface(surfaceTexture); try { mPreviewRequstBuilder = mCameraDevice.createCaptureRequest(CameraDevice.TEMPLATE_PREVIEW); mPreviewRequstBuilder.addTarget(surface); mCameraDevice.createCaptureSession(Arrays.asList(surface, mImageReader.getSurface()), new CameraCaptureSession.StateCallback() { @Override public void onConfigured(@NonNull CameraCaptureSession session) { Log.i(TAG, "onConfigured: "); if (mCameraDevice == null) { return; } else { mCaptureSession = session; } mPreviewRequest = mPreviewRequstBuilder.build(); try { mCaptureSession.setRepeatingRequest(mPreviewRequest, null, mBackgroundHander); } catch (CameraAccessException e) { e.printStackTrace(); } } @Override public void onConfigureFailed(@NonNull CameraCaptureSession session) { Log.i(TAG, "onConfigureFailed: "); } }, mBackgroundHander); } catch (CameraAccessException e) { e.printStackTrace(); } }
小結(jié)
Camera2使用SurfaceTexture組件顯示Preview視頻流;
使用CameraManager打開CameraDevice之camera,同時(shí)塞入回調(diào)函數(shù)CameraDevice之StateCallback來反饋camera狀態(tài);
當(dāng)Camera狀況為Opened時(shí),創(chuàng)建CaptureRequest.Builder為preview,并將surface關(guān)聯(lián)至builder;之后創(chuàng)建CameraDevice之createCaptureSession,當(dāng)收到onConfigured信息時(shí),對諸如 sensor, lens, flash等進(jìn)行配置,然后呼叫Builder的build函數(shù)完成配置CaptureRequest,最后設(shè)置session為repeat模式。
到此這篇關(guān)于Android開發(fā)中amera2 Preview使用詳解的文章就介紹到這了,更多相關(guān)Android Camera2 Preview內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Android制作一個(gè)錨點(diǎn)定位的ScrollView
這篇文章主要介紹了Android制作一個(gè)錨點(diǎn)定位的ScrollView,幫助大家更好的理解和學(xué)習(xí)使用Android,感興趣的朋友可以了解下2021-04-04Android傳遞Bitmap對象在兩個(gè)Activity之間
這篇文章主要介紹了Android傳遞Bitmap對象在兩個(gè)Activity之間的相關(guān)資料,需要的朋友可以參考下2016-01-01Android RecyclerView添加FootView和HeadView
這篇文章主要介紹了Android RecyclerView添加FootView和HeadView的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-10-10RxJava實(shí)戰(zhàn)之訂閱流基本原理示例解析
這篇文章主要為大家介紹了RxJava實(shí)戰(zhàn)之訂閱流基本原理示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-12-12Android如何優(yōu)雅的處理重復(fù)點(diǎn)擊
這篇文章主要介紹了Android如何優(yōu)雅的處理重復(fù)點(diǎn)擊,幫助大家更好的理解和學(xué)習(xí)使用Android開發(fā),感興趣的朋友可以了解下2021-03-03Android自定義手機(jī)界面狀態(tài)欄實(shí)例代碼
我們知道IOS上的應(yīng)用,狀態(tài)欄的顏色總能與應(yīng)用標(biāo)題欄顏色保持一致,用戶體驗(yàn)很不錯(cuò),那安卓是否可以呢?若是在安卓4.4之前,答案是否定的,但在4.4之后,谷歌允許開發(fā)者自定義狀態(tài)欄背景顏色啦,這是個(gè)不錯(cuò)的體驗(yàn)2017-03-03Android下通過httpClient發(fā)送GET和POST請求的實(shí)例代碼
這篇文章介紹了Android下通過httpClient發(fā)送GET和POST請求的實(shí)例代碼,有需要的朋友可以參考一下2013-08-08Android使用 PopupWindow 實(shí)現(xiàn)底部彈窗功能
這篇文章主要介紹了Android使用 PopupWindow 實(shí)現(xiàn)底部彈窗功能,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-12-12Android 自定義 HorizontalScrollView 打造多圖片OOM 的橫向滑動效果(實(shí)例代碼)
這篇文章主要介紹了Android 自定義 HorizontalScrollView 打造多圖片OOM 的橫向滑動效果(實(shí)例代碼),需要的朋友可以參考下2017-10-10