靜態照片一鍵動態化,教你如何集成動態照片能力


有趣的靜態照片動態化是如何實現的?

華為視頻編輯服務(Video Editor Kit)全新上線的“動態照片”能力,利用人臉檢測、人臉關鍵點檢測、表情特征提取、目標人物表情驅動等AI算法,只需上傳一張靜態人物照片,就可以生成人物微笑等動作,輕松實現靜態照片動態化,讓照片更加鮮活生動。

想要實現此功能也很簡單,一起看下集成步驟吧!

集成代碼

1 開發准備

詳細准備步驟可參考華為開發者聯盟官網:
https://developer.huawei.com/consumer/cn/doc/development/Media-Guides/config-agc-0000001101108580?ha_source=hms1

2 編輯工程集成

2.1 設置應用的鑒權信息

可以通過api_key或者Access Token來設置應用鑒權信息。

  • 通過setAccessToken方法設置Access Token,在應用啟動時初始化設置一次即可,無需多次設置。
MediaApplication.getInstance().setAccessToken("your access token");
  • 通過setApiKey方法設置api_key,在應用啟動時初始化設置一次即可,無需多次設置。
MediaApplication.getInstance().setApiKey("your ApiKey");

2.2設置唯一標識ID,即License ID。

License ID是進行管控的有效憑證,您要保證設置License ID的唯一性。

MediaApplication.getInstance().setLicenseId("License ID");

2.2.1初始化Editor運行環境

創建編輯工程,需要首先創建Editor對象並初始化其運行環境。當離開編輯工程時,應釋放Editor實例。

(1) 創建Editor對象

HuaweiVideoEditor editor = HuaweiVideoEditor.create(getApplicationContext());

(2) 指定預覽窗口的布局位置

預覽窗口負責視頻圖像畫面的渲染,由視頻編輯原子能力SDK內部創建SurfaceView來實現。在創建窗口之前,需要在您的App中指定預覽窗口的布局位置。

<LinearLayout    
    android:id="@+id/video_content_layout"    
    android:layout_width="0dp"    
    android:layout_height="0dp"    
    android:background="@color/video_edit_main_bg_color"    
    android:gravity="center"    
    android:orientation="vertical" />
// 指定預覽窗口 
LinearLayout mSdkPreviewContainer = view.findViewById(R.id.video_content_layout);

// 設置預覽窗口承載的布局 
editor.setDisplay(mSdkPreviewContainer);

(3) 初始化運行環境,如果License鑒權失敗,會拋出LicenseException。

當Editor對象創建之后,此時還沒有占用實際的系統資源,需要手動選擇其環境初始化的時機,此時視頻編輯原子能力SDK內部會創建必須的線程和定時器等。

try {
        editor.initEnvironment();
   } catch (LicenseException error) { 
        SmartLog.e(TAG, "initEnvironment failed: " + error.getErrorMsg());    
        finish();
        return;
   }
	

2.2.2添加視頻、圖片

創建一條視頻泳道,然后往泳道上添加圖片或者視頻素材。圖片和視頻素材需要通過文件路徑添加到泳道上。

// 獲取時間線對象 
HVETimeLine timeline = editor.getTimeLine();

// 創建視頻泳道 
HVEVideoLane videoLane = timeline.appendVideoLane();

// 在視頻泳道的末尾,添加視頻資源 
HVEVideoAsset videoAsset = vidoeLane.appendVideoAsset("test.mp4");

// 在視頻泳道的末尾,添加圖片資源 
HVEImageAsset imageAsset = vidoeLane.appendImageAsset("test.jpg");

3 動態照片集成

// 添加動態照片特效
videoAsset.addFaceReenactAIEffect(new HVEAIProcessCallback() {
        @Override
        public void onProgress(int progress) {
        // 動態照片處理進度
        }

        @Override
        public void onSuccess() {
        // 動態照片處理成功
        }

        @Override
        public void onError(int errorCode, String errorMessage) {
        // 動態照片處理失敗
        }
    });

// 動態照片特效
videoAsset.removeFaceReenactAIEffect();

Demo演示

了解更多詳情>>

訪問華為開發者聯盟官網
獲取開發指導文檔
華為移動服務開源倉庫地址:GitHubGitee

關注我們,第一時間了解 HMS Core 最新技術資訊~


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM