您好,登錄后才能下訂單哦!
這篇文章主要介紹“如何使用HwCameraKit接入相機人像模式”,在日常操作中,相信很多人在如何使用HwCameraKit接入相機人像模式問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”如何使用HwCameraKit接入相機人像模式”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
??HwCameraKit為開發者提供了一套兼容EMUI的相機能力開放接口,開發者可以通過HwCameraKit使自己的應用快速接入華為相機的私有能力,擴展應用的拍攝功能,為用戶提供更好拍攝體驗。
??人像模式為HwCameraKit開放的多種相機模式其中之一,它將允許您:
獲取華為相機的人像拍攝能力,包括背景虛化、環境光、瘦臉,皮膚光滑、調色等能力;
提供相機模式高級編程接口,簡化相機應用開發,并借助IDE工具快速接入上述能力。
  在本次CodeLab中,您將使用HwCameraKit建立一款Android相機應用程序,使其可以獲得華為相機的人像拍攝功能,實現人像的虛化、美膚等效果。
使用HwCameraKit IDE高效集成華為相機開放能力
熟悉HwCameraKit基本開發模式
硬件要求
開發計算機(臺式機或筆記本電腦)
操作系統為EMUI10.0及以上版本的華為手機
軟件要求
JAVA JDK安裝包
Android SDK包
Duration: 0:05
??1. 在工程的Manifest文件中添加相關權限:
HwCameraKit IDE工具:DevEco
<uses-permission android:name="android.permission.CAMERA"/> <uses-permission android:name="android.permission.RECORD_AUDIO"/> <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
??2. 動態申請相關權限:
private static final String [] PERMISSIONS_ARRAY = new String[] { Manifest.permission.WRITE_EXTERNAL_STORAGE, Manifest.permission.CAMERA, Manifest.permission.RECORD_AUDIO, Manifest.permission.ACCESS_FINE_LOCATION }; private static List<String> permissionsList = new ArrayList<>(PERMISSIONS_ARRAY.length); /** * 動態請求WRITE_EXTERNAL_STORAGE CAMERA RECORD_AUDIO權限 * * @param activity 應用activity */ public static void requestPermission (final Activity activity) { for (String permission : PERMISSIONS_ARRAY) { if (ContextCompat.checkSelfPermission(activity, permission) != PackageManager.PERMISSION_GRANTED) { permissionsList.add(permission); } } ActivityCompat.requestPermissions(activity, permissionsList.toArray(new String [permissionsList.size()]), REQUEST_CODE_ASK_PERMISSIONS); }
Duration: 0:60
??通過IDE提供的功能卡片,可以快速獲取示例代碼并將其添加到工程中,以人像模式為例,找到人像能力卡片:可通過Tools->EMUI Kits->Kit Assistant->Camera->Portrait Mode 來找到該卡片。
提示:本次Codelabs提供了配套的app開發工程,請使用IDE工具導入,并根據如下步驟,實現提供的配套工程中帶有/ TODO /注釋的方法,從而快速集成人像模式。
private @Mode.Type int mCurrentModeType; private CameraKit mCameraKit; private ModeCharacteristics mModeCharacteristics; private void createMode() { mCameraKit = CameraKit.getInstance(getApplicationContext()); if (mCameraKit == null) { Log.e(TAG, "This device does not support CameraKit!"); } /** Query camera id list*/ String[] cameraLists = mCameraKit . getCameraIdList (); if ((cameraLists != null) && (cameraLists.length > 0)) { Log.i(TAG, "Try to use camera with id " + cameraLists[0]); /** Query supported modes of this device*/ int[] modes = mCameraKit . getSupportedModes (cameraLists[0]); if (!Arrays.stream(modes).anyMatch((i) -> i == mCurrentModeType)) { Log.w(TAG, "Current mode is not supported in this device!"); return; } mCameraKit.createMode(cameraLists[0], mCurrentModeType, mModeStateCallback, mCameraKitHandler); } }
??從mModeStateCallback的onCreated回調后,可從入參可獲得人像Mode實例
/** 在onCreated回調中獲取mode對象,然后以行為的狀態回調和數據回調及對應的線程為入參,初始化ModeConfig.Builder,配置預覽的surface和拍照的大小,通過configure命令將配置項設置到mMode中,進行模式的激活*/ private void configMode() { Log.i(TAG, "configMode begin"); /** Query supported preview size*/ List<Size> previewSizes = mModeCharacteristics.getSupportedPreviewSizes(SurfaceTexture.class); /** Query supported capture size*/ List<Size> captureSizes = mModeCharacteristics.getSupportedCaptureSizes(ImageFormat.JPEG); Log.d(TAG, "configMode: captureSizes = " + captureSizes.size() + ";previewSizes=" + previewSizes.size()); /** Use the first one or default 4000x3000*/ mCaptureSize = captureSizes.stream().findFirst().orElse(new Size(4000, 3000)); /** Use the same ratio with preview*/ mPreviewSize = previewSizes.stream().filter((size) -> Math.abs((1.0f * size.getHeight() / size.getWidth()) - (1.0f * mCaptureSize.getHeight() / mCaptureSize.getWidth())) < 0.01).findFirst().get(); Log.i(TAG, "configMode: mCaptureSize = " + mCaptureSize + ";mPreviewSize=" + mPreviewSize); /** Update view*/ runOnUiThread(() -> mTextureView.setAspectRatio(mPreviewSize.getHeight(), mPreviewSize.getWidth())); SurfaceTexture texture = mTextureView.getSurfaceTexture(); if (texture == null) { Log.e(TAG, "configMode: texture=null!"); return; } /** Set buffer size of view*/ texture.setDefaultBufferSize(mPreviewSize.getWidth(), mPreviewSize.getHeight()); /** Get surface of texture*/ Surface surface = new Surface(texture); /** Add preview and capture parameters to config builder*/ modeConfigBuilder.addPreviewSurface(surface).addCaptureImage(mCaptureSize, ImageFormat.JPEG); /** Set callback for config builder*/ modeConfigBuilder.setDataCallback(actionDataCallback, mCameraKitHandler); modeConfigBuilder.setStateCallback(actionStateCallback, mCameraKitHandler); /** Configure mode*/ mMode.configure(); Log.i(TAG, "configMode end"); }
??使用構造器ModeConfig.Builder配置模式的狀態回調及數據回調及執行回調所在的Handler。從狀態回調中,開發者可以獲取如啟動預覽后狀態變化、拍照結束狀態、手動對焦結束、人臉檢測結果返回等信息;從數據回調中,開發者可獲取模式動作執行過程中產生數據結果(如拍照圖像數據等)。還可通過ModeConfig.Builder配置預覽Surface及拍照分辨率。
/* 在接收到到onConfigured回調后,說明mode配置成功,模式進入開啟狀態,此時調用startPreview命令開啟預覽。*/ private void startPreview() { mMode.startPreview(); }
/* 用戶可以通過ModeCharacteristics#getSupportedParameters查詢當前模式下支持的參數(以人像模式為例:支持背景虛化,美膚等),通過ModeCharacteristics#getParameterRange查詢參數支持的取值范圍,通過Mode#setParameter設置對應效果。*/ /* 設置人像虛化 */ mMode.setParameter(RequestKey.HW_PORTRAIT_SPOTS_BOKEH, validValue); /* 設置美膚:皮膚光滑 */ int[] smoothLevels = modeCharacteristics.getSupportedBeauty(Metadata.BeautyType.HW_BEAUTY_SKIN_SMOOTH); if (smoothLevels != null && smoothLevels.length != 0) { mMode.setBeauty(Metadata.BeautyType.HW_BEAUTY_SKIN_SMOOTH,smoothLevels[smoothLevels.length - 1]); } /* 用戶可以通過設計按鈕等方式,調用takePicture進行拍照,異步通過onImageAvailable回調,返回照片Image數據。*/ mMode.takePicture();
/* 以數據回調為例,在拍照后從回調里獲取圖片 */ private final ActionDataCallback actionDataCallback = new ActionDataCallback() { @Override public void onImageAvailable(Mode mode, int id, Image image) { super.onImageAvailable(mode, id, image); Log.d(TAG, "onImageAvailable"); new ImageSaver(image, mFile, CameraKitActivity.this).run(); } };
提示:除了從ActionDataCallback獲取拍照圖片等數據以外,從ActionStateCallback中還可獲取模式動作執行過程中,執行狀態結果的回調處理,如啟動預覽后狀態變化、拍照結束狀態、手動對焦結束、人臉檢測結果返回等。
/* 應用切后臺,需要將模式釋放 */ @Override protected void onPause() { if (mBackgroundHandler != null) { mBackgroundHandler.post(new Runnable() { @Override public void run() { if (mMode != null) { mMode.release(); mMode = null; } } }); } super.onPause(); }
到此,關于“如何使用HwCameraKit接入相機人像模式”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。