国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

Android | 教你如何使用HwCameraKit接入相機人像模式

這篇具有很好參考價值的文章主要介紹了Android | 教你如何使用HwCameraKit接入相機人像模式。希望對大家有所幫助。如果存在錯誤或未考慮完全的地方,請大家不吝賜教,您也可以點擊"舉報違法"按鈕提交疑問。

介紹

簡介

??HwCameraKit為開發(fā)者提供了一套兼容EMUI的相機能力開放接口,開發(fā)者可以通過HwCameraKit使自己的應(yīng)用快速接入華為相機的私有能力,擴展應(yīng)用的拍攝功能,為用戶提供更好拍攝體驗。

??人像模式為HwCameraKit開放的多種相機模式其中之一,它將允許您:

  • 獲取華為相機的人像拍攝能力,包括背景虛化、環(huán)境光、瘦臉,皮膚光滑、調(diào)色等能力;
  • 提供相機模式高級編程接口,簡化相機應(yīng)用開發(fā),并借助IDE工具快速接入上述能力。

關(guān)于本次CodeLab

你將建立什么

??在本次CodeLab中,您將使用HwCameraKit建立一款A(yù)ndroid相機應(yīng)用程序,使其可以獲得華為相機的人像拍攝功能,實現(xiàn)人像的虛化、美膚等效果。

普通拍攝(左) VS 人像模式開啟虛化(右)

你會學(xué)到什么

  • 使用HwCameraKit IDE高效集成華為相機開放能力
  • 熟悉HwCameraKit基本開發(fā)模式

你需要什么

硬件要求

  1. 開發(fā)計算機(臺式機或筆記本電腦)
  2. 操作系統(tǒng)為EMUI10.0及以上版本的華為手機

軟件要求

  1. JAVA JDK安裝包
  2. Android SDK包

    1. HwCameraKit IDE工具:DevEco

# 申請Camera相關(guān)權(quán)限
Duration: 0:05

   1. 在工程的Manifest文件中添加相關(guān)權(quán)限:
 
<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. 動態(tài)申請相關(guān)權(quán)限:

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);

/**

 * 動態(tài)請求WRITE_EXTERNAL_STORAGE CAMERA RECORD_AUDIO權(quán)限
 *
 * @param activity 應(yīng)用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);
}

集成HwCameraKit開放能力

Duration: 0:60
??通過IDE提供的功能卡片,可以快速獲取示例代碼并將其添加到工程中,以人像模式為例,找到人像能力卡片:可通過Tools->EMUI Kits->Kit Assistant->Camera->Portrait Mode 來找到該卡片。

提示:本次Codelabs提供了配套的app開發(fā)工程,請使用IDE工具導(dǎo)入,并根據(jù)如下步驟,實現(xiàn)提供的配套工程中帶有/ TODO /注釋的方法,從而快速集成人像模式。

步驟1 模式創(chuàng)建:獲取CameraKit實例,創(chuàng)建人像模式

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

步驟2 配置模式:配置模式的狀態(tài)回調(diào),數(shù)據(jù)回調(diào)及處理這些回調(diào)的Handler,以及預(yù)覽、拍照分辨率等參數(shù)

??從mModeStateCallback的onCreated回調(diào)后,可從入?yún)⒖色@得人像Mode實例

/** 在onCreated回調(diào)中獲取mode對象,然后以行為的狀態(tài)回調(diào)和數(shù)據(jù)回調(diào)及對應(yīng)的線程為入?yún)?,初始化ModeConfig.Builder,配置預(yù)覽的surface和拍照的大小,通過configure命令將配置項設(shè)置到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");
}

??使用構(gòu)造器ModeConfig.Builder配置模式的狀態(tài)回調(diào)及數(shù)據(jù)回調(diào)及執(zhí)行回調(diào)所在的Handler。從狀態(tài)回調(diào)中,開發(fā)者可以獲取如啟動預(yù)覽后狀態(tài)變化、拍照結(jié)束狀態(tài)、手動對焦結(jié)束、人臉檢測結(jié)果返回等信息;從數(shù)據(jù)回調(diào)中,開發(fā)者可獲取模式動作執(zhí)行過程中產(chǎn)生數(shù)據(jù)結(jié)果(如拍照圖像數(shù)據(jù)等)。還可通過ModeConfig.Builder配置預(yù)覽Surface及拍照分辨率。

步驟3 模式操作

3.1 開啟預(yù)覽

/* 在接收到到onConfigured回調(diào)后,說明mode配置成功,模式進入開啟狀態(tài),此時調(diào)用startPreview命令開啟預(yù)覽。*/

private   void startPreview() {
    mMode.startPreview();
}

3.2 參數(shù)設(shè)置

/* 用戶可以通過ModeCharacteristics#getSupportedParameters查詢當前模式下支持的參數(shù)(以人像模式為例:支持背景虛化,美膚等),通過ModeCharacteristics#getParameterRange查詢參數(shù)支持的取值范圍,通過Mode#setParameter設(shè)置對應(yīng)效果。*/

/* 設(shè)置人像虛化 */ 
mMode.setParameter(RequestKey.HW_PORTRAIT_SPOTS_BOKEH,   validValue);

/* 設(shè)置美膚:皮膚光滑 */
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]);
}
/* 用戶可以通過設(shè)計按鈕等方式,調(diào)用takePicture進行拍照,異步通過onImageAvailable回調(diào),返回照片Image數(shù)據(jù)。*/
mMode.takePicture();

步驟4 操作Callback

/* 以數(shù)據(jù)回調(diào)為例,在拍照后從回調(diào)里獲取圖片 */
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獲取拍照圖片等數(shù)據(jù)以外,從ActionStateCallback中還可獲取模式動作執(zhí)行過程中,執(zhí)行狀態(tài)結(jié)果的回調(diào)處理,如啟動預(yù)覽后狀態(tài)變化、拍照結(jié)束狀態(tài)、手動對焦結(jié)束、人臉檢測結(jié)果返回等。

步驟5 模式釋放

/* 應(yīng)用切后臺,需要將模式釋放 */
@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 IDE插件的安裝和使用
  • 利用HwCameraKit將華為相機開放能力接入app

更多HwCameraKit相關(guān)信息請關(guān)注我們的官網(wǎng):https://developer.huawei.com/consumer/cn/CameraKit

往期鏈接:Android | 教你如何快速集成機器學(xué)習(xí)能力
內(nèi)容來源:https://developer.huawei.com/consumer/cn/forum/topicview?tid=0201234569803940158&fid=3467
原作者:艾羅門特

作者:華為開發(fā)者論壇

原文地址:https://segmentfault.com/a/1190000022515353文章來源地址http://www.zghlxwxcb.cn/news/detail-834914.html

喜歡 0

到了這里,關(guān)于Android | 教你如何使用HwCameraKit接入相機人像模式的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實不符,請點擊違法舉報進行投訴反饋,一經(jīng)查實,立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費用

相關(guān)文章

  • Unity之如何接入google cardboard-xr-plugin實現(xiàn)android手機VR

    Unity之如何接入google cardboard-xr-plugin實現(xiàn)android手機VR

    我們提到VR,總是會想到Oculus,HTC Vive,Pico等頭戴VR設(shè)備,但是別忘了,最早Google就通過再手機端實現(xiàn)VR了,而且還推出過Cardboard手機盒子,讓我們可以用最低的成本體驗到VR效果。 先說明一下,Unity在1028版本之前,支持過GoogleVR,但是后來因為統(tǒng)一OpenXR標準之后,放棄了對G

    2024年02月07日
    瀏覽(24)
  • Unity+Android GET和POST方式的簡單實現(xiàn)API請求(人像動漫化)

    Unity+Android GET和POST方式的簡單實現(xiàn)API請求(人像動漫化)

    Unity與Android的簡單交互,Unity打開Android相冊并調(diào)用 前端時間本想著去弄個小工具,就是圖文生成視頻,可是這個的API接口的調(diào)用的測試權(quán)限死活申請不下來,只能放棄,就順道看了下BaiduAI,竟然被我發(fā)現(xiàn)了一個很有趣的API接口。人像動漫化,于是就想著整一個人像動漫化A

    2024年02月10日
    瀏覽(26)
  • Android之 Camera相機使用

    Android之 Camera相機使用

    一 簡介 1.1 隨著信息時代的發(fā)展,相機在我們生活中使用越來越頻繁,也成為手機的基本配置之一。相機可以用來拍照,拍視頻,人臉識別,視頻聊天,掃碼支付,監(jiān)控等常見領(lǐng)域 不管什么場景,基本原理都差不多,都要先通過相機采集原始數(shù)據(jù),也就是二進制字節(jié)數(shù)據(jù),我

    2024年02月15日
    瀏覽(20)
  • Unity使用Android Stdio接入SDK制作AAR包

    Unity使用Android Stdio接入SDK制作AAR包

    最近需要在Unity2021版本中接入SDK,發(fā)現(xiàn)和直接接入SDK有些區(qū)別,這里把接入的流程記錄一下。 Unity在最新的版本中把UnityPlayActivity.java,從Class.jar中移除,需要在Unity的工程內(nèi)找到這個文件,并把其加入到Android Stadio內(nèi),才能使用。 ①選擇Android Library ②包名要和Unity工程里面相

    2024年02月10日
    瀏覽(16)
  • Android OpenGL EGL使用——自定義相機

    Android OpenGL EGL使用——自定義相機

    如果要使用OpenGl來自定義相機,EGL還是需要了解下的。 可能大多數(shù)開發(fā)者使用過OpengGL但是不知道EGL是什么?EGL的作用是什么?這其實一點都不奇怪,因為Android中的GlSurfaceView已經(jīng)將EGL環(huán)境都給配置好了,你一直在使用,只是不知道他的存在罷了。 很多人可能在使用OpenGl ES渲

    2024年01月22日
    瀏覽(18)
  • Android 使用Camera1實現(xiàn)相機預(yù)覽、拍照、錄像

    Android 使用Camera1實現(xiàn)相機預(yù)覽、拍照、錄像

    本文介紹如何從零開始,在 Android 中實現(xiàn) Camera1 的接入,并在文末提供 Camera1Manager 工具類,可以用于快速接入 Camera1 。 Android Camera1 API 雖然已經(jīng)被 Google 廢棄,但有些場景下不得不使用。 并且 Camera1 返回的幀數(shù)據(jù)是 NV21 ,不像 Camera2 、 CameraX 那樣,需要自己再轉(zhuǎn)一層,才能得

    2024年02月08日
    瀏覽(25)
  • android使用相機 intent.resolveActivity returns null

    android使用相機 intent.resolveActivity returns null

    筆者使用java進行android開發(fā),啟動相機時 intent.resolveActivity returns null 筆者使用如下代碼啟動相機 控制臺報錯: 步驟1、 在packageappsrcmainAndroidManifest.xml中配置如下內(nèi)容: 具體操作如下圖所示: 具體代碼: 問題產(chǎn)生的原因是在Android 11及更高版本中,由于引入了更嚴格的權(quán)限

    2024年01月21日
    瀏覽(21)
  • Android 使用 registerForActivityResult() 打開系統(tǒng)相冊或相機獲取圖像

    當使用了 AndroidX 后,發(fā)現(xiàn) `startActivityForResult()` 標記為過時了,而是推薦我們使用 `registerForActivityResult()` 函數(shù)。 `registerForActivityResult()` 函數(shù)是 Android 中用于啟動 Activity 結(jié)果回調(diào)的新方式。這個函數(shù)的目的是簡化在 Activity 和 Fragment 之間進行啟動其他 Activity 并接收結(jié)果的過程

    2024年02月08日
    瀏覽(18)
  • Unity接入??迪鄼CSDK(保姆級)

    Unity接入??迪鄼CSDK(保姆級)

    1.問題描述:控制??迪鄼C進行操作(遠焦、近焦、上下左右移動等)。 2.準備:官網(wǎng)下載SDK:https://open.hikvision.com/#home 選擇適合自己平臺代碼語言開發(fā)的SDK下載 Demo里有對應(yīng)案例可查看 在庫文件里除了ClientDemoDll文件 都拖進unityPlugins ,然后有兩個重復(fù)Dll文件(OpenAL,AudioRend

    2024年02月16日
    瀏覽(19)
  • 大華相機接入web頁面實現(xiàn)人臉識別

    大華相機接入web頁面實現(xiàn)人臉識別

    先看下效果,中間主視頻流就是大華相機(視頻編碼H.264),??迪鄼C(視屏編碼H.265) 前端接入視屏流代碼 后臺部署需要啟動:webrtc-streamer.exe 用來解碼視屏流,這樣就能實現(xiàn)web頁面接入視屏流。 主視屏流下面的相機抓拍圖片和預(yù)警數(shù)據(jù)接口是怎么實現(xiàn)的呢? 1、需要把大

    2024年02月16日
    瀏覽(11)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包