鸿蒙版ijkplayer播放器示例工程适配运行

4,230 阅读3分钟

    目前移动端比较主流的播放器库,开源项目ijkplayer播放器算是数一数二的。bilibili官方的ijkplayer项目,之前是只有安卓版和IOS版的,那么现在鸿蒙系统是否有ijkplayer库呢?

    从华为的官方推荐的开源三方库资源汇总和OpenHarmony三方库中心仓中搜索ijkplayer,可以发现它们都指向了同一个开源库,这个库正在大佬们将bilibili的ijkplayer移植到openHarmony系统环境下的。下面我们介绍一下,并使用运行到手机上看看。

一、简介

1、gitee地址:gitee.com/openharmony…

2、这是一个经过移植后,在OpenHarmony环境下可用的ijkplayer播放器

    这个库是可以使用的,但是里面配套的demo工程,是基于OpenHarmony设备搭建的,没法直接编译运行到手机上。因此本篇文章主要介绍下载这个示例工程后,运行到手机上。

二、开发环境和配置调整

1、DevEco Studio版本

    开发工具版本,在它的库介绍里是基于4.0和4.1版本的,因此建议使用是4.0及以上的。

    我使用的是DevEco Studio 4.0 Beta版本,可供参考:

    点击跳转到DevEco Studio 4.0 Beta版本下载地址

    PS:不过其实也可以使用目前官网的DevEco Studio 3.1Release版本,只需要将hvigor-config.json5下的hvigorVersion和@ohos/hvigor-ohos-plugin改为2.4.2版本即可。

2、将运行环境openHarmony调整为Harmony

(1)、修改最外层build-profile.json5

    将这个文件下的"runtimeOS"去掉,然后将compileSdkVersion和compatibleSdkVersion挪到products外,与products同级,并且compileSdkVersion和compatibleSdkVersion均改为9。如下修改改动:

修改后如下代码:

"app": {  
    "compileSdkVersion": 9,  
    "compatibleSdkVersion": 9,  
    "products": [    
    {      "name": "default",      
            "signingConfig": "default",    
    }  
    ],.....

(2)、修改entry/build-profile.json5

    将(1)中的runtimeOS放到这个文件下,并修改为HarmonyOS,如下改动:

    修改后代码如下:

{  
    "apiType": 'stageMode',  
    "buildOption": {  },  
    "targets": [    
        {      
            "name": "default",      
            "runtimeOS": "HarmonyOS"    
        },    
        {   
            "name": "ohosTest",    
        }  
    ]
}

(3)、修改module.json5

    因为要运行到手机上,需要module.json5的deviceTypes中加上手机类型phone,或者直接改为phone,一共有3处module.json5。

    分别在entry/build-profile.json5、entry/src/main/module.json5和entry/src/ohosTest/module.json5:

三、编译错误调整

    上述配置相关调整完成后,开始编译,编译后会报错误。

    从代码中,看到,@ohos.base是属于openHarmoy的API10中才有的,因此需要做一下调整。在代码中,主要是如下的使用:

import { BusinessError } from '@ohos.base';
......
setScreenOnWhilePlaying(on: boolean): void {  
    window.getLastWindow(getContext(this), (err: BusinessError, data: window.Window) => {    
        data.setWindowKeepScreenOn(on);  
    });
}

    其实可以看到变量err没有使用到,而Harmony的API9的getLastWindow函数的参数其实是BaseContext,因此可以改成如下这样:

    到此,可以编译通过。

四、运行到手机上

    编译通过后,运行到手机上,如下页面:

    点击下面的播放列表,可以直接在当前页面播放,或者点击上方的测试地址文字区域,会跳转到播放页面,如下图,会有更多的一些操作,暂停,倍速等:

    目前默认的测试播放地址是devimages.apple.com.edgekey.net/streaming/e…

五、兼容性问题

    上面的运行和播放,当前gitee上的代码目前运行在mate60系列上的话,是可以正常播放的。但是mate30系列,xs2等手机播放的时候会有能听到声音但是视频黑屏的现象。

    这个是问题具体在我的另一篇文章中会具体分析和临时解决:

    ohos_ijkplayer库mate30手机播放有声音无画面问题

我已将上述所说的修改,包括mate30系列问题的修改,并修改了点界面,更直接明了。放到了我自己的仓库上,可供参考:

gitee.com/weekend45/o…

(PS:验证可运行到mate30系列手机,mate60系列可能需要回退5d8e6ab2ca0dcb953358d3d0446200c2332e3bd9这个commit的修改提交)