在应用开发中,经常需要用到一些第三方的native层的开源库。这类native库,一般是用C/C++写的跨平台的,比如ffmpeg库,openssl库等。在安卓开发中,这类库,我们需要使用安卓的sdk,ndk编译工具,去编译适配安卓平台的so库来使用。那么在鸿蒙平台上,是如何操作的呢?
一、编译前准备
我们知道要编译适配安卓平台的so库的话,需要有NDK(主要提供交叉编译工具等),和安卓的sdk(主要提供编译适配平台所需的必要的库和头文件,文件系统等)。
同理,在鸿蒙平台上也是类似。鸿蒙是基于openHarmony的,openHarmony源码中,就包括了交叉编译工具,和所需的文件系统等。首先我们需要先下载openHarmony源码包,比如我要下载openHarmony4.0的,可以去这个网址下载不同版本的openHarmony源码。
如下,我选择下载openHarmony4.0Release版本
点击上面的此处,进入到4.0的页面,然后左边选择源码获取->从镜像站点获取,然后选择“标准系统Public SDK包(Windows/Linux)”,点击“站点”进行下载
下载后,将压缩包解压,可以得到ohos-sdk,里面有Linux和window两个文件夹,由于我的编译环境是Linux的,所以打开Linux下的目录,有很多zip压缩包,我们需要的是native-linux-x64-4.0.10.13-Release.zip,解压这个压缩包,得到native文件夹:
打开native文件夹,有如下东西:
里面的llvm文件夹,就是我们所需的交叉编译工具所在文件夹,而sysroot文件夹,就是我们所需的文件系统,基础库和头文件等。
二、编译脚本修改要点
如上所述,最重要的就是llvm文件夹和sysroot文件夹。
打开llvm文件夹中的bin,会看到有clang相关东西,这个clang就是我们所需的交叉编译工具:
llvm文件夹中的lib下,有对应不同cpu架构所需的交叉编译工具所需的文件夹。如下:
sysroot文件夹中的include和lib文件夹下,也是有不同cpu架构所对应的文件系统必须的基础库,头文件等:
上面的cpu架构相关文件夹中:
aarch64-linux-ohos对应的是arm架构的64位的cpu
arm-linux-ohos对应的是arm架构的32位的cpu
x86_64-linux-ohos对应的是x86架构的64位的cpu
在开源库的相关编译脚本中,一般是会根据cpu的不同,而修改不同的交叉编译工具,或相关头文件,文件系统等。就需要根据不同cpu架构修改为上述的这些文件夹名。
在很多开源库的编译脚本中,需要用到的交叉编译工具里的东西,比如CC,LD,AR,STRIP等,都可以从llvm中拿到,如下:
OHOS_LLVM=/home/weekend/openharmony/ohos-sdk/linux/native/llvm
CC=$OHOS_LLVM/bin/clang
CCGXX=$OHOS_LLVM/bin/clang++
AR=$OHOS_LLVM/bin/llvm-ar
AS=$OHOS_LLVM/bin/llvm-as
NM=$OHOS_LLVM/bin/llvm-nm
RANLIB=$OHOS_LLVM/bin/llvm-ranlib
STRIP=$OHOS_LLVM/bin/llvm-strip
OBJDUMP=$OHOS_LLVM/bin/llvm-objdump
LD=$OHOS_LLVM/bin/ld.lld
OHOS_LIBS="-L${OHOS_LLVM}/lib"
OHOS_INCS="-I${OHOS_LLVM}/include"
sysroot相关的比如:
OHOS_SYSROOT=/home/weekend/openharmony/ohos-sdk/linux/native/sysroot
OHOS_LIBS="$OHOS_LIBS -L${OHOS_SYSROOT}/usr/lib/arm-linux-ohos"
OHOS_INCS="$OHOS_INCS -I${OHOS_SYSROOT}/usr/include/arm-linux-ohos"
三、例子
举个例子,简单的Linux上编译ffmpeg库的脚本。以编译arm的64位为例子。
假如之前的安卓平台的,部分核心脚本可能是如下:
NDK_HOME=/home/weekend/android_ndk/android-ndk-r17c
INSTALL = $(ROOT)/install
ARCH="aarch64"
CPU="armv8-a"
MARCH="armv8-a"
TOOLCHAINS="$NDK_HOME/toolchains/aarch64-linux-android-4.9/prebuilt/linux-x86_64"
CROSS_PREFIX="$TOOLCHAINS/bin/aarch64-linux-android-"
SYSROOT="$NDK_HOME/platforms/$PLATFORM_64/arch-arm64"
EXTRA_CFLAGS="-march=$MARCH"
EXTRA_CFLAGS="$EXTRA_CFLAGS -I$NDK_HOME/sysroot/usr/include/aarch64-linux-android"
EXTRA_CFLAGS="$EXTRA_CFLAGS -isysroot $NDK_HOME/sysroot"
EXTRA_LDFLAGS="-lc -lm -ldl -llog"
EXTRA_LDFLAGS="$EXTRA_LDFLAGS -Wl,-rpath-link=$SYSROOT/usr/lib -L$SYSROOT/usr/lib"
ffmpeg:
@mkdir -p $(INSTALL) && \
tar -xzf $(ROOT)/FFmpeg-n4.4.tar.gz -C $(INSTALL) && \
cd $(INSTALL)/FFmpeg-n4.4 && \
./configure \
--prefix=$(INSTALL) \
--arch=aarch64 \
--cpu=$CPU" \
--disable-asm \
--cross-prefix=$CROSS_PREFIX \
--sysroot=$SYSROOT \
--libdir=$INSTALL/libs/arm64-v8a \
--incdir=$INSTALL/includes/arm64-v8a \
--disable-programs \
--disable-avdevice \
--enable-cross-compile \
--enable-small \
--enable-shared \
--enable-neon \
--disable-x86asm \
--extra-cflags="$EXTRA_CFLAGS" \
--extra-ldflags="$EXTRA_LDFLAGS" && \
make -j4 && make install && \
cd - && \
rm -rf $(INSTALL)/FFmpeg-n4.4
改为鸿蒙平台的,大致需要如下修改:
ROOT = /home/weekend/openharmony/ohos-sdk/linux/native/
INSTALL = $(ROOT)/install
SYSROOT = $(ROOT)/sysroot
LLVM = $(ROOT)/llvm
# compile
CLANG = $(LLVM)/bin/clang
CLANGXX = $(LLVM)/bin/clang++
AR = $(LLVM)/bin/llvm-ar
AS = $(LLVM)/bin/llvm-as
NM = $(LLVM)/bin/llvm-nm
RANLIB = $(LLVM)/bin/llvm-ranlib
STRIP = $(LLVM)/bin/llvm-strip
OBJDUMP = $(LLVM)/bin/llvm-objdump
LD = $(LLVM)/bin/ld.lld
OHOS_CFLAGS = --target=aarch64-linux-ohos --arch=aarch64 --sysroot=$(SYSROOT)
OHOS_LIBS="-L${LLVM}/lib"
OHOS_INCS="-I${LLVM}/include"
OHOS_LIBS="$OHOS_LIBS -L${SYSROOT}/usr/lib/aarch64-linux-ohos"
OHOS_INCS="$OHOS_INCS -I${SYSROOT}/usr/include/aarch64-linux-ohos"
ffmpeg:
@mkdir -p $(INSTALL) && \
tar -xzf $(ROOT)/FFmpeg-n4.4.tar.gz -C $(INSTALL) && \
cd $(INSTALL)/FFmpeg-n4.4 && \
./configure \
--prefix=$(INSTALL) \
--arch=aarch64 \
--target-os=linux \
--disable-asm \
--disable-programs \
--disable-avdevice \
--enable-cross-compile \
--enable-small \
--enable-shared \
--cc=$(CLANG) \
--ld=$(CLANG) \
--strip=$(STRIP) \
--extra-cflags="$(OHOS_CFLAGS) $(OHOS_INCS) $(OHOS_LIBS)" \
--extra-ldflags="$(OHOS_CFLAGS) $(OHOS_INCS) $(OHOS_LIBS)" && \
make -j4 && make install && \
cd - && \
rm -rf $(INSTALL)/FFmpeg-n4.4
综上,主要需要修改的地方就是交叉编译工具(clang或gcc)相关,和文件系统(sysroot)相关。
最后呢,很多开发朋友不知道需要学习那些鸿蒙技术?鸿蒙开发岗位需要掌握那些核心技术点?为此鸿蒙的开发学习必须要系统性的进行。
而网上有关鸿蒙的开发资料非常的少,假如你想学好鸿蒙的应用开发与系统底层开发。你可以参考这份资料,少走很多弯路,节省没必要的麻烦。由两位前阿里高级研发工程师联合打造的《鸿蒙NEXT星河版OpenHarmony开发文档》里面内容包含了(ArkTS、ArkUI开发组件、Stage模型、多端部署、分布式应用开发、音频、视频、WebGL、OpenHarmony多媒体技术、Napi组件、OpenHarmony内核、Harmony南向开发、鸿蒙项目实战等等)鸿蒙(Harmony NEXT)技术知识点
如果你是一名Android、Java、前端等等开发人员,想要转入鸿蒙方向发展。可以直接领取这份资料辅助你的学习。下面是鸿蒙开发的学习路线图。
高清完整版请点击→《鸿蒙NEXT星河版开发学习文档》
针对鸿蒙成长路线打造的鸿蒙学习文档。话不多说,我们直接看详细资料鸿蒙(OpenHarmony )学习手册(共计1236页)与鸿蒙(OpenHarmony )开发入门教学视频,帮助大家在技术的道路上更进一步。
《鸿蒙 (OpenHarmony)开发学习视频》
《鸿蒙生态应用开发V2.0白皮书》
《鸿蒙 (OpenHarmony)开发基础到实战手册》
《鸿蒙开发基础》
《鸿蒙开发进阶》
《鸿蒙开发实战》
获取这份鸿蒙星河版学习资料,请点击→《鸿蒙NEXT星河版开发学习文档》
总结
鸿蒙—作为国家主力推送的国产操作系统。部分的高校已经取消了安卓课程,从而开设鸿蒙课程;企业纷纷跟进启动了鸿蒙研发。
并且鸿蒙是完全具备无与伦比的机遇和潜力的;预计到年底将有 5,000 款的应用完成原生鸿蒙开发,未来将会支持 50 万款的应用。那么这么多的应用需要开发,也就意味着需要有更多的鸿蒙人才。鸿蒙开发工程师也将会迎来爆发式的增长,学习鸿蒙势在必行!