<style type="text/css">
<!--
@page
{margin:2cm}
p
{margin-bottom:0.21cm}
a:link
{}
-->
</style>
一:生成动态库(.so文件)
-->环境:
操作系统:Ubuntu9.10
ffmpeg源码版本:ffmpeg-0.6.1(可以在http://ffmpeg.org/download.html下载源码)
androidndk版本:android-ndk-r4b-linux-x86(可以在http://androidappdocs.appspot.com/sdk/ndk/index.html下载)
-->设置NDK环境变量:
1、用root用户登陆,打开命令窗口,输入cd/root
2、输入ls-a,会显示一个隐藏文件.bashrc
3、输入vi.bashrc,按i进入编辑模式
4、文件底部添加以下两行:
NDK_ROOT=/home/ndk。这里指你ndk的目录路径
exportNDK_ROOT
5、按esc退出,再按:wq保存
-->你可以测试一下有没有安装成功:
$cd $NDK_ROOT
$ ./ndk-buildNDK_PROJECT_PATH=$NDK_ROOT/samples/two-libs
-->找到生成的文件就代表安装正常了:
1、如果提示某个文件"Permissiondenied"之类的信息时,执行chmod777
your_filename就行了
2、如果提示找不到'cc1'等信息,执行chmod-R
777 *,就能解决了
-->配置源代码:
在/home/ndk/samples/创建一个FFMPEG文件夹,在里面再新建一个jni文件夹,然后把ffmpeg源码放在jni里面,所以最后ffmpeg源码的路径是:
/home/ndk/samples/FFMPEG/jni/ffmpeg
1.在ffmpeg源文件夹下创建一个config.sh,内容如下:
#!/bin/bash
PREBUILT=/home/xxx/android_NDK/android-ndk-r4b/build/prebuilt/linux-x86/arm-eabi-4.4.0
PLATFORM=/home/xxx/android_NDK/android-ndk-r4b/build/platforms/android-8/arch-arm
./configure--target-os=linux
\
--arch=arm\
--enable-version3\
--enable-gpl\
--enable-nonfree\
--disable-stripping\
--disable-ffmpeg\
--disable-ffplay\
--disable-ffserver\
--disable-ffprobe\
--disable-encoders\
--disable-muxers\
--disable-devices\
--disable-protocols\
--enable-protocol=file\
--enable-avfilter\
--disable-network\
--disable-mpegaudio-hp\
--disable-avdevice\
--enable-cross-compile\
--cc=$PREBUILT/bin/arm-eabi-gcc\
--cross-prefix=$PREBUILT/bin/arm-eabi-\
--nm=$PREBUILT/bin/arm-eabi-nm\
--extra-cflags="-fPIC-DANDROID"
\
--disable-asm\
--enable-neon\
--enable-armv5te\
--extra-ldflags="-Wl,-T,$PREBUILT/arm-eabi/lib/ldscripts/armelf.x-Wl,-rpath-link=$PLATFORM/usr/lib
-L$PLATFORM/usr/lib -nostdlib$PREBUILT/lib/gcc/arm-eabi/4.4.0/crtbegin.o$PREBUILT/lib/gcc/arm-eabi/4.4.0/crtend.o -lc -lm -ldl"
记得PREBUILT和PLATFORM要设置正确,它在你的NDK里面,你可以按自己的填写
2.然后打开命令窗口,cdffmpeg源文件夹下。
$chmod +x config.sh/*这个命令是改变config.sh执行权限而已*/
$./config.sh
如果配置正确的话显示出来的最后两行是这样的:
License:nonfree and unredistributable
Creating config.mak and config.h...
3、Configure完成后接下做NDK编译的条件了。
Android的GCC是不支持restrict关键字的,所以把ffmpeg源码下configure生成的config.h文件中的这一行:
#definerestrict restrict 改成#definerestrict/*意思就是把后面的restrict去掉*/
如果重新Configure的话记得要把这个关键字去掉。
编辑libavutil/libm.h把其中的static的方法都删除(如果找不到libavutil/libm.h,就表明你的ffmpeg版本不是0.6而是0.5的。)
分别把libavutil、libavcodec、libavformat、libavfilter、libpostproct和libswscale下的Makefile文件中下面两行删除掉:
include$(SUBDIR)../subdir.mak
include $(SUBDIR)../config.mak
然后在ffmpeg源文件夹下新建一个av.mk文件,内容如下:(这些不用替换回车)
#LOCAL_PATH is one of libavutil, libavcodec, libavformat, orlibswscale
#include$(LOCAL_PATH)/../config-$(TARGET_ARCH).mak
include$(LOCAL_PATH)/../config.mak
OBJS:=
OBJS-yes :=
MMX-OBJS-yes :=
include$(LOCAL_PATH)/Makefile
#collect objects
OBJS-$(HAVE_MMX) += $(MMX-OBJS-yes)
OBJS +=$(OBJS-yes)
FFNAME:= lib$(NAME)
FFLIBS :=$(foreach,NAME,$(FFLIBS),lib$(NAME))
FFCFLAGS =-DHAVE_AV_CONFIG_H -Wno-sign-compare -Wno-switch-Wno-pointer-sign
FFCFLAGS +=-DTARGET_CONFIG=\"config-$(TARGET_ARCH).h\"
ALL_S_FILES:= $(wildcard $(LOCAL_PATH)/$(TARGET_ARCH)/*.S)
ALL_S_FILES :=$(addprefix $(TARGET_ARCH)/, $(notdir $(ALL_S_FILES)))
ifneq($(ALL_S_FILES),)
ALL_S_OBJS := $(patsubst%.S,%.o,$(ALL_S_FILES))
C_OBJS := $(filter-out$(ALL_S_OBJS),$(OBJS))
S_OBJS := $(filter$(ALL_S_OBJS),$(OBJS))
else
C_OBJS := $(OBJS)
S_OBJS:=
endif
C_FILES:= $(patsubst %.o,%.c,$(C_OBJS))
S_FILES := $(patsubst%.o,%.S,$(S_OBJS))
FFFILES:= $(sort $(S_FILES)) $(sort $(C_FILES))
接下来就是从jni文件夹开始写Android.mk文件,如jni文件下新建一个Android.mk,内容如下:
include$(all-subdir-makefiles)
在ffmpeg下,Android.mk内容如下:
LOCAL_PATH:= $(call my-dir)
include $(CLEAR_VARS)
LOCAL_SHARED_LIBRARIES:= libavformat libavcodec libavutil libpostproc libswscalelibavfilter
LOCAL_MODULE := ffmpeg
include$(BUILD_SHARED_LIBRARY)
include $(callall-makefiles-under,$(LOCAL_PATH))
在ffmpeg\libavformat下,Android.mk内容如下:
LOCAL_PATH:= $(call my-dir)
include $(CLEAR_VARS)
include$(LOCAL_PATH)/../av.mk
LOCAL_SRC_FILES :=$(FFFILES)
LOCAL_C_INCLUDES:=\
$(LOCAL_PATH)\
$(LOCAL_PATH)/..
LOCAL_CFLAGS+= $(FFCFLAGS)
LOCAL_CFLAGS += -include "string.h"-Dipv6mr_interface=ipv6mr_ifindex
LOCAL_LDLIBS :=-lz
LOCAL_SHARED_LIBRARIES := libavutil libavcodec
LOCAL_MODULE:= $(FFNAME)
include $(BUILD_SHARED_LIBRARY)
在ffmpeg\libavcodec下,Android.mk内容如下:
LOCAL_PATH:= $(call my-dir)
include $(CLEAR_VARS)
include$(LOCAL_PATH)/../av.mk
LOCAL_SRC_FILES :=$(FFFILES)
LOCAL_C_INCLUDES:=\
$(LOCAL_PATH)\
$(LOCAL_PATH)/..
LOCAL_CFLAGS+= $(FFCFLAGS)
LOCAL_LDLIBS := -lz
LOCAL_SHARED_LIBRARIES :=libavutil
LOCAL_MODULE := $(FFNAME)
include$(BUILD_SHARED_LIBRARY)
在ffmpeg\libavfilter、ffmpeg\libavutil、ffmpeg\libpostproc、ffmpeg\libswscale下的Android,mk文件内容如下:
/*最主要是下面加红那行不一样*/
LOCAL_PATH:= $(call my-dir)
include $(CLEAR_VARS)
include$(LOCAL_PATH)/../av.mk
LOCAL_SRC_FILES :=$(FFFILES)
LOCAL_C_INCLUDES:=\
$(LOCAL_PATH)\
$(LOCAL_PATH)/..
LOCAL_CFLAGS+= $(FFCFLAGS)
#LOCAL_SHARED_LIBRARIES:=
(这行根据下面蓝色的来填写相应的lib)
LOCAL_MODULE:= $(FFNAME)
include $(BUILD_SHARED_LIBRARY)
----------------------------------------
ffmpeg\libavutil:不需要这一行,直接加#屏蔽掉。
ffmpeg\libswscale:LOCAL_SHARED_LIBRARIES:=libavutil
ffmpeg\libavfilter:LOCAL_SHARED_LIBRARIES:=libavutil
libswscalelibavcodec
ffmpeg\libpostproc:LOCAL_SHARED_LIBRARIES:=libavutil
可能编译libavdevice也是用上面这个Android.mk,然后根据提示的错误没改变红色这行就OK了。
最后就是运行ndk-build了:
$cd $NDK_ROOT
$ ./ndk-buildNDK_PROJECT_PATH=$NDK_ROOT/samples/FFMPEG
最后生成libavcodec.so、libavutil.so、libavformat.so、libavfilter.so、libswscale.so和libpostproc.so以及libffmpeg.so,你会发现libffmpeg.so只有2K(1599个字节),其实这个文件是没有加载任何东西而编译成的空SO文件,没有任何函数的SO文件。所以不能用,但其它的都可以。估计是没有LOCAL_SRC_FILES的原因。
另外一篇不错的参考文章:http://www.eoeandroid.com/thread-42184-1-1.html,它生成的是静态库
二:生成静态库(.a文件)
-->环境配置
同上
-->源代码配置
1.
在AndroidNDK上建立一個project。
2.
將FFmpeg的sourcecode整包copy到$(PROJECT)/jni底下。
3.
在$(PROJECT)/jni/ffmpeg底下建立一個config.sh:
#!/bin/bash
PREBUILT=/android-ndk-r4b/build/prebuilt/windows/arm-eabi-4.4.0
PLATFORM=/android-ndk-r4b/build/platforms/android-8/arch-arm
./configure--target-os=linux \
--arch=arm\
--enable-version3\
--enable-gpl\
--enable-nonfree\
--disable-stripping\
--disable-ffmpeg\
--disable-ffplay\
--disable-ffserver\
--disable-ffprobe\
--disable-encoders\
--disable-muxers\
--disable-devices\
--disable-protocols\
--enable-protocol=file\
--enable-avfilter\
--disable-network\
--disable-mpegaudio-hp\
--disable-avdevice\
--enable-cross-compile\
--cc=$PREBUILT/bin/arm-eabi-gcc\
--cross-prefix=$PREBUILT/bin/arm-eabi-\
--nm=$PREBUILT/bin/arm-eabi-nm\
--extra-cflags="-fPIC-DANDROID"
\
--disable-asm\
--enable-neon\
--enable-armv5te\
--extra-ldflags="-Wl,-T,$PREBUILT/arm-eabi/lib/ldscripts/armelf.x-Wl,-rpath-link=$PLATFORM/usr/lib
-L$PLATFORM/usr/lib -nostdlib$PREBUILT/lib/gcc/arm-eabi/4.4.0/crtbegin.o$PREBUILT/lib/gcc/arm-eabi/4.4.0/crtend.o -lc -lm-ldl"
PREBUILT和PLATFORM應該要符合你自己的配置。
4.
在Cygwin中,$(PROJECT)/jni/ffmpeg底下執行config.sh:
$./config.sh
configure會依據config.sh內的設定將config.mak及config.h建立出來。
5.
在剛剛生成的config.h中找到這句:
#definerestrict restrict
因為Android的gcc並不認得restrict這個keyword,所以把它改寫成:
#definerestrict
6.
將/libavutil/libm.h中所有的static函式,全都mark起來。
7.
分別修改libavcodec、libavfilter、libavformat、libavutil、libpostproc和libswscale下的Makefile,將下面兩句mark起來:
include$(SUBDIR)../config.mak
include$(SUBDIR)../subdir.mak
8.
在$(PROJECT)/jni/ffmpeg下建立一個檔案av.mk,內容如下:
#LOCAL_PATH is one of libavutil,
libavcodec, libavformat, orlibswscale
include $(LOCAL_PATH)/../config.mak
OBJS:=
OBJS-yes :=
MMX-OBJS-yes :=
include$(LOCAL_PATH)/Makefile
# collect objects
OBJS-$(HAVE_MMX)+= $(MMX-OBJS-yes)
OBJS += $(OBJS-yes)
FFNAME :=lib$(NAME)
FFLIBS :=$(foreach,NAME,$(FFLIBS),lib$(NAME))
FFCFLAGS =-DHAVE_AV_CONFIG_H -Wno-sign-compare -Wno-switch-Wno-pointer-sign
FFCFLAGS +=-DTARGET_CONFIG=\"config-$(TARGET_ARCH).h\"
ALL_S_FILES:= $(wildcard $(LOCAL_PATH)/$(TARGET_ARCH)/*.S)
ALL_S_FILES :=$(addprefix $(TARGET_ARCH)/, $(notdir $(ALL_S_FILES)))
ifneq($(ALL_S_FILES),)
ALL_S_OBJS := $(patsubst%.S,%.o,$(ALL_S_FILES))
C_OBJS := $(filter-out$(ALL_S_OBJS),$(OBJS))
S_OBJS := $(filter$(ALL_S_OBJS),$(OBJS))
else
C_OBJS := $(OBJS)
S_OBJS:=
endif
C_FILES := $(patsubst %.o,%.c,$(C_OBJS))
S_FILES:= $(patsubst %.o,%.S,$(S_OBJS))
FFFILES := $(sort $(S_FILES))$(sort $(C_FILES))
9.
在$(PROJECT)/jni底下修改Android.mk,內容如下:
include$(all-subdir-makefiles)
10.
在/ffmpeg底下新增一個Android.mk:
LOCAL_PATH:=
$(call my-dir)
include$(CLEAR_VARS)
LOCAL_STATIC_LIBRARIES:=
libavformat libavcodec libavutil libpostproc libswscale
LOCAL_MODULE:=
ffmpeg
include$(BUILD_SHARED_LIBRARY)
include$(call
all-makefiles-under,$(LOCAL_PATH))
11.
在/ffmpeg/libavformat底下新增一個Android.mk:
LOCAL_PATH:=
$(call my-dir)
include $(CLEAR_VARS)
include$(LOCAL_PATH)/../av.mk
LOCAL_SRC_FILES :=$(FFFILES)
LOCAL_C_INCLUDES:=\
$(LOCAL_PATH)\
$(LOCAL_PATH)/..
LOCAL_CFLAGS+= $(FFCFLAGS)
LOCAL_CFLAGS += -include "string.h"-Dipv6mr_interface=ipv6mr_ifindex
LOCAL_LDLIBS :=-lz
LOCAL_STATIC_LIBRARIES := $(FFLIBS)
LOCAL_MODULE :=$(FFNAME)
include $(BUILD_STATIC_LIBRARY)
12.
在/ffmpeg/libavcodec底下新增一個Android.mk:
LOCAL_PATH:=
$(call my-dir)
include $(CLEAR_VARS)
include$(LOCAL_PATH)/../av.mk
LOCAL_SRC_FILES :=$(FFFILES)
LOCAL_C_INCLUDES:=\
$(LOCAL_PATH)\
$(LOCAL_PATH)/..
LOCAL_CFLAGS+= $(FFCFLAGS)
LOCAL_LDLIBS := -lz
LOCAL_STATIC_LIBRARIES :=$(FFLIBS)
LOCAL_MODULE := $(FFNAME)
include$(BUILD_STATIC_LIBRARY)
13.
在libavfilter、libavutil、libpostproc和libswscale底下都分別新增一個Android.mk:
LOCAL_PATH:=
$(call my-dir)
include $(CLEAR_VARS)
include$(LOCAL_PATH)/../av.mk
LOCAL_SRC_FILES:=
$(FFFILES)
LOCAL_C_INCLUDES:=\
$(LOCAL_PATH)\
$(LOCAL_PATH)/..
LOCAL_CFLAGS+=
$(FFCFLAGS)
LOCAL_STATIC_LIBRARIES:=
$(FFLIBS)
LOCAL_MODULE:=
$(FFNAME)
include$(BUILD_STATIC_LIBRARY)
14.
在$(PROJECT)底下執行ndk-build:
$/android-ndk-r4b/ndk-build
15.
完成,產生出libavcodec.a、libavformat.a、libavutil.a、libpostproc.a、libswscale.a和libffmpeg.so。
分享到:
相关推荐
将 FFmpeg 移植到 Android 平台,可以让 Android 应用程序具备处理多媒体文件的强大能力,比如播放视频、音频,进行格式转换等。在 Android 上移植 FFmpeg 需要对 C/C++ 语言、Android NDK(Native Development Kit...
将FFmpeg移植到Android,需要进行一系列的编译和配置工作,以便使其能够与Android系统兼容并集成到Java或Kotlin应用中。以下将详细解释这个过程的关键步骤和知识点。 1. **NDK和Android Studio集成** - Android ...
本文将详细介绍如何将FFmpeg移植到Android项目,并使用NDK进行编译,生成可在Android平台JNI层调用的SO库。 首先,我们需要从FFmpeg官方网站下载源代码。通常,选择最新稳定版或根据项目需求选择特定版本。下载完成...
在将 FFmpeg 移植到 Android 平台时,我们需要进行一系列的步骤以确保其能在 Android 设备上正常工作。 首先,我们需要了解 FFmpeg 的基本结构。libavcodec 提供了各种音频和视频编码器和解码器,能够处理常见的...
利用NDK,将FFMPEG移植到android平台 这个是一个完整的android工程,里面有编译好的ffmpeg库 环境: ubuntu 14.04 ffmpeg 2。5 android 4.1.2 android-ndk-r10d
FFmpeg是一款强大的开源多媒体处理工具,它包含了音视频编解码库...通过以上步骤,我们可以成功地将FFmpeg移植到Android平台,并在Android应用中使用FFmpeg的强大功能,进行音视频的编码、解码、播放、录制等多种操作。
通过以上步骤,开发者可以成功地将FFmpeg移植到Android平台上,实现各种音视频处理功能。不过,移植过程可能遇到各种问题,需要对Android系统、NDK和FFmpeg有深入的理解,才能确保移植工作的顺利进行。
本文主要探讨了如何将FFmpeg移植到Android操作系统上,并提供了移植过程中的注意事项和实践经验。 首先,移植FFmpeg到Android涉及的关键步骤包括: 1. **环境配置**:在Windows、Linux或macOS等平台上搭建交叉编译...
因此,本文旨在介绍如何将成熟的开源多媒体框架ffmpeg移植到Android平台,以此来扩展Android平台的编解码能力,并利用ffserver作为流媒体服务器,实现摄像头拍摄视频的远程观看功能。本文将重点探讨ffmpeg的移植、...
在Android平台上,FFmpeg的移植是一项技术性较强的工作,涉及到多个层面的知识点。本压缩包“xmt-FFMpeg.rar”显然是针对FFmpeg在Android上的移植进行了优化,目标是使其不依赖于底层的Surface和AudioTrack。 1. **...
本教程"android_ffmpeg_tutorial01"旨在教你如何将FFmpeg移植到Android应用中,并实现基本的图片显示功能。 首先,我们需要了解如何在Android Studio项目中集成FFmpeg。这通常涉及以下几个步骤: 1. **添加FFmpeg...
总的来说,将FFmpeg移植到Android并编译为可供JNI调用的so库是一项技术性强且需要耐心的工作。但一旦完成,你就可以利用FFmpeg的强大功能,实现高效、灵活的音频和视频处理,比如视频转码、直播推流、音视频同步等。...
本篇文章将详细探讨如何将FFmpeg移植到Android平台,以及在Ubuntu环境下使用Android NDK(Native Development Kit)r9b进行编译。 首先,我们需要了解FFmpeg的基本架构。FFmpeg主要包括libavformat、libavcodec、...
4. **FFmpeg集成到Android项目**:集成FFmpeg到Android项目中,通常需要将编译好的库添加到项目的jniLibs目录下,并在应用的CMakeLists.txt或Android.mk文件中指定依赖。此外,还需要处理权限问题,如读写文件、访问...
总之,移植FFmpeg到Android是一项技术性较强的工作,涉及到Android NDK开发、跨平台编译、JNI编程等多个环节。通过这个过程,开发者可以让Android应用具备强大的音视频处理能力,实现丰富的多媒体功能。
本项目将FFmpeg移植到Android环境中,通过C++层编译和运行FFmpeg进行视频解码,然后将解码后的画面渲染到Android视图上,实现流畅的视频播放体验。 首先,我们需要理解FFmpeg的核心组件。FFmpeg主要包括以下几个...
将FFmpeg移植到Android系统具有以下重要意义: 1. **增强多媒体支持**:Android原生支持的多媒体格式有限,通过FFmpeg可以极大地扩展支持范围,满足更多场景需求。 2. **提高编解码性能**:FFmpeg拥有高效的编解码...
四、FFmpeg移植到Android 1. NDK开发:FFmpeg的移植首先需要使用Android NDK,这是一个允许在Android应用中使用C/C++代码的工具。NDK编译环境的配置是移植的第一步。 2. 配置FFmpeg:根据Android的不同版本和设备...
ffmpeg的编译过程详解,ffmpeg命令行工具在android 上的移植,通过ndk-build或者cmake方式在android studio2.2,ndk14(官网下载android studio2.2,然后通过studio上sdk下载ndk-bundle)构建工程项目。使用的ffmpeg...