编译librtmp for Android

librtmp是一个强大的rtmp开源库,近期的一个Android项目涉及rtmp之类的技术,之前用ffmepg的时候也用到过它,那时候只是作为一个模块将librtmp作为第三方库编到ffmpeg里(ffmpeg本身也支持rtmp)。
将librtmp移植到Android上需要做的准备工作:
1. 准备好NDK并配置好环境变量
2. 当然事准备好librtmp的安装包了

    git clone git://git.ffmpeg.org/rtmpdump

下边一步是提出ndk的一些编译工具,适用于android平台下的编译环境,比如arm-linux-androideabi-gcc等
/home/android-ndk-r10e/build/tools/make-standalone-toolchain.sh --toolchain=arm-linux-androideabi-4.8 --platform=android-14 --install-dir=/home/lide/work/lide/lide
设置环境变量

vim /etc/profile
export PATH=/home/lide/work/lide/lide/bin:$PATH
source /etc/profile

下载polarssl-1.2.14(mbed TLS (formerly known as PolarSSL))最好下载这个版本,不然下边编译librtmp的时候会报错。https://tls.mbed.org/ 右下角 有Latest updates有这个版本
编译前将include/polarssl/config.h中的 #define POLARSSL_HAVEGE_C的注释去掉,否则编译librtmp的时候会出现 undefined reference tohavege_random’`错误,这里是因为polarssl默认关闭了havege模块。

make CC=arm-linux-androideabi-gcc APPS=
make install DESTDIR=/home/lide/work/lide/lide/sysroot

编译(librtmp为动态库)

make SYS=android CROSS_COMPILE=arm-linux-androideabi- INC="-I/home/lide/work/lide/lide/sysroot/include" CRYPTO=POLARSSL

如果想使用librtmp的静态库,使用

make SYS=android CROSS_COMPILE=arm-linux-androideabi- INC="-I/home/lide/work/lide/lide/sysroot/include" CRYPTO=POLARSSL SHARED=

至此,已经得到librtmp的android版本库了,接下来就可以拿来在android下做开发了。下一节先介绍一下android的jni使用,开始android的C之旅喽~~~~

Kotlin Hilt(Hilt Android Dependency Injection)是Android Jetpack库中的一个模块,它提供了一种简化安卓应用依赖注入的方式。Hilt基于Google的Dagger框架,使得我们可以轻松地在Android组件中自动绑定并管理依赖项,而无需手动创建和维护`@Inject`注解的实例。 要在Kotlin项目中使用Hilt,你需要按照以下步骤操作: 1. **添加依赖**: 将`ktx`和`hilt-android`库添加到你的构建.gradle文件中: ```gradle implementation 'androidx.core:ktx:1.4.0' kapt 'com.google.dagger:hilt-android-compiler:2.40.1' ``` 2. **启用Hilt**: 在`AndroidManifest.xml`中声明`<application>`标签里的`meta-data`,指定`dagger.hilt.android.application=true`: ```xml <application android:name=".MyApplication" ...> <meta-data android:name="dagger.hilt.android.application" android:value="true" /> ... </application> ``` 3. **标记需要注入的组件**: 使用`@HiltComponent`注解标记你的App或Fragment等组件,表示它们将由Hilt管理其依赖: ```kotlin @HiltComponent(modules = [MyModule::class]) interface MyAppComponent : AndroidInjector<MyActivity> ``` 4. **注入依赖**: 在类上使用`@Inject`注解声明依赖,并在构造函数中使用`@Inject`,Hilt会自动处理依赖的创建和传递: ```kotlin class MyClass { lateinit var myService: MyService @Inject constructor(private val serviceFactory: ServiceFactory) { myService = serviceFactory.create() } } class MyService @Inject constructor() { ... } ``` 5. **运行Hilt初始化**: 通常,在`MyApplication.onCreate()`或其他适当的生命周期回调中,需要初始化Hilt组件: ```kotlin override fun onCreate() { super.onCreate() HiltAndroid.init(this) DaggerMyAppComponent.builder().build().inject(this) } ```
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值