├── .gitignore
├── README.md
├── app
├── .gitignore
├── CMakeLists.txt
├── build.gradle
├── proguard-rules.pro
└── src
│ ├── androidTest
│ └── java
│ │ └── io
│ │ └── github
│ │ └── iamyours
│ │ └── ffmpegaudioplayer
│ │ └── ExampleInstrumentedTest.kt
│ ├── main
│ ├── AndroidManifest.xml
│ ├── assets
│ │ ├── TimeTravel.mp3
│ │ ├── a.mp3
│ │ ├── b.mp3
│ │ ├── c.mp3
│ │ ├── d.mp3
│ │ ├── mix.pcm
│ │ ├── mix.xmp
│ │ └── test1.mp3
│ ├── cpp
│ │ ├── AudioPlayer.cpp
│ │ ├── AudioPlayer.h
│ │ ├── audio-mix.cpp
│ │ ├── audio_encode.cpp
│ │ ├── native-lib.cpp
│ │ ├── opensles-test.cpp
│ │ ├── player-test.cpp
│ │ └── wave_player.cpp
│ ├── java
│ │ └── io
│ │ │ └── github
│ │ │ └── iamyours
│ │ │ └── ffmpegaudioplayer
│ │ │ ├── ByteUtil.java
│ │ │ ├── Callback.java
│ │ │ ├── FFmpegAudioPlayer.kt
│ │ │ ├── FFmpegAudioRecorder.kt
│ │ │ ├── FFmpegPlayerActivity.kt
│ │ │ ├── FileUtil.java
│ │ │ ├── MainActivity.kt
│ │ │ ├── WaveDataCallback.java
│ │ │ ├── WavePlayerActivity.kt
│ │ │ └── view
│ │ │ ├── AudioData.java
│ │ │ ├── LineRenderer.java
│ │ │ ├── Renderer.java
│ │ │ ├── VisualizerView.java
│ │ │ └── WaveView.java
│ ├── jniLibs
│ │ ├── armeabi-v7a
│ │ │ ├── libavcodec-57.so
│ │ │ ├── libavfilter-6.so
│ │ │ ├── libavformat-57.so
│ │ │ ├── libavutil-55.so
│ │ │ ├── libswresample-2.so
│ │ │ └── libswscale-4.so
│ │ └── include
│ │ │ ├── libavcodec
│ │ │ ├── avcodec.h
│ │ │ ├── avdct.h
│ │ │ ├── avfft.h
│ │ │ ├── d3d11va.h
│ │ │ ├── dirac.h
│ │ │ ├── dv_profile.h
│ │ │ ├── dxva2.h
│ │ │ ├── jni.h
│ │ │ ├── mediacodec.h
│ │ │ ├── qsv.h
│ │ │ ├── vaapi.h
│ │ │ ├── vda.h
│ │ │ ├── vdpau.h
│ │ │ ├── version.h
│ │ │ ├── videotoolbox.h
│ │ │ ├── vorbis_parser.h
│ │ │ └── xvmc.h
│ │ │ ├── libavfilter
│ │ │ ├── avfilter.h
│ │ │ ├── avfiltergraph.h
│ │ │ ├── buffersink.h
│ │ │ ├── buffersrc.h
│ │ │ └── version.h
│ │ │ ├── libavformat
│ │ │ ├── avformat.h
│ │ │ ├── avio.h
│ │ │ └── version.h
│ │ │ ├── libavutil
│ │ │ ├── adler32.h
│ │ │ ├── aes.h
│ │ │ ├── aes_ctr.h
│ │ │ ├── attributes.h
│ │ │ ├── audio_fifo.h
│ │ │ ├── avassert.h
│ │ │ ├── avconfig.h
│ │ │ ├── avstring.h
│ │ │ ├── avutil.h
│ │ │ ├── base64.h
│ │ │ ├── blowfish.h
│ │ │ ├── bprint.h
│ │ │ ├── bswap.h
│ │ │ ├── buffer.h
│ │ │ ├── camellia.h
│ │ │ ├── cast5.h
│ │ │ ├── channel_layout.h
│ │ │ ├── common.h
│ │ │ ├── cpu.h
│ │ │ ├── crc.h
│ │ │ ├── des.h
│ │ │ ├── dict.h
│ │ │ ├── display.h
│ │ │ ├── downmix_info.h
│ │ │ ├── error.h
│ │ │ ├── eval.h
│ │ │ ├── ffversion.h
│ │ │ ├── fifo.h
│ │ │ ├── file.h
│ │ │ ├── frame.h
│ │ │ ├── hash.h
│ │ │ ├── hmac.h
│ │ │ ├── hwcontext.h
│ │ │ ├── hwcontext_cuda.h
│ │ │ ├── hwcontext_dxva2.h
│ │ │ ├── hwcontext_qsv.h
│ │ │ ├── hwcontext_vaapi.h
│ │ │ ├── hwcontext_vdpau.h
│ │ │ ├── imgutils.h
│ │ │ ├── intfloat.h
│ │ │ ├── intreadwrite.h
│ │ │ ├── lfg.h
│ │ │ ├── log.h
│ │ │ ├── lzo.h
│ │ │ ├── macros.h
│ │ │ ├── mastering_display_metadata.h
│ │ │ ├── mathematics.h
│ │ │ ├── md5.h
│ │ │ ├── mem.h
│ │ │ ├── motion_vector.h
│ │ │ ├── murmur3.h
│ │ │ ├── opt.h
│ │ │ ├── parseutils.h
│ │ │ ├── pixdesc.h
│ │ │ ├── pixelutils.h
│ │ │ ├── pixfmt.h
│ │ │ ├── random_seed.h
│ │ │ ├── rational.h
│ │ │ ├── rc4.h
│ │ │ ├── replaygain.h
│ │ │ ├── ripemd.h
│ │ │ ├── samplefmt.h
│ │ │ ├── sha.h
│ │ │ ├── sha512.h
│ │ │ ├── stereo3d.h
│ │ │ ├── tea.h
│ │ │ ├── threadmessage.h
│ │ │ ├── time.h
│ │ │ ├── timecode.h
│ │ │ ├── timestamp.h
│ │ │ ├── tree.h
│ │ │ ├── twofish.h
│ │ │ ├── version.h
│ │ │ └── xtea.h
│ │ │ ├── libswresample
│ │ │ ├── swresample.h
│ │ │ └── version.h
│ │ │ └── libswscale
│ │ │ ├── swscale.h
│ │ │ └── version.h
│ └── res
│ │ ├── drawable-v24
│ │ └── ic_launcher_foreground.xml
│ │ ├── drawable
│ │ └── ic_launcher_background.xml
│ │ ├── layout
│ │ ├── activity_ffmpeg_player.xml
│ │ ├── activity_main.xml
│ │ └── activity_wave_player.xml
│ │ ├── mipmap-anydpi-v26
│ │ ├── ic_launcher.xml
│ │ └── ic_launcher_round.xml
│ │ ├── mipmap-hdpi
│ │ ├── ic_launcher.png
│ │ └── ic_launcher_round.png
│ │ ├── mipmap-mdpi
│ │ ├── ic_launcher.png
│ │ └── ic_launcher_round.png
│ │ ├── mipmap-xhdpi
│ │ ├── ic_launcher.png
│ │ └── ic_launcher_round.png
│ │ ├── mipmap-xxhdpi
│ │ ├── ic_launcher.png
│ │ └── ic_launcher_round.png
│ │ ├── mipmap-xxxhdpi
│ │ ├── ic_launcher.png
│ │ └── ic_launcher_round.png
│ │ └── values
│ │ ├── colors.xml
│ │ ├── strings.xml
│ │ └── styles.xml
│ └── test
│ └── java
│ └── io
│ └── github
│ └── iamyours
│ └── ffmpegaudioplayer
│ └── ExampleUnitTest.kt
├── build.gradle
├── build_android_all.sh
├── gradle.properties
├── gradle
└── wrapper
│ ├── gradle-wrapper.jar
│ └── gradle-wrapper.properties
├── gradlew
├── gradlew.bat
└── settings.gradle
/.gitignore:
--------------------------------------------------------------------------------
1 | *.iml
2 | .gradle
3 | /local.properties
4 | /.idea
5 | .DS_Store
6 | /build
7 | /captures
8 | .externalNativeBuild
9 |
--------------------------------------------------------------------------------
/README.md:
--------------------------------------------------------------------------------
1 | 在Android使用FFmpeg的一些例子
2 | - [x] **mp3解码成pcm**
3 | - [x] **多个文件解码合成**
4 | (使用amix过滤器合成多个音频文件)
5 | - [x] **实时解码播放**
6 | (c++生产消费模型,实时解码,OpenSL ES播放pcm)
7 | - [x] **多音轨播放**
8 | (多种AVFilter综合组合使用,实现音频变速,调音,多音轨合成实时播放)
9 | - [x] **音频波形显示**
10 | (Visualizer替代方案,避免需要录音权限)
11 | - [ ] **录音编码** (libmp3lame+FFmpeg交叉编译,使用FFmpeg实现实时录音编码成mp3)
--------------------------------------------------------------------------------
/app/.gitignore:
--------------------------------------------------------------------------------
1 | /build
2 |
--------------------------------------------------------------------------------
/app/CMakeLists.txt:
--------------------------------------------------------------------------------
1 | cmake_minimum_required(VERSION 3.6)
2 | # 查找当前目录下的所有源文件,并保存到 DIR_LIB_SRCS 变量
3 | aux_source_directory(src/main/cpp/ DIR_LIB_SRCS)
4 | add_definitions(-w)
5 | add_library( native-lib
6 | SHARED
7 | ${DIR_LIB_SRCS} )
8 |
9 | find_library( log-lib
10 | log )
11 | find_library( android-lib
12 | android )
13 | set(distribution_DIR ${CMAKE_SOURCE_DIR}/src/main/jniLibs/${ANDROID_ABI})
14 | add_library( avutil-55
15 | SHARED
16 | IMPORTED )
17 | set_target_properties( avutil-55
18 | PROPERTIES IMPORTED_LOCATION
19 | ${distribution_DIR}/libavutil-55.so)
20 | add_library( swresample-2
21 | SHARED
22 | IMPORTED )
23 | set_target_properties( swresample-2
24 | PROPERTIES IMPORTED_LOCATION
25 | ${distribution_DIR}/libswresample-2.so)
26 | add_library( avcodec-57
27 | SHARED
28 | IMPORTED )
29 | set_target_properties( avcodec-57
30 | PROPERTIES IMPORTED_LOCATION
31 | ${distribution_DIR}/libavcodec-57.so)
32 | add_library( avfilter-6
33 | SHARED
34 | IMPORTED )
35 | set_target_properties( avfilter-6
36 | PROPERTIES IMPORTED_LOCATION
37 | ${distribution_DIR}/libavfilter-6.so)
38 | add_library( swscale-4
39 | SHARED
40 | IMPORTED )
41 | set_target_properties( swscale-4
42 | PROPERTIES IMPORTED_LOCATION
43 | ${distribution_DIR}/libswscale-4.so)
44 | add_library( avformat-57
45 | SHARED
46 | IMPORTED )
47 | set_target_properties( avformat-57
48 | PROPERTIES IMPORTED_LOCATION
49 | ${distribution_DIR}/libavformat-57.so)
50 | set(CMAKE_VERBOSE_MAKEFILE on)
51 | set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -g -Wall -std=c++11 -Wno-deprecated-declarations")
52 | include_directories(src/main/cpp)
53 | include_directories(src/main/jniLibs/include)
54 |
55 | target_link_libraries(native-lib
56 | avutil-55 #工具库
57 | swresample-2 #音频采样数据格式转换
58 | avcodec-57 #编解码
59 | avfilter-6 #滤镜特效处理
60 | swscale-4 #视频像素数据格式转换
61 | avformat-57 #封装格式处理
62 | OpenSLES
63 | ${log-lib}
64 | ${android-lib})
--------------------------------------------------------------------------------
/app/build.gradle:
--------------------------------------------------------------------------------
1 | apply plugin: 'com.android.application'
2 |
3 | apply plugin: 'kotlin-android'
4 |
5 | apply plugin: 'kotlin-android-extensions'
6 |
7 | android {
8 | compileSdkVersion 28
9 | defaultConfig {
10 | applicationId "io.github.iamyours.ffmpegaudioplayer"
11 | minSdkVersion 14
12 | targetSdkVersion 26
13 | versionCode 1
14 | versionName "1.0"
15 | testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
16 | externalNativeBuild {
17 | cmake {
18 | cppFlags "-std=c++11"
19 | }
20 | ndk{
21 | abiFilters "armeabi-v7a"
22 | }
23 | }
24 | }
25 | buildTypes {
26 | release {
27 | minifyEnabled false
28 | proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
29 | }
30 | }
31 | externalNativeBuild {
32 | cmake {
33 | path "CMakeLists.txt"
34 | }
35 | }
36 | }
37 |
38 | dependencies {
39 | implementation fileTree(dir: 'libs', include: ['*.jar'])
40 | implementation "org.jetbrains.kotlin:kotlin-stdlib-jdk7:$kotlin_version"
41 | implementation 'com.android.support:appcompat-v7:28.0.0'
42 | implementation 'com.yanzhenjie:permission:2.0.0'
43 | implementation 'com.android.support.constraint:constraint-layout:1.1.3'
44 | testImplementation 'junit:junit:4.12'
45 | androidTestImplementation 'com.android.support.test:runner:1.0.2'
46 | androidTestImplementation 'com.android.support.test.espresso:espresso-core:3.0.2'
47 | }
48 |
--------------------------------------------------------------------------------
/app/proguard-rules.pro:
--------------------------------------------------------------------------------
1 | # Add project specific ProGuard rules here.
2 | # You can control the set of applied configuration files using the
3 | # proguardFiles setting in build.gradle.
4 | #
5 | # For more details, see
6 | # http://developer.android.com/guide/developing/tools/proguard.html
7 |
8 | # If your project uses WebView with JS, uncomment the following
9 | # and specify the fully qualified class name to the JavaScript interface
10 | # class:
11 | #-keepclassmembers class fqcn.of.javascript.interface.for.webview {
12 | # public *;
13 | #}
14 |
15 | # Uncomment this to preserve the line number information for
16 | # debugging stack traces.
17 | #-keepattributes SourceFile,LineNumberTable
18 |
19 | # If you keep the line number information, uncomment this to
20 | # hide the original source file name.
21 | #-renamesourcefileattribute SourceFile
22 |
--------------------------------------------------------------------------------
/app/src/androidTest/java/io/github/iamyours/ffmpegaudioplayer/ExampleInstrumentedTest.kt:
--------------------------------------------------------------------------------
1 | package io.github.iamyours.ffmpegaudioplayer
2 |
3 | import android.support.test.InstrumentationRegistry
4 | import android.support.test.runner.AndroidJUnit4
5 |
6 | import org.junit.Test
7 | import org.junit.runner.RunWith
8 |
9 | import org.junit.Assert.*
10 |
11 | /**
12 | * Instrumented test, which will execute on an Android device.
13 | *
14 | * See [testing documentation](http://d.android.com/tools/testing).
15 | */
16 | @RunWith(AndroidJUnit4::class)
17 | class ExampleInstrumentedTest {
18 | @Test
19 | fun useAppContext() {
20 | // Context of the app under test.
21 | val appContext = InstrumentationRegistry.getTargetContext()
22 | assertEquals("io.github.iamyours.ffmpegaudioplayer", appContext.packageName)
23 | }
24 | }
25 |
--------------------------------------------------------------------------------
/app/src/main/AndroidManifest.xml:
--------------------------------------------------------------------------------
1 |
2 |
4 |
5 |
6 |
13 |
14 |
15 |
16 |
17 |
18 |
19 |
20 |
23 |
24 |
25 |
26 |
--------------------------------------------------------------------------------
/app/src/main/assets/TimeTravel.mp3:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/iamyours/FFmpegAudioPlayer/72582893a91ac9bd067285c571ceb05b4a966b22/app/src/main/assets/TimeTravel.mp3
--------------------------------------------------------------------------------
/app/src/main/assets/a.mp3:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/iamyours/FFmpegAudioPlayer/72582893a91ac9bd067285c571ceb05b4a966b22/app/src/main/assets/a.mp3
--------------------------------------------------------------------------------
/app/src/main/assets/b.mp3:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/iamyours/FFmpegAudioPlayer/72582893a91ac9bd067285c571ceb05b4a966b22/app/src/main/assets/b.mp3
--------------------------------------------------------------------------------
/app/src/main/assets/c.mp3:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/iamyours/FFmpegAudioPlayer/72582893a91ac9bd067285c571ceb05b4a966b22/app/src/main/assets/c.mp3
--------------------------------------------------------------------------------
/app/src/main/assets/d.mp3:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/iamyours/FFmpegAudioPlayer/72582893a91ac9bd067285c571ceb05b4a966b22/app/src/main/assets/d.mp3
--------------------------------------------------------------------------------
/app/src/main/assets/mix.pcm:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/iamyours/FFmpegAudioPlayer/72582893a91ac9bd067285c571ceb05b4a966b22/app/src/main/assets/mix.pcm
--------------------------------------------------------------------------------
/app/src/main/assets/test1.mp3:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/iamyours/FFmpegAudioPlayer/72582893a91ac9bd067285c571ceb05b4a966b22/app/src/main/assets/test1.mp3
--------------------------------------------------------------------------------
/app/src/main/cpp/AudioPlayer.h:
--------------------------------------------------------------------------------
1 | //
2 | // Created by yanxx on 2019/1/21.
3 | //
4 |
5 | #ifndef FFMPEGAUDIOPLAYER_AUDIOPLAYER_H
6 | #define FFMPEGAUDIOPLAYER_AUDIOPLAYER_H
7 |
8 | #include
9 | #include
10 | #include
11 | #include
12 |
13 | extern "C" {
14 | #include
15 | #include
16 | #include
17 | #include
18 | #include
19 | #include
20 | #include
21 | #include
22 | #define LOGI(FORMAT, ...) __android_log_print(ANDROID_LOG_INFO,"FFmpegAudioPlayer",FORMAT,##__VA_ARGS__);
23 | #define LOGE(FORMAT, ...) __android_log_print(ANDROID_LOG_ERROR,"FFmpegAudioPlayer",FORMAT,##__VA_ARGS__);
24 |
25 | class AudioPlayer {
26 | public:
27 | AudioPlayer(char **pathArr, int len);
28 |
29 | jobject jobj;
30 | JNIEnv *env;
31 | //解码
32 | int fileCount; //输入音频文件数量
33 | AVFormatContext **fmt_ctx_arr; //FFmpeg上下文数组
34 | AVCodecContext **codec_ctx_arr; //解码器上下文数组
35 | int *stream_index_arr; //音频流索引数组
36 |
37 | //过滤
38 | AVFilterGraph *graph;
39 | AVFilterContext **srcs; //输入filter
40 | AVFilterContext *sink; //输出filter
41 | AVFilterContext **volumeCtxs;
42 | char **volumes; //各个音频的音量
43 | char *tempo; //播放速度0.5~2.0
44 | int change = 0;
45 |
46 | //AVFrame队列
47 | std::vector queue; //队列,用于保存解码过滤后的AVFrame
48 |
49 | //输入输出格式
50 | SwrContext *swr_ctx; //重采样,用于将AVFrame转成pcm数据
51 | uint64_t in_ch_layout;
52 | int in_sample_rate; //采样率
53 | int in_ch_layout_nb; //输入声道数,配合swr_ctx使用
54 | enum AVSampleFormat in_sample_fmt; //输入音频采样格式
55 |
56 | uint64_t out_ch_layout;
57 | int out_sample_rate; //采样率
58 | int out_ch_layout_nb; //输出声道数,配合swr_ctx使用
59 | int max_audio_frame_size; //最大缓冲数据大小
60 | enum AVSampleFormat out_sample_fmt; //输出音频采样格式
61 |
62 | // 进度相关
63 | AVRational time_base; //刻度,用于计算进度
64 | double total_time; //总时长(秒)
65 | double current_time = 0; //当前进度
66 | int isPlay = 0; //播放状态1:播放中
67 |
68 | //多线程
69 | pthread_t decodeId; //解码线程id
70 | pthread_t playId; //播放线程id
71 | pthread_mutex_t mutex; //同步锁
72 | pthread_cond_t not_full; //不为满条件,生产AVFrame时使用
73 | pthread_cond_t not_empty; //不为空条件,消费AVFrame时使用
74 |
75 | //Open SL ES
76 | SLObjectItf engineObject; //引擎对象
77 | SLEngineItf engineItf; //引擎接口
78 | SLObjectItf mixObject; //输出混音对象
79 | SLObjectItf playerObject; //播放器对象
80 | SLPlayItf playItf; //播放器接口
81 | SLAndroidSimpleBufferQueueItf bufferQueueItf; //缓冲接口
82 |
83 | void play();
84 |
85 | void pause();
86 |
87 | void setPlaying();
88 |
89 | void decodeAudio(); //解码音频
90 |
91 | int createPlayer(); //创建播放器
92 | int initCodecs(char **pathArr); //初始化解码器
93 | int initSwrContext(); //初始化SwrContext
94 | int initFilters(); //初始化过滤器
95 |
96 |
97 | AVFrame *get();
98 |
99 | int put(AVFrame *frame);
100 |
101 | void seek(double secs);
102 |
103 | void release();
104 |
105 | void updateFilters();
106 | };
107 |
108 | }
109 |
110 | #endif //FFMPEGAUDIOPLAYER_AUDIOPLAYER_H
111 |
--------------------------------------------------------------------------------
/app/src/main/cpp/player-test.cpp:
--------------------------------------------------------------------------------
1 | //
2 | // Created by yanxx on 2019/1/23.
3 | //
4 | #include "AudioPlayer.h"
5 |
6 | static AudioPlayer *player;
7 |
8 | extern "C" JNIEXPORT void
9 | JNICALL
10 | Java_io_github_iamyours_ffmpegaudioplayer_FFmpegAudioPlayer_init(
11 | JNIEnv *env,
12 | jobject thiz, jobjectArray _srcs) {
13 | //将java传入的字符串数组转为c字符串数组
14 | jsize len = env->GetArrayLength(_srcs);
15 | char **pathArr = (char **) malloc(len * sizeof(char *));
16 | int i = 0;
17 | for (i = 0; i < len; i++) {
18 | jstring str = static_cast(env->GetObjectArrayElement(_srcs, i));
19 | pathArr[i] = const_cast(env->GetStringUTFChars(str, 0));
20 | }
21 | player = new AudioPlayer(pathArr, len);
22 | player->env = env;
23 | player->jobj = thiz;
24 | }
25 |
26 | extern "C" JNIEXPORT void
27 | JNICALL
28 | Java_io_github_iamyours_ffmpegaudioplayer_FFmpegAudioPlayer_callback(
29 | JNIEnv *env,
30 | jobject thiz, jobject callback) {
31 | jclass callbackClass = env->GetObjectClass(callbackClass);
32 | jmethodID method = env->GetMethodID(callbackClass, "test", "()V");
33 | env->CallVoidMethod(callback, method);
34 | }
35 |
36 | extern "C" JNIEXPORT void
37 | JNICALL
38 | Java_io_github_iamyours_ffmpegaudioplayer_FFmpegAudioPlayer_changeVolumes(
39 | JNIEnv *env,
40 | jobject /* this */, jobjectArray _volumes) {
41 | //将java传入的字符串数组转为c字符串数组
42 | jsize len = env->GetArrayLength(_volumes);
43 | int i = 0;
44 | for (i = 0; i < len; i++) {
45 | jstring str = static_cast(env->GetObjectArrayElement(_volumes, i));
46 | char *volume = const_cast(env->GetStringUTFChars(str, 0));
47 | player->volumes[i] = volume;
48 | }
49 | player->change = 1;
50 | }
51 |
52 | extern "C" JNIEXPORT void
53 | JNICALL
54 | Java_io_github_iamyours_ffmpegaudioplayer_FFmpegAudioPlayer_changeTempo(
55 | JNIEnv *env,
56 | jobject /* this */, jstring _tempo) {
57 | char *tempo = const_cast(env->GetStringUTFChars(_tempo, 0));
58 | player->tempo = tempo;
59 | player->change = 1;
60 | }
61 | extern "C" JNIEXPORT void
62 | JNICALL
63 | Java_io_github_iamyours_ffmpegaudioplayer_FFmpegAudioPlayer_play(
64 | JNIEnv *env,
65 | jobject /* this */) {
66 | player->play();
67 | }
68 |
69 | extern "C" JNIEXPORT void
70 | JNICALL
71 | Java_io_github_iamyours_ffmpegaudioplayer_FFmpegAudioPlayer_pause(
72 | JNIEnv *env,
73 | jobject /* this */) {
74 | player->pause();
75 | }
76 |
77 | extern "C" JNIEXPORT void
78 | JNICALL
79 | Java_io_github_iamyours_ffmpegaudioplayer_FFmpegAudioPlayer_release(
80 | JNIEnv *env,
81 | jobject /* this */) {
82 | player->release();
83 | }
84 | extern "C" JNIEXPORT void
85 | JNICALL
86 | Java_io_github_iamyours_ffmpegaudioplayer_FFmpegAudioPlayer_seek(
87 | JNIEnv *env,
88 | jobject /* this */, jdouble secs) {
89 | player->seek(secs);
90 | }
91 |
92 | extern "C" JNIEXPORT jdouble
93 | JNICALL
94 | Java_io_github_iamyours_ffmpegaudioplayer_FFmpegAudioPlayer_duration(
95 | JNIEnv *env,
96 | jobject /* this */) {
97 | return player->total_time;
98 | }
99 |
100 | extern "C" JNIEXPORT jdouble
101 | JNICALL
102 | Java_io_github_iamyours_ffmpegaudioplayer_FFmpegAudioPlayer_position(
103 | JNIEnv *env,
104 | jobject /* this */) {
105 | return player->current_time;
106 | }
107 |
--------------------------------------------------------------------------------
/app/src/main/java/io/github/iamyours/ffmpegaudioplayer/ByteUtil.java:
--------------------------------------------------------------------------------
1 | package io.github.iamyours.ffmpegaudioplayer;
2 |
3 | import android.util.Log;
4 |
5 | import java.util.ArrayList;
6 | import java.util.Arrays;
7 | import java.util.List;
8 |
9 | public class ByteUtil {
10 | public static byte combine(ArrayList bytes, int index) {
11 | if (bytes == null) return 0;
12 | int b1 = bytes.get(index);
13 | int b2 = bytes.get(index + 1);
14 | if (b1 < 0) b1 += 256;
15 | if (b2 < 0) b2 += 256;
16 | return (byte) (b1 + b2);
17 | }
18 |
19 | public static short toShort(byte[] bytes, int index) {
20 | return (short) ((bytes[index + 1] << 8) | (bytes[index] & 0xff));
21 | }
22 |
23 | public static int toInt(byte[] bytes, int index) {
24 | return ((bytes[index + 1] << 8) | (bytes[index] & 0xff));
25 | }
26 |
27 | public static byte toByte(List list, int index) {
28 | return (byte) ((toInt(list, index) + toInt(list, index + 2)) / 2);
29 | }
30 |
31 | public static int toInt(List list, int index) {
32 | return ((list.get(index + 1) & 0xff) << 8) | (list.get(index) & 0xff);
33 | }
34 |
35 | public static double[] toDoubleArray(List list, int size) {
36 | double[] result = new double[size];
37 | int step = list.size() / (size * 2);
38 | double maxDb = 20 * Math.log10(Math.pow(2, 16) - 1);
39 | int index = 0;
40 | for (int i = 0; i < size; i++) {
41 | int count = 0;
42 | double total = 0;
43 | while (count++ < step) {
44 | int pcm = toInt(list, index);
45 | total += pcm;
46 | index += 2;
47 | }
48 | double avg = total / step;
49 | double db = Math.log10(avg) * 20;
50 | result[i] = db / maxDb;
51 | }
52 | Log.i("Main", Arrays.toString(result));
53 | return result;
54 | }
55 |
56 | public static short[] byteArray2ShortArray(byte[] data) {
57 | int items = data.length / 2;
58 | short[] retVal = new short[items];
59 | for (int i = 0; i < retVal.length; i++)
60 | retVal[i] = (short) ((data[i * 2] & 0xff) | (data[i * 2 + 1] & 0xff) << 8);
61 |
62 | return retVal;
63 | }
64 |
65 | public static short[] byteArray2ShortArray(List data) {
66 | int items = data.size() / 2;
67 | short[] retVal = new short[items];
68 | for (int i = 0; i < retVal.length; i++)
69 | retVal[i] = (short) ((data.get(i * 2) & 0xff) | (data.get(i * 2 + 1) & 0xff) << 8);
70 |
71 | return retVal;
72 | }
73 | }
74 |
--------------------------------------------------------------------------------
/app/src/main/java/io/github/iamyours/ffmpegaudioplayer/Callback.java:
--------------------------------------------------------------------------------
1 | package io.github.iamyours.ffmpegaudioplayer;
2 |
3 | public interface Callback {
4 | void test();
5 | }
6 |
--------------------------------------------------------------------------------
/app/src/main/java/io/github/iamyours/ffmpegaudioplayer/FFmpegAudioPlayer.kt:
--------------------------------------------------------------------------------
1 | package io.github.iamyours.ffmpegaudioplayer
2 |
3 | class FFmpegAudioPlayer {
4 | /**
5 | * 初始化
6 | */
7 | external fun init(paths: Array)
8 |
9 | /**
10 | * 播放
11 | */
12 | external fun play()
13 |
14 | /**
15 | * 暂停
16 | */
17 | external fun pause()
18 |
19 | /**
20 | * 释放资源
21 | */
22 | external fun release()
23 |
24 | /**
25 | * 修改每个音量
26 | */
27 | external fun changeVolumes(volumes: Array)
28 |
29 | /**
30 | * 变速
31 | */
32 | external fun changeTempo(tempo: String)
33 |
34 | /**
35 | * 总时长 秒
36 | */
37 | external fun duration(): Double
38 |
39 | /**
40 | * 当前进度 秒
41 | */
42 | external fun position(): Double
43 |
44 | /**
45 | * 进度跳转
46 | */
47 | external fun seek(sec: Double)
48 |
49 | external fun callback(callback: Callback)
50 |
51 | }
--------------------------------------------------------------------------------
/app/src/main/java/io/github/iamyours/ffmpegaudioplayer/FFmpegAudioRecorder.kt:
--------------------------------------------------------------------------------
1 | package io.github.iamyours.ffmpegaudioplayer
2 |
3 | /**
4 | * 基于OpenSL ES和FFmpeg的录音器,支持实时录音转mp3/aac等
5 | */
6 | class FFmpegAudioRecorder {
7 |
8 | }
--------------------------------------------------------------------------------
/app/src/main/java/io/github/iamyours/ffmpegaudioplayer/FFmpegPlayerActivity.kt:
--------------------------------------------------------------------------------
1 | package io.github.iamyours.ffmpegaudioplayer
2 |
3 | import android.os.Bundle
4 | import android.os.Environment
5 | import android.os.Handler
6 | import android.os.Message
7 | import android.support.v7.app.AppCompatActivity
8 | import android.widget.SeekBar
9 | import android.widget.TextView
10 | import kotlinx.android.synthetic.main.activity_ffmpeg_player.*
11 |
12 | class FFmpegPlayerActivity : AppCompatActivity() {
13 | var volumes = arrayOf("1.0", "1.0", "1.0", "1.0")
14 | var tempo = "1.0"
15 | var total = 0
16 | lateinit var player: FFmpegAudioPlayer
17 | override fun onCreate(savedInstanceState: Bundle?) {
18 | super.onCreate(savedInstanceState)
19 | setContentView(R.layout.activity_ffmpeg_player)
20 |
21 | player = FFmpegAudioPlayer()
22 | val path = "${Environment.getExternalStorageDirectory()}/test"
23 | val srcs = arrayOf(
24 | "$path/a.mp3",
25 | "$path/b.mp3",
26 | "$path/c.mp3",
27 | "$path/d.mp3"
28 | )
29 | player.init(srcs)
30 | initListeners()
31 |
32 | object : Handler() {
33 | override fun handleMessage(msg: Message?) {
34 | val text = "${player.position()}/${player.duration()}"
35 | tv_time.text = text
36 | val progress = player.position() * 10000 / player.duration()
37 | sb_progress.progress = progress.toInt()
38 | sendEmptyMessageDelayed(1, 500)
39 | }
40 | }.sendEmptyMessageDelayed(1, 500)
41 | }
42 |
43 | lateinit var tvs: Array
44 |
45 |
46 | private fun initListeners() {
47 | sb_progress.setOnSeekBarChangeListener(object : SeekBar.OnSeekBarChangeListener {
48 | override fun onProgressChanged(seekBar: SeekBar, progress: Int, fromUser: Boolean) {
49 |
50 | }
51 |
52 | override fun onStartTrackingTouch(seekBar: SeekBar?) {
53 | }
54 |
55 | override fun onStopTrackingTouch(seekBar: SeekBar) {
56 | val duration = player.duration()
57 | val current = duration * seekBar.progress / seekBar.max
58 | player.seek(current)
59 | }
60 | })
61 | tvs = arrayOf(tv_value1, tv_value2, tv_value3, tv_value4)
62 | val seekBars = arrayOf(sb1, sb2, sb3, sb4)
63 | seekBars.forEachIndexed { index, seekBar ->
64 | seekBar.setOnSeekBarChangeListener(object : SeekBar.OnSeekBarChangeListener {
65 | override fun onProgressChanged(seekBar: SeekBar, progress: Int, fromUser: Boolean) {
66 |
67 | }
68 |
69 | override fun onStartTrackingTouch(seekBar: SeekBar?) {
70 | }
71 |
72 | override fun onStopTrackingTouch(seekBar: SeekBar) {
73 | val progress = seekBar.progress / 100.0f
74 | volumes[index] = String.format("%.2f", progress)
75 | changeVolumes()
76 | }
77 |
78 | })
79 | }
80 | sb5.setOnSeekBarChangeListener(object : SeekBar.OnSeekBarChangeListener {
81 | override fun onProgressChanged(seekBar: SeekBar?, progress: Int, fromUser: Boolean) {
82 | }
83 |
84 | override fun onStartTrackingTouch(seekBar: SeekBar?) {
85 | }
86 |
87 | override fun onStopTrackingTouch(seekBar: SeekBar) {
88 | val progress = seekBar.progress / 100.0f + 0.5
89 | tempo = String.format("%.2f", progress)
90 | tv_value5.text = "${tempo.toFloat() * 100}%"
91 | player.changeTempo(tempo)
92 | }
93 | })
94 | btn_play.setOnClickListener {
95 | player.play()
96 | }
97 | btn_pause.setOnClickListener {
98 | player.pause()
99 | }
100 | }
101 |
102 | private fun changeVolumes() {
103 | tvs.forEachIndexed { index, textView ->
104 | textView.text = "${volumes[index].toFloat() * 100}%"
105 | }
106 | player.changeVolumes(volumes)
107 |
108 | }
109 |
110 | override fun onDestroy() {
111 | super.onDestroy()
112 | player.release()
113 | }
114 | }
--------------------------------------------------------------------------------
/app/src/main/java/io/github/iamyours/ffmpegaudioplayer/FileUtil.java:
--------------------------------------------------------------------------------
1 | package io.github.iamyours.ffmpegaudioplayer;
2 |
3 | import android.content.Context;
4 |
5 | import java.io.FileOutputStream;
6 | import java.io.InputStream;
7 | import java.io.OutputStream;
8 |
9 | public class FileUtil {
10 | public static void copyFromAssets(Context context, String src, String out) {
11 | InputStream myInput;
12 | OutputStream myOutput = null;
13 | try {
14 | myOutput = new FileOutputStream(out);
15 | myInput = context.getAssets().open(src);
16 | byte[] buffer = new byte[1024];
17 | int length = myInput.read(buffer);
18 | while (length > 0) {
19 | myOutput.write(buffer, 0, length);
20 | length = myInput.read(buffer);
21 | }
22 |
23 | myOutput.flush();
24 | myInput.close();
25 | myOutput.close();
26 | } catch (Exception e) {
27 | e.printStackTrace();
28 | }
29 | }
30 | }
31 |
--------------------------------------------------------------------------------
/app/src/main/java/io/github/iamyours/ffmpegaudioplayer/MainActivity.kt:
--------------------------------------------------------------------------------
1 | package io.github.iamyours.ffmpegaudioplayer
2 |
3 | import android.content.Intent
4 | import android.os.Bundle
5 | import android.os.Environment
6 | import android.support.v7.app.AppCompatActivity
7 | import android.util.Log
8 | import android.view.View
9 | import com.yanzhenjie.permission.AndPermission
10 | import com.yanzhenjie.permission.runtime.Permission
11 | import java.io.File
12 |
13 | class MainActivity : AppCompatActivity() {
14 | lateinit var player: FFmpegAudioPlayer
15 | override fun onCreate(savedInstanceState: Bundle?) {
16 | super.onCreate(savedInstanceState)
17 | setContentView(R.layout.activity_main)
18 | player = FFmpegAudioPlayer()
19 | AndPermission.with(this)
20 | .runtime()
21 | .permission(Permission.Group.STORAGE)
22 | .onGranted {
23 | copyFiles()
24 | }.start()
25 | }
26 |
27 | private fun copyFiles() {
28 | val srcs = arrayOf("a.mp3", "b.mp3", "c.mp3", "d.mp3", "test1.mp3", "TimeTravel.mp3")
29 | val outDir = "${Environment.getExternalStorageDirectory()}/test/"
30 | val file = File(outDir)
31 | if (!file.exists()) file.mkdirs()
32 | srcs.forEach {
33 | val out = "$outDir$it"
34 | if (!File(out).exists()) {
35 | FileUtil.copyFromAssets(this, it, out)
36 | }
37 | }
38 | }
39 |
40 | fun decodeAudio(v: View) {
41 | val src = "${Environment.getExternalStorageDirectory()}/test/test1.mp3"
42 | val out = "${Environment.getExternalStorageDirectory()}/test/out2.pcm"
43 | decodeAudio(src, out)
44 | }
45 |
46 | fun mixAudio(v: View) {
47 | val path = "${Environment.getExternalStorageDirectory()}/test"
48 | val srcs = arrayOf(
49 | "$path/a.mp3",
50 | "$path/b.mp3",
51 | "$path/c.mp3",
52 | "$path/d.mp3"
53 | )
54 |
55 | mixAudio(srcs, "$path/mix.pcm")
56 | }
57 |
58 | fun encodeAudio(v: View) {
59 | val src = "${Environment.getExternalStorageDirectory()}/test/mix.pcm"
60 | val out = "${Environment.getExternalStorageDirectory()}/test/mix.mp3"
61 | encodeAudio(src, out)
62 | }
63 |
64 | fun toPlay(v: View) {
65 | val intent = Intent(this, FFmpegPlayerActivity::class.java)
66 | startActivity(intent)
67 | }
68 |
69 |
70 | fun openSLESPlay(v: View) {
71 | val path = "${Environment.getExternalStorageDirectory()}/test"
72 | val src = "$path/TimeTravel.mp3"
73 | val exist = File(src).exists()
74 | Log.e("Main", "exist:$exist")
75 | openslesTest(src)
76 | }
77 |
78 | fun playMultiAudio(v: View) {
79 | val path = "${Environment.getExternalStorageDirectory()}/test"
80 | val srcs = arrayOf(
81 | "$path/a.mp3",
82 | "$path/b.mp3",
83 | "$path/c.mp3",
84 | "$path/d.mp3"
85 | )
86 |
87 | player.init(srcs)
88 | player.play()
89 | }
90 |
91 | fun showWave(v: View) {
92 | startActivity(Intent(this, WavePlayerActivity::class.java))
93 | }
94 |
95 | external fun mixAudio(srcs: Array, out: String)
96 | external fun decodeAudio(src: String, out: String)
97 | external fun openslesTest(src: String)
98 | external fun encodeAudio(str: String, out: String)
99 |
100 | companion object {
101 | init {
102 | System.loadLibrary("avutil-55")
103 | System.loadLibrary("swresample-2")
104 | System.loadLibrary("avcodec-57")
105 | System.loadLibrary("avfilter-6")
106 | System.loadLibrary("swscale-4")
107 | System.loadLibrary("avformat-57")
108 | System.loadLibrary("native-lib")
109 | }
110 | }
111 | }
112 |
--------------------------------------------------------------------------------
/app/src/main/java/io/github/iamyours/ffmpegaudioplayer/WaveDataCallback.java:
--------------------------------------------------------------------------------
1 | package io.github.iamyours.ffmpegaudioplayer;
2 |
3 | public interface WaveDataCallback {
4 | void onDataCapture(byte[] data);
5 | }
6 |
--------------------------------------------------------------------------------
/app/src/main/java/io/github/iamyours/ffmpegaudioplayer/WavePlayerActivity.kt:
--------------------------------------------------------------------------------
1 | package io.github.iamyours.ffmpegaudioplayer
2 |
3 | import android.os.Bundle
4 | import android.os.Environment
5 | import android.support.v7.app.AppCompatActivity
6 | import kotlinx.android.synthetic.main.activity_wave_player.*
7 |
8 |
9 | class WavePlayerActivity : AppCompatActivity() {
10 | override fun onCreate(savedInstanceState: Bundle?) {
11 | super.onCreate(savedInstanceState)
12 | setContentView(R.layout.activity_wave_player)
13 | val path = "${Environment.getExternalStorageDirectory()}/test"
14 | val src = "$path/TimeTravel.mp3"
15 | init(src, WaveDataCallback {
16 | updateWave(it)
17 | })
18 | }
19 |
20 | private var lastTime = System.currentTimeMillis()
21 | private val list = ArrayList()
22 | private fun updateWave(it: ByteArray) {
23 | val t = System.currentTimeMillis()
24 | list.addAll(it.toMutableList())
25 | if (t - lastTime > 100) {
26 | waveView.post {
27 | waveView.update(ByteUtil.byteArray2ShortArray(list))
28 | list.clear()
29 | }
30 | lastTime = t
31 | }
32 |
33 | }
34 |
35 |
36 | external fun init(src: String, callback: WaveDataCallback)
37 | }
--------------------------------------------------------------------------------
/app/src/main/java/io/github/iamyours/ffmpegaudioplayer/view/AudioData.java:
--------------------------------------------------------------------------------
1 | package io.github.iamyours.ffmpegaudioplayer.view;
2 |
3 | public class AudioData
4 | {
5 | public AudioData(byte[] bytes)
6 | {
7 | this.bytes = bytes;
8 | }
9 |
10 | public byte[] bytes;
11 | }
--------------------------------------------------------------------------------
/app/src/main/java/io/github/iamyours/ffmpegaudioplayer/view/LineRenderer.java:
--------------------------------------------------------------------------------
1 | package io.github.iamyours.ffmpegaudioplayer.view;
2 |
3 | import android.graphics.Canvas;
4 | import android.graphics.Color;
5 | import android.graphics.Paint;
6 | import android.graphics.Rect;
7 |
8 |
9 | public class LineRenderer extends Renderer
10 | {
11 | private Paint mPaint;
12 | private Paint mFlashPaint;
13 | private boolean mCycleColor;
14 | private float amplitude = 0;
15 |
16 |
17 | /**
18 | * Renders the audio data onto a line. The line flashes on prominent beats
19 | * @param paint - Paint to draw lines with
20 | * @param paint - Paint to draw flash with
21 | */
22 | public LineRenderer(Paint paint, Paint flashPaint)
23 | {
24 | this(paint, flashPaint, false);
25 | }
26 |
27 | /**
28 | * Renders the audio data onto a line. The line flashes on prominent beats
29 | * @param paint - Paint to draw lines with
30 | * @param paint - Paint to draw flash with
31 | * @param cycleColor - If true the color will change on each frame
32 | */
33 | public LineRenderer(Paint paint,
34 | Paint flashPaint,
35 | boolean cycleColor)
36 | {
37 | super();
38 | mPaint = paint;
39 | mFlashPaint = flashPaint;
40 | mCycleColor = cycleColor;
41 | }
42 |
43 | @Override
44 | public void onRender(Canvas canvas, AudioData data, Rect rect)
45 | {
46 | if(mCycleColor)
47 | {
48 | cycleColor();
49 | }
50 |
51 | // Calculate points for line
52 | for (int i = 0; i < data.bytes.length - 1; i++) {
53 | mPoints[i * 4] = rect.width() * i / (data.bytes.length - 1);
54 | mPoints[i * 4 + 1] = rect.height() / 2
55 | + ((byte) (data.bytes[i] + 128)) * (rect.height() / 3) / 128;
56 | mPoints[i * 4 + 2] = rect.width() * (i + 1) / (data.bytes.length - 1);
57 | mPoints[i * 4 + 3] = rect.height() / 2
58 | + ((byte) (data.bytes[i + 1] + 128)) * (rect.height() / 3) / 128;
59 | }
60 |
61 | // Calc amplitude for this waveform
62 | float accumulator = 0;
63 | for (int i = 0; i < data.bytes.length - 1; i++) {
64 | accumulator += Math.abs(data.bytes[i]);
65 | }
66 |
67 | float amp = accumulator/(128 * data.bytes.length);
68 | if(amp > amplitude)
69 | {
70 | // Amplitude is bigger than normal, make a prominent line
71 | amplitude = amp;
72 | canvas.drawLines(mPoints, mFlashPaint);
73 | }
74 | else
75 | {
76 | // Amplitude is nothing special, reduce the amplitude
77 | amplitude *= 0.99;
78 | canvas.drawLines(mPoints, mPaint);
79 | }
80 | }
81 |
82 | private float colorCounter = 0;
83 | private void cycleColor()
84 | {
85 | int r = (int)Math.floor(128*(Math.sin(colorCounter) + 3));
86 | int g = (int)Math.floor(128*(Math.sin(colorCounter + 1) + 1));
87 | int b = (int)Math.floor(128*(Math.sin(colorCounter + 7) + 1));
88 | mPaint.setColor(Color.argb(128, r, g, b));
89 | colorCounter += 0.03;
90 | }
91 | }
--------------------------------------------------------------------------------
/app/src/main/java/io/github/iamyours/ffmpegaudioplayer/view/Renderer.java:
--------------------------------------------------------------------------------
1 | package io.github.iamyours.ffmpegaudioplayer.view;
2 |
3 | import android.graphics.Canvas;
4 | import android.graphics.Rect;
5 |
6 | abstract public class Renderer
7 | {
8 | // Have these as members, so we don't have to re-create them each time
9 | protected float[] mPoints;
10 | protected float[] mFFTPoints;
11 | public Renderer()
12 | {
13 | }
14 |
15 | // As the display of raw/FFT audio will usually look different, subclasses
16 | // will typically only implement one of the below methods
17 | /**
18 | * Implement this method to render the audio data onto the canvas
19 | * @param canvas - Canvas to draw on
20 | * @param data - Data to render
21 | * @param rect - Rect to render into
22 | */
23 | abstract public void onRender(Canvas canvas, AudioData data, Rect rect);
24 |
25 | /**
26 | * Implement this method to render the FFT audio data onto the canvas
27 | * @param canvas - Canvas to draw on
28 | * @param data - Data to render
29 | * @param rect - Rect to render into
30 | */
31 |
32 |
33 | // These methods should actually be called for rendering
34 | /**
35 | * Render the audio data onto the canvas
36 | * @param canvas - Canvas to draw on
37 | * @param data - Data to render
38 | * @param rect - Rect to render into
39 | */
40 | final public void render(Canvas canvas, AudioData data, Rect rect)
41 | {
42 | if (mPoints == null || mPoints.length < data.bytes.length * 4) {
43 | mPoints = new float[data.bytes.length * 4];
44 | }
45 |
46 | onRender(canvas, data, rect);
47 | }
48 |
49 | }
--------------------------------------------------------------------------------
/app/src/main/java/io/github/iamyours/ffmpegaudioplayer/view/VisualizerView.java:
--------------------------------------------------------------------------------
1 | package io.github.iamyours.ffmpegaudioplayer.view;
2 |
3 | import java.util.HashSet;
4 | import java.util.Set;
5 |
6 | import android.content.Context;
7 | import android.graphics.Bitmap;
8 | import android.graphics.Bitmap.Config;
9 | import android.graphics.Canvas;
10 | import android.graphics.Color;
11 | import android.graphics.Matrix;
12 | import android.graphics.Paint;
13 | import android.graphics.PorterDuff.Mode;
14 | import android.graphics.PorterDuffXfermode;
15 | import android.graphics.Rect;
16 | import android.media.MediaPlayer;
17 | import android.media.audiofx.Visualizer;
18 | import android.util.AttributeSet;
19 | import android.view.View;
20 |
21 |
22 | /**
23 | * A class that draws visualizations of data received from a
24 | * {@link Visualizer.OnDataCaptureListener#onWaveFormDataCapture } and
25 | * {@link Visualizer.OnDataCaptureListener#onFftDataCapture }
26 | */
27 | public class VisualizerView extends View {
28 | private static final String TAG = "VisualizerView";
29 |
30 | private byte[] mBytes;
31 | private byte[] mFFTBytes;
32 | private Rect mRect = new Rect();
33 |
34 | private Set mRenderers;
35 |
36 | private Paint mFlashPaint = new Paint();
37 | private Paint mFadePaint = new Paint();
38 |
39 | public VisualizerView(Context context, AttributeSet attrs, int defStyle)
40 | {
41 | super(context, attrs);
42 | init();
43 | }
44 |
45 | public VisualizerView(Context context, AttributeSet attrs)
46 | {
47 | this(context, attrs, 0);
48 | }
49 |
50 | public VisualizerView(Context context)
51 | {
52 | this(context, null, 0);
53 | }
54 |
55 | private void init() {
56 | mBytes = null;
57 | mFFTBytes = null;
58 |
59 | mFlashPaint.setColor(Color.argb(122, 255, 255, 255));
60 | mFadePaint.setColor(Color.argb(238, 255, 255, 255)); // Adjust alpha to change how quickly the image fades
61 | mFadePaint.setXfermode(new PorterDuffXfermode(Mode.MULTIPLY));
62 |
63 | mRenderers = new HashSet();
64 | }
65 |
66 | public void addRenderer(Renderer renderer)
67 | {
68 | if(renderer != null)
69 | {
70 | mRenderers.add(renderer);
71 | }
72 | }
73 |
74 | public void clearRenderers()
75 | {
76 | mRenderers.clear();
77 | }
78 |
79 | /**
80 | * Call to release the resources used by VisualizerView. Like with the
81 | * MediaPlayer it is good practice to call this method
82 | */
83 |
84 | /**
85 | * Pass data to the visualizer. Typically this will be obtained from the
86 | * Android Visualizer.OnDataCaptureListener call back. See
87 | * {@link Visualizer.OnDataCaptureListener#onWaveFormDataCapture }
88 | * @param bytes
89 | */
90 | public void updateVisualizer(byte[] bytes) {
91 | mBytes = bytes;
92 | invalidate();
93 | }
94 |
95 | /**
96 | * Pass FFT data to the visualizer. Typically this will be obtained from the
97 | * Android Visualizer.OnDataCaptureListener call back. See
98 | * {@link Visualizer.OnDataCaptureListener#onFftDataCapture }
99 | * @param bytes
100 | */
101 | public void updateVisualizerFFT(byte[] bytes) {
102 | mFFTBytes = bytes;
103 | invalidate();
104 | }
105 |
106 | boolean mFlash = false;
107 |
108 | /**
109 | * Call this to make the visualizer flash. Useful for flashing at the start
110 | * of a song/loop etc...
111 | */
112 | public void flash() {
113 | mFlash = true;
114 | invalidate();
115 | }
116 |
117 | Bitmap mCanvasBitmap;
118 | Canvas mCanvas;
119 |
120 |
121 | @Override
122 | protected void onDraw(Canvas canvas) {
123 | super.onDraw(canvas);
124 |
125 | // Create canvas once we're ready to draw
126 | mRect.set(0, 0, getWidth(), getHeight());
127 |
128 | if(mCanvasBitmap == null)
129 | {
130 | mCanvasBitmap = Bitmap.createBitmap(canvas.getWidth(), canvas.getHeight(), Config.ARGB_8888);
131 | }
132 | if(mCanvas == null)
133 | {
134 | mCanvas = new Canvas(mCanvasBitmap);
135 | }
136 |
137 | if (mBytes != null) {
138 | // Render all audio renderers
139 | AudioData audioData = new AudioData(mBytes);
140 | for(Renderer r : mRenderers)
141 | {
142 | r.render(mCanvas, audioData, mRect);
143 | }
144 | }
145 |
146 | // Fade out old contents
147 | mCanvas.drawPaint(mFadePaint);
148 |
149 | if(mFlash)
150 | {
151 | mFlash = false;
152 | mCanvas.drawPaint(mFlashPaint);
153 | }
154 |
155 | canvas.drawBitmap(mCanvasBitmap, new Matrix(), null);
156 | }
157 | }
--------------------------------------------------------------------------------
/app/src/main/java/io/github/iamyours/ffmpegaudioplayer/view/WaveView.java:
--------------------------------------------------------------------------------
1 | package io.github.iamyours.ffmpegaudioplayer.view;
2 |
3 | import android.content.Context;
4 | import android.graphics.Canvas;
5 | import android.graphics.Color;
6 | import android.graphics.Paint;
7 | import android.graphics.Path;
8 | import android.support.annotation.Nullable;
9 | import android.util.AttributeSet;
10 | import android.util.Log;
11 | import android.view.View;
12 |
13 | public class WaveView extends View {
14 | private short[] shortData;
15 | private Paint paint;
16 | private Path path;
17 |
18 | public WaveView(Context context, @Nullable AttributeSet attrs) {
19 | super(context, attrs);
20 | paint = new Paint();
21 | paint.setColor(Color.WHITE);
22 | paint.setStyle(Paint.Style.STROKE);
23 | }
24 |
25 | public void update(short[] data) {
26 | shortData = data;
27 | invalidate();
28 | }
29 |
30 | private int index;
31 | private int height2;
32 | private int len;
33 |
34 | @Override
35 | protected void onDraw(Canvas canvas) {
36 | super.onDraw(canvas);
37 | index = 0;
38 | path = new Path();
39 | path.moveTo(0, 0);
40 | height2 = getHeight() / 2;
41 | if (shortData != null) {
42 | len = shortData.length;
43 | for (short s : shortData) {
44 | float y = height2 - s * height2 / 32768f;
45 | float x = (index++) * getWidth() / len;
46 | path.lineTo(x, y);
47 | }
48 | }
49 | canvas.drawPath(path, paint);
50 | }
51 | }
52 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/armeabi-v7a/libavcodec-57.so:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/iamyours/FFmpegAudioPlayer/72582893a91ac9bd067285c571ceb05b4a966b22/app/src/main/jniLibs/armeabi-v7a/libavcodec-57.so
--------------------------------------------------------------------------------
/app/src/main/jniLibs/armeabi-v7a/libavfilter-6.so:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/iamyours/FFmpegAudioPlayer/72582893a91ac9bd067285c571ceb05b4a966b22/app/src/main/jniLibs/armeabi-v7a/libavfilter-6.so
--------------------------------------------------------------------------------
/app/src/main/jniLibs/armeabi-v7a/libavformat-57.so:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/iamyours/FFmpegAudioPlayer/72582893a91ac9bd067285c571ceb05b4a966b22/app/src/main/jniLibs/armeabi-v7a/libavformat-57.so
--------------------------------------------------------------------------------
/app/src/main/jniLibs/armeabi-v7a/libavutil-55.so:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/iamyours/FFmpegAudioPlayer/72582893a91ac9bd067285c571ceb05b4a966b22/app/src/main/jniLibs/armeabi-v7a/libavutil-55.so
--------------------------------------------------------------------------------
/app/src/main/jniLibs/armeabi-v7a/libswresample-2.so:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/iamyours/FFmpegAudioPlayer/72582893a91ac9bd067285c571ceb05b4a966b22/app/src/main/jniLibs/armeabi-v7a/libswresample-2.so
--------------------------------------------------------------------------------
/app/src/main/jniLibs/armeabi-v7a/libswscale-4.so:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/iamyours/FFmpegAudioPlayer/72582893a91ac9bd067285c571ceb05b4a966b22/app/src/main/jniLibs/armeabi-v7a/libswscale-4.so
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavcodec/avdct.h:
--------------------------------------------------------------------------------
1 | /*
2 | * This file is part of FFmpeg.
3 | *
4 | * FFmpeg is free software; you can redistribute it and/or
5 | * modify it under the terms of the GNU Lesser General Public
6 | * License as published by the Free Software Foundation; either
7 | * version 2.1 of the License, or (at your option) any later version.
8 | *
9 | * FFmpeg is distributed in the hope that it will be useful,
10 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 | * Lesser General Public License for more details.
13 | *
14 | * You should have received a copy of the GNU Lesser General Public
15 | * License along with FFmpeg; if not, write to the Free Software
16 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17 | */
18 |
19 | #ifndef AVCODEC_AVDCT_H
20 | #define AVCODEC_AVDCT_H
21 |
22 | #include "libavutil/opt.h"
23 |
24 | /**
25 | * AVDCT context.
26 | * @note function pointers can be NULL if the specific features have been
27 | * disabled at build time.
28 | */
29 | typedef struct AVDCT {
30 | const AVClass *av_class;
31 |
32 | void (*idct)(int16_t *block /* align 16 */);
33 |
34 | /**
35 | * IDCT input permutation.
36 | * Several optimized IDCTs need a permutated input (relative to the
37 | * normal order of the reference IDCT).
38 | * This permutation must be performed before the idct_put/add.
39 | * Note, normally this can be merged with the zigzag/alternate scan
40 | * An example to avoid confusion:
41 | * - (->decode coeffs -> zigzag reorder -> dequant -> reference IDCT -> ...)
42 | * - (x -> reference DCT -> reference IDCT -> x)
43 | * - (x -> reference DCT -> simple_mmx_perm = idct_permutation
44 | * -> simple_idct_mmx -> x)
45 | * - (-> decode coeffs -> zigzag reorder -> simple_mmx_perm -> dequant
46 | * -> simple_idct_mmx -> ...)
47 | */
48 | uint8_t idct_permutation[64];
49 |
50 | void (*fdct)(int16_t *block /* align 16 */);
51 |
52 |
53 | /**
54 | * DCT algorithm.
55 | * must use AVOptions to set this field.
56 | */
57 | int dct_algo;
58 |
59 | /**
60 | * IDCT algorithm.
61 | * must use AVOptions to set this field.
62 | */
63 | int idct_algo;
64 |
65 | void (*get_pixels)(int16_t *block /* align 16 */,
66 | const uint8_t *pixels /* align 8 */,
67 | ptrdiff_t line_size);
68 |
69 | int bits_per_sample;
70 | } AVDCT;
71 |
72 | /**
73 | * Allocates a AVDCT context.
74 | * This needs to be initialized with avcodec_dct_init() after optionally
75 | * configuring it with AVOptions.
76 | *
77 | * To free it use av_free()
78 | */
79 | AVDCT *avcodec_dct_alloc(void);
80 | int avcodec_dct_init(AVDCT *);
81 |
82 | const AVClass *avcodec_dct_get_class(void);
83 |
84 | #endif /* AVCODEC_AVDCT_H */
85 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavcodec/avfft.h:
--------------------------------------------------------------------------------
1 | /*
2 | * This file is part of FFmpeg.
3 | *
4 | * FFmpeg is free software; you can redistribute it and/or
5 | * modify it under the terms of the GNU Lesser General Public
6 | * License as published by the Free Software Foundation; either
7 | * version 2.1 of the License, or (at your option) any later version.
8 | *
9 | * FFmpeg is distributed in the hope that it will be useful,
10 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 | * Lesser General Public License for more details.
13 | *
14 | * You should have received a copy of the GNU Lesser General Public
15 | * License along with FFmpeg; if not, write to the Free Software
16 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17 | */
18 |
19 | #ifndef AVCODEC_AVFFT_H
20 | #define AVCODEC_AVFFT_H
21 |
22 | /**
23 | * @file
24 | * @ingroup lavc_fft
25 | * FFT functions
26 | */
27 |
28 | /**
29 | * @defgroup lavc_fft FFT functions
30 | * @ingroup lavc_misc
31 | *
32 | * @{
33 | */
34 |
35 | typedef float FFTSample;
36 |
37 | typedef struct FFTComplex {
38 | FFTSample re, im;
39 | } FFTComplex;
40 |
41 | typedef struct FFTContext FFTContext;
42 |
43 | /**
44 | * Set up a complex FFT.
45 | * @param nbits log2 of the length of the input array
46 | * @param inverse if 0 perform the forward transform, if 1 perform the inverse
47 | */
48 | FFTContext *av_fft_init(int nbits, int inverse);
49 |
50 | /**
51 | * Do the permutation needed BEFORE calling ff_fft_calc().
52 | */
53 | void av_fft_permute(FFTContext *s, FFTComplex *z);
54 |
55 | /**
56 | * Do a complex FFT with the parameters defined in av_fft_init(). The
57 | * input data must be permuted before. No 1.0/sqrt(n) normalization is done.
58 | */
59 | void av_fft_calc(FFTContext *s, FFTComplex *z);
60 |
61 | void av_fft_end(FFTContext *s);
62 |
63 | FFTContext *av_mdct_init(int nbits, int inverse, double scale);
64 | void av_imdct_calc(FFTContext *s, FFTSample *output, const FFTSample *input);
65 | void av_imdct_half(FFTContext *s, FFTSample *output, const FFTSample *input);
66 | void av_mdct_calc(FFTContext *s, FFTSample *output, const FFTSample *input);
67 | void av_mdct_end(FFTContext *s);
68 |
69 | /* Real Discrete Fourier Transform */
70 |
71 | enum RDFTransformType {
72 | DFT_R2C,
73 | IDFT_C2R,
74 | IDFT_R2C,
75 | DFT_C2R,
76 | };
77 |
78 | typedef struct RDFTContext RDFTContext;
79 |
80 | /**
81 | * Set up a real FFT.
82 | * @param nbits log2 of the length of the input array
83 | * @param trans the type of transform
84 | */
85 | RDFTContext *av_rdft_init(int nbits, enum RDFTransformType trans);
86 | void av_rdft_calc(RDFTContext *s, FFTSample *data);
87 | void av_rdft_end(RDFTContext *s);
88 |
89 | /* Discrete Cosine Transform */
90 |
91 | typedef struct DCTContext DCTContext;
92 |
93 | enum DCTTransformType {
94 | DCT_II = 0,
95 | DCT_III,
96 | DCT_I,
97 | DST_I,
98 | };
99 |
100 | /**
101 | * Set up DCT.
102 | *
103 | * @param nbits size of the input array:
104 | * (1 << nbits) for DCT-II, DCT-III and DST-I
105 | * (1 << nbits) + 1 for DCT-I
106 | * @param type the type of transform
107 | *
108 | * @note the first element of the input of DST-I is ignored
109 | */
110 | DCTContext *av_dct_init(int nbits, enum DCTTransformType type);
111 | void av_dct_calc(DCTContext *s, FFTSample *data);
112 | void av_dct_end (DCTContext *s);
113 |
114 | /**
115 | * @}
116 | */
117 |
118 | #endif /* AVCODEC_AVFFT_H */
119 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavcodec/d3d11va.h:
--------------------------------------------------------------------------------
1 | /*
2 | * Direct3D11 HW acceleration
3 | *
4 | * copyright (c) 2009 Laurent Aimar
5 | * copyright (c) 2015 Steve Lhomme
6 | *
7 | * This file is part of FFmpeg.
8 | *
9 | * FFmpeg is free software; you can redistribute it and/or
10 | * modify it under the terms of the GNU Lesser General Public
11 | * License as published by the Free Software Foundation; either
12 | * version 2.1 of the License, or (at your option) any later version.
13 | *
14 | * FFmpeg is distributed in the hope that it will be useful,
15 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
17 | * Lesser General Public License for more details.
18 | *
19 | * You should have received a copy of the GNU Lesser General Public
20 | * License along with FFmpeg; if not, write to the Free Software
21 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
22 | */
23 |
24 | #ifndef AVCODEC_D3D11VA_H
25 | #define AVCODEC_D3D11VA_H
26 |
27 | /**
28 | * @file
29 | * @ingroup lavc_codec_hwaccel_d3d11va
30 | * Public libavcodec D3D11VA header.
31 | */
32 |
33 | #if !defined(_WIN32_WINNT) || _WIN32_WINNT < 0x0602
34 | #undef _WIN32_WINNT
35 | #define _WIN32_WINNT 0x0602
36 | #endif
37 |
38 | #include
39 | #include
40 |
41 | /**
42 | * @defgroup lavc_codec_hwaccel_d3d11va Direct3D11
43 | * @ingroup lavc_codec_hwaccel
44 | *
45 | * @{
46 | */
47 |
48 | #define FF_DXVA2_WORKAROUND_SCALING_LIST_ZIGZAG 1 ///< Work around for Direct3D11 and old UVD/UVD+ ATI video cards
49 | #define FF_DXVA2_WORKAROUND_INTEL_CLEARVIDEO 2 ///< Work around for Direct3D11 and old Intel GPUs with ClearVideo interface
50 |
51 | /**
52 | * This structure is used to provides the necessary configurations and data
53 | * to the Direct3D11 FFmpeg HWAccel implementation.
54 | *
55 | * The application must make it available as AVCodecContext.hwaccel_context.
56 | *
57 | * Use av_d3d11va_alloc_context() exclusively to allocate an AVD3D11VAContext.
58 | */
59 | typedef struct AVD3D11VAContext {
60 | /**
61 | * D3D11 decoder object
62 | */
63 | ID3D11VideoDecoder *decoder;
64 |
65 | /**
66 | * D3D11 VideoContext
67 | */
68 | ID3D11VideoContext *video_context;
69 |
70 | /**
71 | * D3D11 configuration used to create the decoder
72 | */
73 | D3D11_VIDEO_DECODER_CONFIG *cfg;
74 |
75 | /**
76 | * The number of surface in the surface array
77 | */
78 | unsigned surface_count;
79 |
80 | /**
81 | * The array of Direct3D surfaces used to create the decoder
82 | */
83 | ID3D11VideoDecoderOutputView **surface;
84 |
85 | /**
86 | * A bit field configuring the workarounds needed for using the decoder
87 | */
88 | uint64_t workaround;
89 |
90 | /**
91 | * Private to the FFmpeg AVHWAccel implementation
92 | */
93 | unsigned report_id;
94 |
95 | /**
96 | * Mutex to access video_context
97 | */
98 | HANDLE context_mutex;
99 | } AVD3D11VAContext;
100 |
101 | /**
102 | * Allocate an AVD3D11VAContext.
103 | *
104 | * @return Newly-allocated AVD3D11VAContext or NULL on failure.
105 | */
106 | AVD3D11VAContext *av_d3d11va_alloc_context(void);
107 |
108 | /**
109 | * @}
110 | */
111 |
112 | #endif /* AVCODEC_D3D11VA_H */
113 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavcodec/dirac.h:
--------------------------------------------------------------------------------
1 | /*
2 | * Copyright (C) 2007 Marco Gerards
3 | * Copyright (C) 2009 David Conrad
4 | * Copyright (C) 2011 Jordi Ortiz
5 | *
6 | * This file is part of FFmpeg.
7 | *
8 | * FFmpeg is free software; you can redistribute it and/or
9 | * modify it under the terms of the GNU Lesser General Public
10 | * License as published by the Free Software Foundation; either
11 | * version 2.1 of the License, or (at your option) any later version.
12 | *
13 | * FFmpeg is distributed in the hope that it will be useful,
14 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16 | * Lesser General Public License for more details.
17 | *
18 | * You should have received a copy of the GNU Lesser General Public
19 | * License along with FFmpeg; if not, write to the Free Software
20 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
21 | */
22 |
23 | #ifndef AVCODEC_DIRAC_H
24 | #define AVCODEC_DIRAC_H
25 |
26 | /**
27 | * @file
28 | * Interface to Dirac Decoder/Encoder
29 | * @author Marco Gerards
30 | * @author David Conrad
31 | * @author Jordi Ortiz
32 | */
33 |
34 | #include "avcodec.h"
35 |
36 | /**
37 | * The spec limits the number of wavelet decompositions to 4 for both
38 | * level 1 (VC-2) and 128 (long-gop default).
39 | * 5 decompositions is the maximum before >16-bit buffers are needed.
40 | * Schroedinger allows this for DD 9,7 and 13,7 wavelets only, limiting
41 | * the others to 4 decompositions (or 3 for the fidelity filter).
42 | *
43 | * We use this instead of MAX_DECOMPOSITIONS to save some memory.
44 | */
45 | #define MAX_DWT_LEVELS 5
46 |
47 | /**
48 | * Parse code values:
49 | *
50 | * Dirac Specification ->
51 | * 9.6.1 Table 9.1
52 | *
53 | * VC-2 Specification ->
54 | * 10.4.1 Table 10.1
55 | */
56 |
57 | enum DiracParseCodes {
58 | DIRAC_PCODE_SEQ_HEADER = 0x00,
59 | DIRAC_PCODE_END_SEQ = 0x10,
60 | DIRAC_PCODE_AUX = 0x20,
61 | DIRAC_PCODE_PAD = 0x30,
62 | DIRAC_PCODE_PICTURE_CODED = 0x08,
63 | DIRAC_PCODE_PICTURE_RAW = 0x48,
64 | DIRAC_PCODE_PICTURE_LOW_DEL = 0xC8,
65 | DIRAC_PCODE_PICTURE_HQ = 0xE8,
66 | DIRAC_PCODE_INTER_NOREF_CO1 = 0x0A,
67 | DIRAC_PCODE_INTER_NOREF_CO2 = 0x09,
68 | DIRAC_PCODE_INTER_REF_CO1 = 0x0D,
69 | DIRAC_PCODE_INTER_REF_CO2 = 0x0E,
70 | DIRAC_PCODE_INTRA_REF_CO = 0x0C,
71 | DIRAC_PCODE_INTRA_REF_RAW = 0x4C,
72 | DIRAC_PCODE_INTRA_REF_PICT = 0xCC,
73 | DIRAC_PCODE_MAGIC = 0x42424344,
74 | };
75 |
76 | typedef struct DiracVersionInfo {
77 | int major;
78 | int minor;
79 | } DiracVersionInfo;
80 |
81 | typedef struct AVDiracSeqHeader {
82 | unsigned width;
83 | unsigned height;
84 | uint8_t chroma_format; ///< 0: 444 1: 422 2: 420
85 |
86 | uint8_t interlaced;
87 | uint8_t top_field_first;
88 |
89 | uint8_t frame_rate_index; ///< index into dirac_frame_rate[]
90 | uint8_t aspect_ratio_index; ///< index into dirac_aspect_ratio[]
91 |
92 | uint16_t clean_width;
93 | uint16_t clean_height;
94 | uint16_t clean_left_offset;
95 | uint16_t clean_right_offset;
96 |
97 | uint8_t pixel_range_index; ///< index into dirac_pixel_range_presets[]
98 | uint8_t color_spec_index; ///< index into dirac_color_spec_presets[]
99 |
100 | int profile;
101 | int level;
102 |
103 | AVRational framerate;
104 | AVRational sample_aspect_ratio;
105 |
106 | enum AVPixelFormat pix_fmt;
107 | enum AVColorRange color_range;
108 | enum AVColorPrimaries color_primaries;
109 | enum AVColorTransferCharacteristic color_trc;
110 | enum AVColorSpace colorspace;
111 |
112 | DiracVersionInfo version;
113 | int bit_depth;
114 | } AVDiracSeqHeader;
115 |
116 | /**
117 | * Parse a Dirac sequence header.
118 | *
119 | * @param dsh this function will allocate and fill an AVDiracSeqHeader struct
120 | * and write it into this pointer. The caller must free it with
121 | * av_free().
122 | * @param buf the data buffer
123 | * @param buf_size the size of the data buffer in bytes
124 | * @param log_ctx if non-NULL, this function will log errors here
125 | * @return 0 on success, a negative AVERROR code on failure
126 | */
127 | int av_dirac_parse_sequence_header(AVDiracSeqHeader **dsh,
128 | const uint8_t *buf, size_t buf_size,
129 | void *log_ctx);
130 |
131 | #endif /* AVCODEC_DIRAC_H */
132 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavcodec/dv_profile.h:
--------------------------------------------------------------------------------
1 | /*
2 | * This file is part of FFmpeg.
3 | *
4 | * FFmpeg is free software; you can redistribute it and/or
5 | * modify it under the terms of the GNU Lesser General Public
6 | * License as published by the Free Software Foundation; either
7 | * version 2.1 of the License, or (at your option) any later version.
8 | *
9 | * FFmpeg is distributed in the hope that it will be useful,
10 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 | * Lesser General Public License for more details.
13 | *
14 | * You should have received a copy of the GNU Lesser General Public
15 | * License along with FFmpeg; if not, write to the Free Software
16 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17 | */
18 |
19 | #ifndef AVCODEC_DV_PROFILE_H
20 | #define AVCODEC_DV_PROFILE_H
21 |
22 | #include
23 |
24 | #include "libavutil/pixfmt.h"
25 | #include "libavutil/rational.h"
26 | #include "avcodec.h"
27 |
28 | /* minimum number of bytes to read from a DV stream in order to
29 | * determine the profile */
30 | #define DV_PROFILE_BYTES (6 * 80) /* 6 DIF blocks */
31 |
32 |
33 | /*
34 | * AVDVProfile is used to express the differences between various
35 | * DV flavors. For now it's primarily used for differentiating
36 | * 525/60 and 625/50, but the plans are to use it for various
37 | * DV specs as well (e.g. SMPTE314M vs. IEC 61834).
38 | */
39 | typedef struct AVDVProfile {
40 | int dsf; /* value of the dsf in the DV header */
41 | int video_stype; /* stype for VAUX source pack */
42 | int frame_size; /* total size of one frame in bytes */
43 | int difseg_size; /* number of DIF segments per DIF channel */
44 | int n_difchan; /* number of DIF channels per frame */
45 | AVRational time_base; /* 1/framerate */
46 | int ltc_divisor; /* FPS from the LTS standpoint */
47 | int height; /* picture height in pixels */
48 | int width; /* picture width in pixels */
49 | AVRational sar[2]; /* sample aspect ratios for 4:3 and 16:9 */
50 | enum AVPixelFormat pix_fmt; /* picture pixel format */
51 | int bpm; /* blocks per macroblock */
52 | const uint8_t *block_sizes; /* AC block sizes, in bits */
53 | int audio_stride; /* size of audio_shuffle table */
54 | int audio_min_samples[3]; /* min amount of audio samples */
55 | /* for 48kHz, 44.1kHz and 32kHz */
56 | int audio_samples_dist[5]; /* how many samples are supposed to be */
57 | /* in each frame in a 5 frames window */
58 | const uint8_t (*audio_shuffle)[9]; /* PCM shuffling table */
59 | } AVDVProfile;
60 |
61 | /**
62 | * Get a DV profile for the provided compressed frame.
63 | *
64 | * @param sys the profile used for the previous frame, may be NULL
65 | * @param frame the compressed data buffer
66 | * @param buf_size size of the buffer in bytes
67 | * @return the DV profile for the supplied data or NULL on failure
68 | */
69 | const AVDVProfile *av_dv_frame_profile(const AVDVProfile *sys,
70 | const uint8_t *frame, unsigned buf_size);
71 |
72 | /**
73 | * Get a DV profile for the provided stream parameters.
74 | */
75 | const AVDVProfile *av_dv_codec_profile(int width, int height, enum AVPixelFormat pix_fmt);
76 |
77 | /**
78 | * Get a DV profile for the provided stream parameters.
79 | * The frame rate is used as a best-effort parameter.
80 | */
81 | const AVDVProfile *av_dv_codec_profile2(int width, int height, enum AVPixelFormat pix_fmt, AVRational frame_rate);
82 |
83 | #endif /* AVCODEC_DV_PROFILE_H */
84 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavcodec/dxva2.h:
--------------------------------------------------------------------------------
1 | /*
2 | * DXVA2 HW acceleration
3 | *
4 | * copyright (c) 2009 Laurent Aimar
5 | *
6 | * This file is part of FFmpeg.
7 | *
8 | * FFmpeg is free software; you can redistribute it and/or
9 | * modify it under the terms of the GNU Lesser General Public
10 | * License as published by the Free Software Foundation; either
11 | * version 2.1 of the License, or (at your option) any later version.
12 | *
13 | * FFmpeg is distributed in the hope that it will be useful,
14 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16 | * Lesser General Public License for more details.
17 | *
18 | * You should have received a copy of the GNU Lesser General Public
19 | * License along with FFmpeg; if not, write to the Free Software
20 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
21 | */
22 |
23 | #ifndef AVCODEC_DXVA2_H
24 | #define AVCODEC_DXVA2_H
25 |
26 | /**
27 | * @file
28 | * @ingroup lavc_codec_hwaccel_dxva2
29 | * Public libavcodec DXVA2 header.
30 | */
31 |
32 | #if !defined(_WIN32_WINNT) || _WIN32_WINNT < 0x0602
33 | #undef _WIN32_WINNT
34 | #define _WIN32_WINNT 0x0602
35 | #endif
36 |
37 | #include
38 | #include
39 | #include
40 |
41 | /**
42 | * @defgroup lavc_codec_hwaccel_dxva2 DXVA2
43 | * @ingroup lavc_codec_hwaccel
44 | *
45 | * @{
46 | */
47 |
48 | #define FF_DXVA2_WORKAROUND_SCALING_LIST_ZIGZAG 1 ///< Work around for DXVA2 and old UVD/UVD+ ATI video cards
49 | #define FF_DXVA2_WORKAROUND_INTEL_CLEARVIDEO 2 ///< Work around for DXVA2 and old Intel GPUs with ClearVideo interface
50 |
51 | /**
52 | * This structure is used to provides the necessary configurations and data
53 | * to the DXVA2 FFmpeg HWAccel implementation.
54 | *
55 | * The application must make it available as AVCodecContext.hwaccel_context.
56 | */
57 | struct dxva_context {
58 | /**
59 | * DXVA2 decoder object
60 | */
61 | IDirectXVideoDecoder *decoder;
62 |
63 | /**
64 | * DXVA2 configuration used to create the decoder
65 | */
66 | const DXVA2_ConfigPictureDecode *cfg;
67 |
68 | /**
69 | * The number of surface in the surface array
70 | */
71 | unsigned surface_count;
72 |
73 | /**
74 | * The array of Direct3D surfaces used to create the decoder
75 | */
76 | LPDIRECT3DSURFACE9 *surface;
77 |
78 | /**
79 | * A bit field configuring the workarounds needed for using the decoder
80 | */
81 | uint64_t workaround;
82 |
83 | /**
84 | * Private to the FFmpeg AVHWAccel implementation
85 | */
86 | unsigned report_id;
87 | };
88 |
89 | /**
90 | * @}
91 | */
92 |
93 | #endif /* AVCODEC_DXVA2_H */
94 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavcodec/jni.h:
--------------------------------------------------------------------------------
1 | /*
2 | * JNI public API functions
3 | *
4 | * Copyright (c) 2015-2016 Matthieu Bouron
5 | *
6 | * This file is part of FFmpeg.
7 | *
8 | * FFmpeg is free software; you can redistribute it and/or
9 | * modify it under the terms of the GNU Lesser General Public
10 | * License as published by the Free Software Foundation; either
11 | * version 2.1 of the License, or (at your option) any later version.
12 | *
13 | * FFmpeg is distributed in the hope that it will be useful,
14 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16 | * Lesser General Public License for more details.
17 | *
18 | * You should have received a copy of the GNU Lesser General Public
19 | * License along with FFmpeg; if not, write to the Free Software
20 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
21 | */
22 |
23 | #ifndef AVCODEC_JNI_H
24 | #define AVCODEC_JNI_H
25 |
26 | /*
27 | * Manually set a Java virtual machine which will be used to retrieve the JNI
28 | * environment. Once a Java VM is set it cannot be changed afterwards, meaning
29 | * you can call multiple times av_jni_set_java_vm with the same Java VM pointer
30 | * however it will error out if you try to set a different Java VM.
31 | *
32 | * @param vm Java virtual machine
33 | * @param log_ctx context used for logging, can be NULL
34 | * @return 0 on success, < 0 otherwise
35 | */
36 | int av_jni_set_java_vm(void *vm, void *log_ctx);
37 |
38 | /*
39 | * Get the Java virtual machine which has been set with av_jni_set_java_vm.
40 | *
41 | * @param vm Java virtual machine
42 | * @return a pointer to the Java virtual machine
43 | */
44 | void *av_jni_get_java_vm(void *log_ctx);
45 |
46 | #endif /* AVCODEC_JNI_H */
47 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavcodec/mediacodec.h:
--------------------------------------------------------------------------------
1 | /*
2 | * Android MediaCodec public API
3 | *
4 | * Copyright (c) 2016 Matthieu Bouron
5 | *
6 | * This file is part of FFmpeg.
7 | *
8 | * FFmpeg is free software; you can redistribute it and/or
9 | * modify it under the terms of the GNU Lesser General Public
10 | * License as published by the Free Software Foundation; either
11 | * version 2.1 of the License, or (at your option) any later version.
12 | *
13 | * FFmpeg is distributed in the hope that it will be useful,
14 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16 | * Lesser General Public License for more details.
17 | *
18 | * You should have received a copy of the GNU Lesser General Public
19 | * License along with FFmpeg; if not, write to the Free Software
20 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
21 | */
22 |
23 | #ifndef AVCODEC_MEDIACODEC_H
24 | #define AVCODEC_MEDIACODEC_H
25 |
26 | #include "libavcodec/avcodec.h"
27 |
28 | /**
29 | * This structure holds a reference to a android/view/Surface object that will
30 | * be used as output by the decoder.
31 | *
32 | */
33 | typedef struct AVMediaCodecContext {
34 |
35 | /**
36 | * android/view/Surface object reference.
37 | */
38 | void *surface;
39 |
40 | } AVMediaCodecContext;
41 |
42 | /**
43 | * Allocate and initialize a MediaCodec context.
44 | *
45 | * When decoding with MediaCodec is finished, the caller must free the
46 | * MediaCodec context with av_mediacodec_default_free.
47 | *
48 | * @return a pointer to a newly allocated AVMediaCodecContext on success, NULL otherwise
49 | */
50 | AVMediaCodecContext *av_mediacodec_alloc_context(void);
51 |
52 | /**
53 | * Convenience function that sets up the MediaCodec context.
54 | *
55 | * @param avctx codec context
56 | * @param ctx MediaCodec context to initialize
57 | * @param surface reference to an android/view/Surface
58 | * @return 0 on success, < 0 otherwise
59 | */
60 | int av_mediacodec_default_init(AVCodecContext *avctx, AVMediaCodecContext *ctx, void *surface);
61 |
62 | /**
63 | * This function must be called to free the MediaCodec context initialized with
64 | * av_mediacodec_default_init().
65 | *
66 | * @param avctx codec context
67 | */
68 | void av_mediacodec_default_free(AVCodecContext *avctx);
69 |
70 | /**
71 | * Opaque structure representing a MediaCodec buffer to render.
72 | */
73 | typedef struct MediaCodecBuffer AVMediaCodecBuffer;
74 |
75 | /**
76 | * Release a MediaCodec buffer and render it to the surface that is associated
77 | * with the decoder. This function should only be called once on a given
78 | * buffer, once released the underlying buffer returns to the codec, thus
79 | * subsequent calls to this function will have no effect.
80 | *
81 | * @param buffer the buffer to render
82 | * @param render 1 to release and render the buffer to the surface or 0 to
83 | * discard the buffer
84 | * @return 0 on success, < 0 otherwise
85 | */
86 | int av_mediacodec_release_buffer(AVMediaCodecBuffer *buffer, int render);
87 |
88 | #endif /* AVCODEC_MEDIACODEC_H */
89 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavcodec/qsv.h:
--------------------------------------------------------------------------------
1 | /*
2 | * Intel MediaSDK QSV public API
3 | *
4 | * This file is part of FFmpeg.
5 | *
6 | * FFmpeg is free software; you can redistribute it and/or
7 | * modify it under the terms of the GNU Lesser General Public
8 | * License as published by the Free Software Foundation; either
9 | * version 2.1 of the License, or (at your option) any later version.
10 | *
11 | * FFmpeg is distributed in the hope that it will be useful,
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 | * Lesser General Public License for more details.
15 | *
16 | * You should have received a copy of the GNU Lesser General Public
17 | * License along with FFmpeg; if not, write to the Free Software
18 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19 | */
20 |
21 | #ifndef AVCODEC_QSV_H
22 | #define AVCODEC_QSV_H
23 |
24 | #include
25 |
26 | #include "libavutil/buffer.h"
27 |
28 | /**
29 | * This struct is used for communicating QSV parameters between libavcodec and
30 | * the caller. It is managed by the caller and must be assigned to
31 | * AVCodecContext.hwaccel_context.
32 | * - decoding: hwaccel_context must be set on return from the get_format()
33 | * callback
34 | * - encoding: hwaccel_context must be set before avcodec_open2()
35 | */
36 | typedef struct AVQSVContext {
37 | /**
38 | * If non-NULL, the session to use for encoding or decoding.
39 | * Otherwise, libavcodec will try to create an internal session.
40 | */
41 | mfxSession session;
42 |
43 | /**
44 | * The IO pattern to use.
45 | */
46 | int iopattern;
47 |
48 | /**
49 | * Extra buffers to pass to encoder or decoder initialization.
50 | */
51 | mfxExtBuffer **ext_buffers;
52 | int nb_ext_buffers;
53 |
54 | /**
55 | * Encoding only. If this field is set to non-zero by the caller, libavcodec
56 | * will create an mfxExtOpaqueSurfaceAlloc extended buffer and pass it to
57 | * the encoder initialization. This only makes sense if iopattern is also
58 | * set to MFX_IOPATTERN_IN_OPAQUE_MEMORY.
59 | *
60 | * The number of allocated opaque surfaces will be the sum of the number
61 | * required by the encoder and the user-provided value nb_opaque_surfaces.
62 | * The array of the opaque surfaces will be exported to the caller through
63 | * the opaque_surfaces field.
64 | */
65 | int opaque_alloc;
66 |
67 | /**
68 | * Encoding only, and only if opaque_alloc is set to non-zero. Before
69 | * calling avcodec_open2(), the caller should set this field to the number
70 | * of extra opaque surfaces to allocate beyond what is required by the
71 | * encoder.
72 | *
73 | * On return from avcodec_open2(), this field will be set by libavcodec to
74 | * the total number of allocated opaque surfaces.
75 | */
76 | int nb_opaque_surfaces;
77 |
78 | /**
79 | * Encoding only, and only if opaque_alloc is set to non-zero. On return
80 | * from avcodec_open2(), this field will be used by libavcodec to export the
81 | * array of the allocated opaque surfaces to the caller, so they can be
82 | * passed to other parts of the pipeline.
83 | *
84 | * The buffer reference exported here is owned and managed by libavcodec,
85 | * the callers should make their own reference with av_buffer_ref() and free
86 | * it with av_buffer_unref() when it is no longer needed.
87 | *
88 | * The buffer data is an nb_opaque_surfaces-sized array of mfxFrameSurface1.
89 | */
90 | AVBufferRef *opaque_surfaces;
91 |
92 | /**
93 | * Encoding only, and only if opaque_alloc is set to non-zero. On return
94 | * from avcodec_open2(), this field will be set to the surface type used in
95 | * the opaque allocation request.
96 | */
97 | int opaque_alloc_type;
98 | } AVQSVContext;
99 |
100 | /**
101 | * Allocate a new context.
102 | *
103 | * It must be freed by the caller with av_free().
104 | */
105 | AVQSVContext *av_qsv_alloc_context(void);
106 |
107 | #endif /* AVCODEC_QSV_H */
108 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavcodec/videotoolbox.h:
--------------------------------------------------------------------------------
1 | /*
2 | * Videotoolbox hardware acceleration
3 | *
4 | * copyright (c) 2012 Sebastien Zwickert
5 | *
6 | * This file is part of FFmpeg.
7 | *
8 | * FFmpeg is free software; you can redistribute it and/or
9 | * modify it under the terms of the GNU Lesser General Public
10 | * License as published by the Free Software Foundation; either
11 | * version 2.1 of the License, or (at your option) any later version.
12 | *
13 | * FFmpeg is distributed in the hope that it will be useful,
14 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16 | * Lesser General Public License for more details.
17 | *
18 | * You should have received a copy of the GNU Lesser General Public
19 | * License along with FFmpeg; if not, write to the Free Software
20 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
21 | */
22 |
23 | #ifndef AVCODEC_VIDEOTOOLBOX_H
24 | #define AVCODEC_VIDEOTOOLBOX_H
25 |
26 | /**
27 | * @file
28 | * @ingroup lavc_codec_hwaccel_videotoolbox
29 | * Public libavcodec Videotoolbox header.
30 | */
31 |
32 | #include
33 |
34 | #define Picture QuickdrawPicture
35 | #include
36 | #undef Picture
37 |
38 | #include "libavcodec/avcodec.h"
39 |
40 | /**
41 | * This struct holds all the information that needs to be passed
42 | * between the caller and libavcodec for initializing Videotoolbox decoding.
43 | * Its size is not a part of the public ABI, it must be allocated with
44 | * av_videotoolbox_alloc_context() and freed with av_free().
45 | */
46 | typedef struct AVVideotoolboxContext {
47 | /**
48 | * Videotoolbox decompression session object.
49 | * Created and freed the caller.
50 | */
51 | VTDecompressionSessionRef session;
52 |
53 | /**
54 | * The output callback that must be passed to the session.
55 | * Set by av_videottoolbox_default_init()
56 | */
57 | VTDecompressionOutputCallback output_callback;
58 |
59 | /**
60 | * CVPixelBuffer Format Type that Videotoolbox will use for decoded frames.
61 | * set by the caller.
62 | */
63 | OSType cv_pix_fmt_type;
64 |
65 | /**
66 | * CoreMedia Format Description that Videotoolbox will use to create the decompression session.
67 | * Set by the caller.
68 | */
69 | CMVideoFormatDescriptionRef cm_fmt_desc;
70 |
71 | /**
72 | * CoreMedia codec type that Videotoolbox will use to create the decompression session.
73 | * Set by the caller.
74 | */
75 | int cm_codec_type;
76 | } AVVideotoolboxContext;
77 |
78 | /**
79 | * Allocate and initialize a Videotoolbox context.
80 | *
81 | * This function should be called from the get_format() callback when the caller
82 | * selects the AV_PIX_FMT_VIDETOOLBOX format. The caller must then create
83 | * the decoder object (using the output callback provided by libavcodec) that
84 | * will be used for Videotoolbox-accelerated decoding.
85 | *
86 | * When decoding with Videotoolbox is finished, the caller must destroy the decoder
87 | * object and free the Videotoolbox context using av_free().
88 | *
89 | * @return the newly allocated context or NULL on failure
90 | */
91 | AVVideotoolboxContext *av_videotoolbox_alloc_context(void);
92 |
93 | /**
94 | * This is a convenience function that creates and sets up the Videotoolbox context using
95 | * an internal implementation.
96 | *
97 | * @param avctx the corresponding codec context
98 | *
99 | * @return >= 0 on success, a negative AVERROR code on failure
100 | */
101 | int av_videotoolbox_default_init(AVCodecContext *avctx);
102 |
103 | /**
104 | * This is a convenience function that creates and sets up the Videotoolbox context using
105 | * an internal implementation.
106 | *
107 | * @param avctx the corresponding codec context
108 | * @param vtctx the Videotoolbox context to use
109 | *
110 | * @return >= 0 on success, a negative AVERROR code on failure
111 | */
112 | int av_videotoolbox_default_init2(AVCodecContext *avctx, AVVideotoolboxContext *vtctx);
113 |
114 | /**
115 | * This function must be called to free the Videotoolbox context initialized with
116 | * av_videotoolbox_default_init().
117 | *
118 | * @param avctx the corresponding codec context
119 | */
120 | void av_videotoolbox_default_free(AVCodecContext *avctx);
121 |
122 | /**
123 | * @}
124 | */
125 |
126 | #endif /* AVCODEC_VIDEOTOOLBOX_H */
127 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavcodec/vorbis_parser.h:
--------------------------------------------------------------------------------
1 | /*
2 | * This file is part of FFmpeg.
3 | *
4 | * FFmpeg is free software; you can redistribute it and/or
5 | * modify it under the terms of the GNU Lesser General Public
6 | * License as published by the Free Software Foundation; either
7 | * version 2.1 of the License, or (at your option) any later version.
8 | *
9 | * FFmpeg is distributed in the hope that it will be useful,
10 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 | * Lesser General Public License for more details.
13 | *
14 | * You should have received a copy of the GNU Lesser General Public
15 | * License along with FFmpeg; if not, write to the Free Software
16 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17 | */
18 |
19 | /**
20 | * @file
21 | * A public API for Vorbis parsing
22 | *
23 | * Determines the duration for each packet.
24 | */
25 |
26 | #ifndef AVCODEC_VORBIS_PARSER_H
27 | #define AVCODEC_VORBIS_PARSER_H
28 |
29 | #include
30 |
31 | typedef struct AVVorbisParseContext AVVorbisParseContext;
32 |
33 | /**
34 | * Allocate and initialize the Vorbis parser using headers in the extradata.
35 | *
36 | * @param avctx codec context
37 | * @param s Vorbis parser context
38 | */
39 | AVVorbisParseContext *av_vorbis_parse_init(const uint8_t *extradata,
40 | int extradata_size);
41 |
42 | /**
43 | * Free the parser and everything associated with it.
44 | */
45 | void av_vorbis_parse_free(AVVorbisParseContext **s);
46 |
47 | #define VORBIS_FLAG_HEADER 0x00000001
48 | #define VORBIS_FLAG_COMMENT 0x00000002
49 | #define VORBIS_FLAG_SETUP 0x00000004
50 |
51 | /**
52 | * Get the duration for a Vorbis packet.
53 | *
54 | * If @p flags is @c NULL,
55 | * special frames are considered invalid.
56 | *
57 | * @param s Vorbis parser context
58 | * @param buf buffer containing a Vorbis frame
59 | * @param buf_size size of the buffer
60 | * @param flags flags for special frames
61 | */
62 | int av_vorbis_parse_frame_flags(AVVorbisParseContext *s, const uint8_t *buf,
63 | int buf_size, int *flags);
64 |
65 | /**
66 | * Get the duration for a Vorbis packet.
67 | *
68 | * @param s Vorbis parser context
69 | * @param buf buffer containing a Vorbis frame
70 | * @param buf_size size of the buffer
71 | */
72 | int av_vorbis_parse_frame(AVVorbisParseContext *s, const uint8_t *buf,
73 | int buf_size);
74 |
75 | void av_vorbis_parse_reset(AVVorbisParseContext *s);
76 |
77 | #endif /* AVCODEC_VORBIS_PARSER_H */
78 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavfilter/avfiltergraph.h:
--------------------------------------------------------------------------------
1 | /*
2 | * Filter graphs
3 | * copyright (c) 2007 Bobby Bingham
4 | *
5 | * This file is part of FFmpeg.
6 | *
7 | * FFmpeg is free software; you can redistribute it and/or
8 | * modify it under the terms of the GNU Lesser General Public
9 | * License as published by the Free Software Foundation; either
10 | * version 2.1 of the License, or (at your option) any later version.
11 | *
12 | * FFmpeg is distributed in the hope that it will be useful,
13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 | * Lesser General Public License for more details.
16 | *
17 | * You should have received a copy of the GNU Lesser General Public
18 | * License along with FFmpeg; if not, write to the Free Software
19 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20 | */
21 |
22 | #ifndef AVFILTER_AVFILTERGRAPH_H
23 | #define AVFILTER_AVFILTERGRAPH_H
24 |
25 | #include "avfilter.h"
26 | #include "libavutil/log.h"
27 |
28 | #endif /* AVFILTER_AVFILTERGRAPH_H */
29 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavfilter/version.h:
--------------------------------------------------------------------------------
1 | /*
2 | * Version macros.
3 | *
4 | * This file is part of FFmpeg.
5 | *
6 | * FFmpeg is free software; you can redistribute it and/or
7 | * modify it under the terms of the GNU Lesser General Public
8 | * License as published by the Free Software Foundation; either
9 | * version 2.1 of the License, or (at your option) any later version.
10 | *
11 | * FFmpeg is distributed in the hope that it will be useful,
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 | * Lesser General Public License for more details.
15 | *
16 | * You should have received a copy of the GNU Lesser General Public
17 | * License along with FFmpeg; if not, write to the Free Software
18 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19 | */
20 |
21 | #ifndef AVFILTER_VERSION_H
22 | #define AVFILTER_VERSION_H
23 |
24 | /**
25 | * @file
26 | * @ingroup lavfi
27 | * Libavfilter version macros
28 | */
29 |
30 | #include "libavutil/version.h"
31 |
32 | #define LIBAVFILTER_VERSION_MAJOR 6
33 | #define LIBAVFILTER_VERSION_MINOR 65
34 | #define LIBAVFILTER_VERSION_MICRO 100
35 |
36 | #define LIBAVFILTER_VERSION_INT AV_VERSION_INT(LIBAVFILTER_VERSION_MAJOR, \
37 | LIBAVFILTER_VERSION_MINOR, \
38 | LIBAVFILTER_VERSION_MICRO)
39 | #define LIBAVFILTER_VERSION AV_VERSION(LIBAVFILTER_VERSION_MAJOR, \
40 | LIBAVFILTER_VERSION_MINOR, \
41 | LIBAVFILTER_VERSION_MICRO)
42 | #define LIBAVFILTER_BUILD LIBAVFILTER_VERSION_INT
43 |
44 | #define LIBAVFILTER_IDENT "Lavfi" AV_STRINGIFY(LIBAVFILTER_VERSION)
45 |
46 | /**
47 | * FF_API_* defines may be placed below to indicate public API that will be
48 | * dropped at a future version bump. The defines themselves are not part of
49 | * the public API and may change, break or disappear at any time.
50 | */
51 |
52 | #ifndef FF_API_OLD_FILTER_OPTS
53 | #define FF_API_OLD_FILTER_OPTS (LIBAVFILTER_VERSION_MAJOR < 7)
54 | #endif
55 | #ifndef FF_API_OLD_FILTER_OPTS_ERROR
56 | #define FF_API_OLD_FILTER_OPTS_ERROR (LIBAVFILTER_VERSION_MAJOR < 7)
57 | #endif
58 | #ifndef FF_API_AVFILTER_OPEN
59 | #define FF_API_AVFILTER_OPEN (LIBAVFILTER_VERSION_MAJOR < 7)
60 | #endif
61 | #ifndef FF_API_AVFILTER_INIT_FILTER
62 | #define FF_API_AVFILTER_INIT_FILTER (LIBAVFILTER_VERSION_MAJOR < 7)
63 | #endif
64 | #ifndef FF_API_OLD_FILTER_REGISTER
65 | #define FF_API_OLD_FILTER_REGISTER (LIBAVFILTER_VERSION_MAJOR < 7)
66 | #endif
67 | #ifndef FF_API_NOCONST_GET_NAME
68 | #define FF_API_NOCONST_GET_NAME (LIBAVFILTER_VERSION_MAJOR < 7)
69 | #endif
70 |
71 | #endif /* AVFILTER_VERSION_H */
72 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavformat/version.h:
--------------------------------------------------------------------------------
1 | /*
2 | * Version macros.
3 | *
4 | * This file is part of FFmpeg.
5 | *
6 | * FFmpeg is free software; you can redistribute it and/or
7 | * modify it under the terms of the GNU Lesser General Public
8 | * License as published by the Free Software Foundation; either
9 | * version 2.1 of the License, or (at your option) any later version.
10 | *
11 | * FFmpeg is distributed in the hope that it will be useful,
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 | * Lesser General Public License for more details.
15 | *
16 | * You should have received a copy of the GNU Lesser General Public
17 | * License along with FFmpeg; if not, write to the Free Software
18 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19 | */
20 |
21 | #ifndef AVFORMAT_VERSION_H
22 | #define AVFORMAT_VERSION_H
23 |
24 | /**
25 | * @file
26 | * @ingroup libavf
27 | * Libavformat version macros
28 | */
29 |
30 | #include "libavutil/version.h"
31 |
32 | // Major bumping may affect Ticket5467, 5421, 5451(compatibility with Chromium)
33 | // Also please add any ticket numbers that you believe might be affected here
34 | #define LIBAVFORMAT_VERSION_MAJOR 57
35 | #define LIBAVFORMAT_VERSION_MINOR 56
36 | #define LIBAVFORMAT_VERSION_MICRO 101
37 |
38 | #define LIBAVFORMAT_VERSION_INT AV_VERSION_INT(LIBAVFORMAT_VERSION_MAJOR, \
39 | LIBAVFORMAT_VERSION_MINOR, \
40 | LIBAVFORMAT_VERSION_MICRO)
41 | #define LIBAVFORMAT_VERSION AV_VERSION(LIBAVFORMAT_VERSION_MAJOR, \
42 | LIBAVFORMAT_VERSION_MINOR, \
43 | LIBAVFORMAT_VERSION_MICRO)
44 | #define LIBAVFORMAT_BUILD LIBAVFORMAT_VERSION_INT
45 |
46 | #define LIBAVFORMAT_IDENT "Lavf" AV_STRINGIFY(LIBAVFORMAT_VERSION)
47 |
48 | /**
49 | * FF_API_* defines may be placed below to indicate public API that will be
50 | * dropped at a future version bump. The defines themselves are not part of
51 | * the public API and may change, break or disappear at any time.
52 | *
53 | * @note, when bumping the major version it is recommended to manually
54 | * disable each FF_API_* in its own commit instead of disabling them all
55 | * at once through the bump. This improves the git bisect-ability of the change.
56 | *
57 | */
58 | #ifndef FF_API_LAVF_BITEXACT
59 | #define FF_API_LAVF_BITEXACT (LIBAVFORMAT_VERSION_MAJOR < 58)
60 | #endif
61 | #ifndef FF_API_LAVF_FRAC
62 | #define FF_API_LAVF_FRAC (LIBAVFORMAT_VERSION_MAJOR < 58)
63 | #endif
64 | #ifndef FF_API_LAVF_CODEC_TB
65 | #define FF_API_LAVF_CODEC_TB (LIBAVFORMAT_VERSION_MAJOR < 58)
66 | #endif
67 | #ifndef FF_API_URL_FEOF
68 | #define FF_API_URL_FEOF (LIBAVFORMAT_VERSION_MAJOR < 58)
69 | #endif
70 | #ifndef FF_API_LAVF_FMT_RAWPICTURE
71 | #define FF_API_LAVF_FMT_RAWPICTURE (LIBAVFORMAT_VERSION_MAJOR < 58)
72 | #endif
73 | #ifndef FF_API_COMPUTE_PKT_FIELDS2
74 | #define FF_API_COMPUTE_PKT_FIELDS2 (LIBAVFORMAT_VERSION_MAJOR < 58)
75 | #endif
76 | #ifndef FF_API_OLD_OPEN_CALLBACKS
77 | #define FF_API_OLD_OPEN_CALLBACKS (LIBAVFORMAT_VERSION_MAJOR < 58)
78 | #endif
79 | #ifndef FF_API_LAVF_AVCTX
80 | #define FF_API_LAVF_AVCTX (LIBAVFORMAT_VERSION_MAJOR < 58)
81 | #endif
82 | #ifndef FF_API_NOCONST_GET_SIDE_DATA
83 | #define FF_API_NOCONST_GET_SIDE_DATA (LIBAVFORMAT_VERSION_MAJOR < 58)
84 | #endif
85 | #ifndef FF_API_HTTP_USER_AGENT
86 | #define FF_API_HTTP_USER_AGENT (LIBAVFORMAT_VERSION_MAJOR < 58)
87 | #endif
88 |
89 | #ifndef FF_API_R_FRAME_RATE
90 | #define FF_API_R_FRAME_RATE 1
91 | #endif
92 | #endif /* AVFORMAT_VERSION_H */
93 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavutil/adler32.h:
--------------------------------------------------------------------------------
1 | /*
2 | * copyright (c) 2006 Mans Rullgard
3 | *
4 | * This file is part of FFmpeg.
5 | *
6 | * FFmpeg is free software; you can redistribute it and/or
7 | * modify it under the terms of the GNU Lesser General Public
8 | * License as published by the Free Software Foundation; either
9 | * version 2.1 of the License, or (at your option) any later version.
10 | *
11 | * FFmpeg is distributed in the hope that it will be useful,
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 | * Lesser General Public License for more details.
15 | *
16 | * You should have received a copy of the GNU Lesser General Public
17 | * License along with FFmpeg; if not, write to the Free Software
18 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19 | */
20 |
21 | /**
22 | * @file
23 | * @ingroup lavu_adler32
24 | * Public header for Adler-32 hash function implementation.
25 | */
26 |
27 | #ifndef AVUTIL_ADLER32_H
28 | #define AVUTIL_ADLER32_H
29 |
30 | #include
31 | #include "attributes.h"
32 |
33 | /**
34 | * @defgroup lavu_adler32 Adler-32
35 | * @ingroup lavu_hash
36 | * Adler-32 hash function implementation.
37 | *
38 | * @{
39 | */
40 |
41 | /**
42 | * Calculate the Adler32 checksum of a buffer.
43 | *
44 | * Passing the return value to a subsequent av_adler32_update() call
45 | * allows the checksum of multiple buffers to be calculated as though
46 | * they were concatenated.
47 | *
48 | * @param adler initial checksum value
49 | * @param buf pointer to input buffer
50 | * @param len size of input buffer
51 | * @return updated checksum
52 | */
53 | unsigned long av_adler32_update(unsigned long adler, const uint8_t *buf,
54 | unsigned int len) av_pure;
55 |
56 | /**
57 | * @}
58 | */
59 |
60 | #endif /* AVUTIL_ADLER32_H */
61 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavutil/aes.h:
--------------------------------------------------------------------------------
1 | /*
2 | * copyright (c) 2007 Michael Niedermayer
3 | *
4 | * This file is part of FFmpeg.
5 | *
6 | * FFmpeg is free software; you can redistribute it and/or
7 | * modify it under the terms of the GNU Lesser General Public
8 | * License as published by the Free Software Foundation; either
9 | * version 2.1 of the License, or (at your option) any later version.
10 | *
11 | * FFmpeg is distributed in the hope that it will be useful,
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 | * Lesser General Public License for more details.
15 | *
16 | * You should have received a copy of the GNU Lesser General Public
17 | * License along with FFmpeg; if not, write to the Free Software
18 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19 | */
20 |
21 | #ifndef AVUTIL_AES_H
22 | #define AVUTIL_AES_H
23 |
24 | #include
25 |
26 | #include "attributes.h"
27 | #include "version.h"
28 |
29 | /**
30 | * @defgroup lavu_aes AES
31 | * @ingroup lavu_crypto
32 | * @{
33 | */
34 |
35 | extern const int av_aes_size;
36 |
37 | struct AVAES;
38 |
39 | /**
40 | * Allocate an AVAES context.
41 | */
42 | struct AVAES *av_aes_alloc(void);
43 |
44 | /**
45 | * Initialize an AVAES context.
46 | * @param key_bits 128, 192 or 256
47 | * @param decrypt 0 for encryption, 1 for decryption
48 | */
49 | int av_aes_init(struct AVAES *a, const uint8_t *key, int key_bits, int decrypt);
50 |
51 | /**
52 | * Encrypt or decrypt a buffer using a previously initialized context.
53 | * @param count number of 16 byte blocks
54 | * @param dst destination array, can be equal to src
55 | * @param src source array, can be equal to dst
56 | * @param iv initialization vector for CBC mode, if NULL then ECB will be used
57 | * @param decrypt 0 for encryption, 1 for decryption
58 | */
59 | void av_aes_crypt(struct AVAES *a, uint8_t *dst, const uint8_t *src, int count, uint8_t *iv, int decrypt);
60 |
61 | /**
62 | * @}
63 | */
64 |
65 | #endif /* AVUTIL_AES_H */
66 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavutil/aes_ctr.h:
--------------------------------------------------------------------------------
1 | /*
2 | * AES-CTR cipher
3 | * Copyright (c) 2015 Eran Kornblau
4 | *
5 | * This file is part of FFmpeg.
6 | *
7 | * FFmpeg is free software; you can redistribute it and/or
8 | * modify it under the terms of the GNU Lesser General Public
9 | * License as published by the Free Software Foundation; either
10 | * version 2.1 of the License, or (at your option) any later version.
11 | *
12 | * FFmpeg is distributed in the hope that it will be useful,
13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 | * Lesser General Public License for more details.
16 | *
17 | * You should have received a copy of the GNU Lesser General Public
18 | * License along with FFmpeg; if not, write to the Free Software
19 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20 | */
21 |
22 | #ifndef AVUTIL_AES_CTR_H
23 | #define AVUTIL_AES_CTR_H
24 |
25 | #include
26 |
27 | #include "attributes.h"
28 | #include "version.h"
29 |
30 | #define AES_CTR_KEY_SIZE (16)
31 | #define AES_CTR_IV_SIZE (8)
32 |
33 | struct AVAESCTR;
34 |
35 | /**
36 | * Allocate an AVAESCTR context.
37 | */
38 | struct AVAESCTR *av_aes_ctr_alloc(void);
39 |
40 | /**
41 | * Initialize an AVAESCTR context.
42 | * @param key encryption key, must have a length of AES_CTR_KEY_SIZE
43 | */
44 | int av_aes_ctr_init(struct AVAESCTR *a, const uint8_t *key);
45 |
46 | /**
47 | * Release an AVAESCTR context.
48 | */
49 | void av_aes_ctr_free(struct AVAESCTR *a);
50 |
51 | /**
52 | * Process a buffer using a previously initialized context.
53 | * @param dst destination array, can be equal to src
54 | * @param src source array, can be equal to dst
55 | * @param size the size of src and dst
56 | */
57 | void av_aes_ctr_crypt(struct AVAESCTR *a, uint8_t *dst, const uint8_t *src, int size);
58 |
59 | /**
60 | * Get the current iv
61 | */
62 | const uint8_t* av_aes_ctr_get_iv(struct AVAESCTR *a);
63 |
64 | /**
65 | * Generate a random iv
66 | */
67 | void av_aes_ctr_set_random_iv(struct AVAESCTR *a);
68 |
69 | /**
70 | * Forcefully change the iv
71 | */
72 | void av_aes_ctr_set_iv(struct AVAESCTR *a, const uint8_t* iv);
73 |
74 | /**
75 | * Increment the top 64 bit of the iv (performed after each frame)
76 | */
77 | void av_aes_ctr_increment_iv(struct AVAESCTR *a);
78 |
79 | /**
80 | * @}
81 | */
82 |
83 | #endif /* AVUTIL_AES_CTR_H */
84 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavutil/avassert.h:
--------------------------------------------------------------------------------
1 | /*
2 | * copyright (c) 2010 Michael Niedermayer
3 | *
4 | * This file is part of FFmpeg.
5 | *
6 | * FFmpeg is free software; you can redistribute it and/or
7 | * modify it under the terms of the GNU Lesser General Public
8 | * License as published by the Free Software Foundation; either
9 | * version 2.1 of the License, or (at your option) any later version.
10 | *
11 | * FFmpeg is distributed in the hope that it will be useful,
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 | * Lesser General Public License for more details.
15 | *
16 | * You should have received a copy of the GNU Lesser General Public
17 | * License along with FFmpeg; if not, write to the Free Software
18 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19 | */
20 |
21 | /**
22 | * @file
23 | * simple assert() macros that are a bit more flexible than ISO C assert().
24 | * @author Michael Niedermayer
25 | */
26 |
27 | #ifndef AVUTIL_AVASSERT_H
28 | #define AVUTIL_AVASSERT_H
29 |
30 | #include
31 | #include "avutil.h"
32 | #include "log.h"
33 |
34 | /**
35 | * assert() equivalent, that is always enabled.
36 | */
37 | #define av_assert0(cond) do { \
38 | if (!(cond)) { \
39 | av_log(NULL, AV_LOG_PANIC, "Assertion %s failed at %s:%d\n", \
40 | AV_STRINGIFY(cond), __FILE__, __LINE__); \
41 | abort(); \
42 | } \
43 | } while (0)
44 |
45 |
46 | /**
47 | * assert() equivalent, that does not lie in speed critical code.
48 | * These asserts() thus can be enabled without fearing speed loss.
49 | */
50 | #if defined(ASSERT_LEVEL) && ASSERT_LEVEL > 0
51 | #define av_assert1(cond) av_assert0(cond)
52 | #else
53 | #define av_assert1(cond) ((void)0)
54 | #endif
55 |
56 |
57 | /**
58 | * assert() equivalent, that does lie in speed critical code.
59 | */
60 | #if defined(ASSERT_LEVEL) && ASSERT_LEVEL > 1
61 | #define av_assert2(cond) av_assert0(cond)
62 | #define av_assert2_fpu() av_assert0_fpu()
63 | #else
64 | #define av_assert2(cond) ((void)0)
65 | #define av_assert2_fpu() ((void)0)
66 | #endif
67 |
68 | /**
69 | * Assert that floating point opperations can be executed.
70 | *
71 | * This will av_assert0() that the cpu is not in MMX state on X86
72 | */
73 | void av_assert0_fpu(void);
74 |
75 | #endif /* AVUTIL_AVASSERT_H */
76 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavutil/avconfig.h:
--------------------------------------------------------------------------------
1 | /* Generated by ffconf */
2 | #ifndef AVUTIL_AVCONFIG_H
3 | #define AVUTIL_AVCONFIG_H
4 | #define AV_HAVE_BIGENDIAN 0
5 | #define AV_HAVE_FAST_UNALIGNED 1
6 | #endif /* AVUTIL_AVCONFIG_H */
7 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavutil/base64.h:
--------------------------------------------------------------------------------
1 | /*
2 | * Copyright (c) 2006 Ryan Martell. (rdm4@martellventures.com)
3 | *
4 | * This file is part of FFmpeg.
5 | *
6 | * FFmpeg is free software; you can redistribute it and/or
7 | * modify it under the terms of the GNU Lesser General Public
8 | * License as published by the Free Software Foundation; either
9 | * version 2.1 of the License, or (at your option) any later version.
10 | *
11 | * FFmpeg is distributed in the hope that it will be useful,
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 | * Lesser General Public License for more details.
15 | *
16 | * You should have received a copy of the GNU Lesser General Public
17 | * License along with FFmpeg; if not, write to the Free Software
18 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19 | */
20 |
21 | #ifndef AVUTIL_BASE64_H
22 | #define AVUTIL_BASE64_H
23 |
24 | #include
25 |
26 | /**
27 | * @defgroup lavu_base64 Base64
28 | * @ingroup lavu_crypto
29 | * @{
30 | */
31 |
32 | /**
33 | * Decode a base64-encoded string.
34 | *
35 | * @param out buffer for decoded data
36 | * @param in null-terminated input string
37 | * @param out_size size in bytes of the out buffer, must be at
38 | * least 3/4 of the length of in, that is AV_BASE64_DECODE_SIZE(strlen(in))
39 | * @return number of bytes written, or a negative value in case of
40 | * invalid input
41 | */
42 | int av_base64_decode(uint8_t *out, const char *in, int out_size);
43 |
44 | /**
45 | * Calculate the output size in bytes needed to decode a base64 string
46 | * with length x to a data buffer.
47 | */
48 | #define AV_BASE64_DECODE_SIZE(x) ((x) * 3LL / 4)
49 |
50 | /**
51 | * Encode data to base64 and null-terminate.
52 | *
53 | * @param out buffer for encoded data
54 | * @param out_size size in bytes of the out buffer (including the
55 | * null terminator), must be at least AV_BASE64_SIZE(in_size)
56 | * @param in input buffer containing the data to encode
57 | * @param in_size size in bytes of the in buffer
58 | * @return out or NULL in case of error
59 | */
60 | char *av_base64_encode(char *out, int out_size, const uint8_t *in, int in_size);
61 |
62 | /**
63 | * Calculate the output size needed to base64-encode x bytes to a
64 | * null-terminated string.
65 | */
66 | #define AV_BASE64_SIZE(x) (((x)+2) / 3 * 4 + 1)
67 |
68 | /**
69 | * @}
70 | */
71 |
72 | #endif /* AVUTIL_BASE64_H */
73 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavutil/blowfish.h:
--------------------------------------------------------------------------------
1 | /*
2 | * Blowfish algorithm
3 | * Copyright (c) 2012 Samuel Pitoiset
4 | *
5 | * This file is part of FFmpeg.
6 | *
7 | * FFmpeg is free software; you can redistribute it and/or
8 | * modify it under the terms of the GNU Lesser General Public
9 | * License as published by the Free Software Foundation; either
10 | * version 2.1 of the License, or (at your option) any later version.
11 | *
12 | * FFmpeg is distributed in the hope that it will be useful,
13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 | * Lesser General Public License for more details.
16 | *
17 | * You should have received a copy of the GNU Lesser General Public
18 | * License along with FFmpeg; if not, write to the Free Software
19 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20 | */
21 |
22 | #ifndef AVUTIL_BLOWFISH_H
23 | #define AVUTIL_BLOWFISH_H
24 |
25 | #include
26 |
27 | /**
28 | * @defgroup lavu_blowfish Blowfish
29 | * @ingroup lavu_crypto
30 | * @{
31 | */
32 |
33 | #define AV_BF_ROUNDS 16
34 |
35 | typedef struct AVBlowfish {
36 | uint32_t p[AV_BF_ROUNDS + 2];
37 | uint32_t s[4][256];
38 | } AVBlowfish;
39 |
40 | /**
41 | * Allocate an AVBlowfish context.
42 | */
43 | AVBlowfish *av_blowfish_alloc(void);
44 |
45 | /**
46 | * Initialize an AVBlowfish context.
47 | *
48 | * @param ctx an AVBlowfish context
49 | * @param key a key
50 | * @param key_len length of the key
51 | */
52 | void av_blowfish_init(struct AVBlowfish *ctx, const uint8_t *key, int key_len);
53 |
54 | /**
55 | * Encrypt or decrypt a buffer using a previously initialized context.
56 | *
57 | * @param ctx an AVBlowfish context
58 | * @param xl left four bytes halves of input to be encrypted
59 | * @param xr right four bytes halves of input to be encrypted
60 | * @param decrypt 0 for encryption, 1 for decryption
61 | */
62 | void av_blowfish_crypt_ecb(struct AVBlowfish *ctx, uint32_t *xl, uint32_t *xr,
63 | int decrypt);
64 |
65 | /**
66 | * Encrypt or decrypt a buffer using a previously initialized context.
67 | *
68 | * @param ctx an AVBlowfish context
69 | * @param dst destination array, can be equal to src
70 | * @param src source array, can be equal to dst
71 | * @param count number of 8 byte blocks
72 | * @param iv initialization vector for CBC mode, if NULL ECB will be used
73 | * @param decrypt 0 for encryption, 1 for decryption
74 | */
75 | void av_blowfish_crypt(struct AVBlowfish *ctx, uint8_t *dst, const uint8_t *src,
76 | int count, uint8_t *iv, int decrypt);
77 |
78 | /**
79 | * @}
80 | */
81 |
82 | #endif /* AVUTIL_BLOWFISH_H */
83 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavutil/bswap.h:
--------------------------------------------------------------------------------
1 | /*
2 | * copyright (c) 2006 Michael Niedermayer
3 | *
4 | * This file is part of FFmpeg.
5 | *
6 | * FFmpeg is free software; you can redistribute it and/or
7 | * modify it under the terms of the GNU Lesser General Public
8 | * License as published by the Free Software Foundation; either
9 | * version 2.1 of the License, or (at your option) any later version.
10 | *
11 | * FFmpeg is distributed in the hope that it will be useful,
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 | * Lesser General Public License for more details.
15 | *
16 | * You should have received a copy of the GNU Lesser General Public
17 | * License along with FFmpeg; if not, write to the Free Software
18 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19 | */
20 |
21 | /**
22 | * @file
23 | * byte swapping routines
24 | */
25 |
26 | #ifndef AVUTIL_BSWAP_H
27 | #define AVUTIL_BSWAP_H
28 |
29 | #include
30 | #include "libavutil/avconfig.h"
31 | #include "attributes.h"
32 |
33 | #ifdef HAVE_AV_CONFIG_H
34 |
35 | #include "config.h"
36 |
37 | #if ARCH_AARCH64
38 | # include "aarch64/bswap.h"
39 | #elif ARCH_ARM
40 | # include "arm/bswap.h"
41 | #elif ARCH_AVR32
42 | # include "avr32/bswap.h"
43 | #elif ARCH_SH4
44 | # include "sh4/bswap.h"
45 | #elif ARCH_X86
46 | # include "x86/bswap.h"
47 | #endif
48 |
49 | #endif /* HAVE_AV_CONFIG_H */
50 |
51 | #define AV_BSWAP16C(x) (((x) << 8 & 0xff00) | ((x) >> 8 & 0x00ff))
52 | #define AV_BSWAP32C(x) (AV_BSWAP16C(x) << 16 | AV_BSWAP16C((x) >> 16))
53 | #define AV_BSWAP64C(x) (AV_BSWAP32C(x) << 32 | AV_BSWAP32C((x) >> 32))
54 |
55 | #define AV_BSWAPC(s, x) AV_BSWAP##s##C(x)
56 |
57 | #ifndef av_bswap16
58 | static av_always_inline av_const uint16_t av_bswap16(uint16_t x)
59 | {
60 | x= (x>>8) | (x<<8);
61 | return x;
62 | }
63 | #endif
64 |
65 | #ifndef av_bswap32
66 | static av_always_inline av_const uint32_t av_bswap32(uint32_t x)
67 | {
68 | return AV_BSWAP32C(x);
69 | }
70 | #endif
71 |
72 | #ifndef av_bswap64
73 | static inline uint64_t av_const av_bswap64(uint64_t x)
74 | {
75 | return (uint64_t)av_bswap32(x) << 32 | av_bswap32(x >> 32);
76 | }
77 | #endif
78 |
79 | // be2ne ... big-endian to native-endian
80 | // le2ne ... little-endian to native-endian
81 |
82 | #if AV_HAVE_BIGENDIAN
83 | #define av_be2ne16(x) (x)
84 | #define av_be2ne32(x) (x)
85 | #define av_be2ne64(x) (x)
86 | #define av_le2ne16(x) av_bswap16(x)
87 | #define av_le2ne32(x) av_bswap32(x)
88 | #define av_le2ne64(x) av_bswap64(x)
89 | #define AV_BE2NEC(s, x) (x)
90 | #define AV_LE2NEC(s, x) AV_BSWAPC(s, x)
91 | #else
92 | #define av_be2ne16(x) av_bswap16(x)
93 | #define av_be2ne32(x) av_bswap32(x)
94 | #define av_be2ne64(x) av_bswap64(x)
95 | #define av_le2ne16(x) (x)
96 | #define av_le2ne32(x) (x)
97 | #define av_le2ne64(x) (x)
98 | #define AV_BE2NEC(s, x) AV_BSWAPC(s, x)
99 | #define AV_LE2NEC(s, x) (x)
100 | #endif
101 |
102 | #define AV_BE2NE16C(x) AV_BE2NEC(16, x)
103 | #define AV_BE2NE32C(x) AV_BE2NEC(32, x)
104 | #define AV_BE2NE64C(x) AV_BE2NEC(64, x)
105 | #define AV_LE2NE16C(x) AV_LE2NEC(16, x)
106 | #define AV_LE2NE32C(x) AV_LE2NEC(32, x)
107 | #define AV_LE2NE64C(x) AV_LE2NEC(64, x)
108 |
109 | #endif /* AVUTIL_BSWAP_H */
110 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavutil/camellia.h:
--------------------------------------------------------------------------------
1 | /*
2 | * An implementation of the CAMELLIA algorithm as mentioned in RFC3713
3 | * Copyright (c) 2014 Supraja Meedinti
4 | *
5 | * This file is part of FFmpeg.
6 | *
7 | * FFmpeg is free software; you can redistribute it and/or
8 | * modify it under the terms of the GNU Lesser General Public
9 | * License as published by the Free Software Foundation; either
10 | * version 2.1 of the License, or (at your option) any later version.
11 | *
12 | * FFmpeg is distributed in the hope that it will be useful,
13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 | * Lesser General Public License for more details.
16 | *
17 | * You should have received a copy of the GNU Lesser General Public
18 | * License along with FFmpeg; if not, write to the Free Software
19 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20 | */
21 |
22 | #ifndef AVUTIL_CAMELLIA_H
23 | #define AVUTIL_CAMELLIA_H
24 |
25 | #include
26 |
27 |
28 | /**
29 | * @file
30 | * @brief Public header for libavutil CAMELLIA algorithm
31 | * @defgroup lavu_camellia CAMELLIA
32 | * @ingroup lavu_crypto
33 | * @{
34 | */
35 |
36 | extern const int av_camellia_size;
37 |
38 | struct AVCAMELLIA;
39 |
40 | /**
41 | * Allocate an AVCAMELLIA context
42 | * To free the struct: av_free(ptr)
43 | */
44 | struct AVCAMELLIA *av_camellia_alloc(void);
45 |
46 | /**
47 | * Initialize an AVCAMELLIA context.
48 | *
49 | * @param ctx an AVCAMELLIA context
50 | * @param key a key of 16, 24, 32 bytes used for encryption/decryption
51 | * @param key_bits number of keybits: possible are 128, 192, 256
52 | */
53 | int av_camellia_init(struct AVCAMELLIA *ctx, const uint8_t *key, int key_bits);
54 |
55 | /**
56 | * Encrypt or decrypt a buffer using a previously initialized context
57 | *
58 | * @param ctx an AVCAMELLIA context
59 | * @param dst destination array, can be equal to src
60 | * @param src source array, can be equal to dst
61 | * @param count number of 16 byte blocks
62 | * @paran iv initialization vector for CBC mode, NULL for ECB mode
63 | * @param decrypt 0 for encryption, 1 for decryption
64 | */
65 | void av_camellia_crypt(struct AVCAMELLIA *ctx, uint8_t *dst, const uint8_t *src, int count, uint8_t* iv, int decrypt);
66 |
67 | /**
68 | * @}
69 | */
70 | #endif /* AVUTIL_CAMELLIA_H */
71 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavutil/cast5.h:
--------------------------------------------------------------------------------
1 | /*
2 | * An implementation of the CAST128 algorithm as mentioned in RFC2144
3 | * Copyright (c) 2014 Supraja Meedinti
4 | *
5 | * This file is part of FFmpeg.
6 | *
7 | * FFmpeg is free software; you can redistribute it and/or
8 | * modify it under the terms of the GNU Lesser General Public
9 | * License as published by the Free Software Foundation; either
10 | * version 2.1 of the License, or (at your option) any later version.
11 | *
12 | * FFmpeg is distributed in the hope that it will be useful,
13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 | * Lesser General Public License for more details.
16 | *
17 | * You should have received a copy of the GNU Lesser General Public
18 | * License along with FFmpeg; if not, write to the Free Software
19 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20 | */
21 |
22 | #ifndef AVUTIL_CAST5_H
23 | #define AVUTIL_CAST5_H
24 |
25 | #include
26 |
27 |
28 | /**
29 | * @file
30 | * @brief Public header for libavutil CAST5 algorithm
31 | * @defgroup lavu_cast5 CAST5
32 | * @ingroup lavu_crypto
33 | * @{
34 | */
35 |
36 | extern const int av_cast5_size;
37 |
38 | struct AVCAST5;
39 |
40 | /**
41 | * Allocate an AVCAST5 context
42 | * To free the struct: av_free(ptr)
43 | */
44 | struct AVCAST5 *av_cast5_alloc(void);
45 | /**
46 | * Initialize an AVCAST5 context.
47 | *
48 | * @param ctx an AVCAST5 context
49 | * @param key a key of 5,6,...16 bytes used for encryption/decryption
50 | * @param key_bits number of keybits: possible are 40,48,...,128
51 | * @return 0 on success, less than 0 on failure
52 | */
53 | int av_cast5_init(struct AVCAST5 *ctx, const uint8_t *key, int key_bits);
54 |
55 | /**
56 | * Encrypt or decrypt a buffer using a previously initialized context, ECB mode only
57 | *
58 | * @param ctx an AVCAST5 context
59 | * @param dst destination array, can be equal to src
60 | * @param src source array, can be equal to dst
61 | * @param count number of 8 byte blocks
62 | * @param decrypt 0 for encryption, 1 for decryption
63 | */
64 | void av_cast5_crypt(struct AVCAST5 *ctx, uint8_t *dst, const uint8_t *src, int count, int decrypt);
65 |
66 | /**
67 | * Encrypt or decrypt a buffer using a previously initialized context
68 | *
69 | * @param ctx an AVCAST5 context
70 | * @param dst destination array, can be equal to src
71 | * @param src source array, can be equal to dst
72 | * @param count number of 8 byte blocks
73 | * @param iv initialization vector for CBC mode, NULL for ECB mode
74 | * @param decrypt 0 for encryption, 1 for decryption
75 | */
76 | void av_cast5_crypt2(struct AVCAST5 *ctx, uint8_t *dst, const uint8_t *src, int count, uint8_t *iv, int decrypt);
77 | /**
78 | * @}
79 | */
80 | #endif /* AVUTIL_CAST5_H */
81 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavutil/crc.h:
--------------------------------------------------------------------------------
1 | /*
2 | * copyright (c) 2006 Michael Niedermayer
3 | *
4 | * This file is part of FFmpeg.
5 | *
6 | * FFmpeg is free software; you can redistribute it and/or
7 | * modify it under the terms of the GNU Lesser General Public
8 | * License as published by the Free Software Foundation; either
9 | * version 2.1 of the License, or (at your option) any later version.
10 | *
11 | * FFmpeg is distributed in the hope that it will be useful,
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 | * Lesser General Public License for more details.
15 | *
16 | * You should have received a copy of the GNU Lesser General Public
17 | * License along with FFmpeg; if not, write to the Free Software
18 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19 | */
20 |
21 | /**
22 | * @file
23 | * @ingroup lavu_crc32
24 | * Public header for CRC hash function implementation.
25 | */
26 |
27 | #ifndef AVUTIL_CRC_H
28 | #define AVUTIL_CRC_H
29 |
30 | #include
31 | #include
32 | #include "attributes.h"
33 | #include "version.h"
34 |
35 | /**
36 | * @defgroup lavu_crc32 CRC
37 | * @ingroup lavu_hash
38 | * CRC (Cyclic Redundancy Check) hash function implementation.
39 | *
40 | * This module supports numerous CRC polynomials, in addition to the most
41 | * widely used CRC-32-IEEE. See @ref AVCRCId for a list of available
42 | * polynomials.
43 | *
44 | * @{
45 | */
46 |
47 | typedef uint32_t AVCRC;
48 |
49 | typedef enum {
50 | AV_CRC_8_ATM,
51 | AV_CRC_16_ANSI,
52 | AV_CRC_16_CCITT,
53 | AV_CRC_32_IEEE,
54 | AV_CRC_32_IEEE_LE, /*< reversed bitorder version of AV_CRC_32_IEEE */
55 | AV_CRC_16_ANSI_LE, /*< reversed bitorder version of AV_CRC_16_ANSI */
56 | #if FF_API_CRC_BIG_TABLE
57 | AV_CRC_24_IEEE = 12,
58 | #else
59 | AV_CRC_24_IEEE,
60 | #endif /* FF_API_CRC_BIG_TABLE */
61 | AV_CRC_MAX, /*< Not part of public API! Do not use outside libavutil. */
62 | }AVCRCId;
63 |
64 | /**
65 | * Initialize a CRC table.
66 | * @param ctx must be an array of size sizeof(AVCRC)*257 or sizeof(AVCRC)*1024
67 | * @param le If 1, the lowest bit represents the coefficient for the highest
68 | * exponent of the corresponding polynomial (both for poly and
69 | * actual CRC).
70 | * If 0, you must swap the CRC parameter and the result of av_crc
71 | * if you need the standard representation (can be simplified in
72 | * most cases to e.g. bswap16):
73 | * av_bswap32(crc << (32-bits))
74 | * @param bits number of bits for the CRC
75 | * @param poly generator polynomial without the x**bits coefficient, in the
76 | * representation as specified by le
77 | * @param ctx_size size of ctx in bytes
78 | * @return <0 on failure
79 | */
80 | int av_crc_init(AVCRC *ctx, int le, int bits, uint32_t poly, int ctx_size);
81 |
82 | /**
83 | * Get an initialized standard CRC table.
84 | * @param crc_id ID of a standard CRC
85 | * @return a pointer to the CRC table or NULL on failure
86 | */
87 | const AVCRC *av_crc_get_table(AVCRCId crc_id);
88 |
89 | /**
90 | * Calculate the CRC of a block.
91 | * @param crc CRC of previous blocks if any or initial value for CRC
92 | * @return CRC updated with the data from the given block
93 | *
94 | * @see av_crc_init() "le" parameter
95 | */
96 | uint32_t av_crc(const AVCRC *ctx, uint32_t crc,
97 | const uint8_t *buffer, size_t length) av_pure;
98 |
99 | /**
100 | * @}
101 | */
102 |
103 | #endif /* AVUTIL_CRC_H */
104 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavutil/des.h:
--------------------------------------------------------------------------------
1 | /*
2 | * DES encryption/decryption
3 | * Copyright (c) 2007 Reimar Doeffinger
4 | *
5 | * This file is part of FFmpeg.
6 | *
7 | * FFmpeg is free software; you can redistribute it and/or
8 | * modify it under the terms of the GNU Lesser General Public
9 | * License as published by the Free Software Foundation; either
10 | * version 2.1 of the License, or (at your option) any later version.
11 | *
12 | * FFmpeg is distributed in the hope that it will be useful,
13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 | * Lesser General Public License for more details.
16 | *
17 | * You should have received a copy of the GNU Lesser General Public
18 | * License along with FFmpeg; if not, write to the Free Software
19 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20 | */
21 |
22 | #ifndef AVUTIL_DES_H
23 | #define AVUTIL_DES_H
24 |
25 | #include
26 |
27 | /**
28 | * @defgroup lavu_des DES
29 | * @ingroup lavu_crypto
30 | * @{
31 | */
32 |
33 | typedef struct AVDES {
34 | uint64_t round_keys[3][16];
35 | int triple_des;
36 | } AVDES;
37 |
38 | /**
39 | * Allocate an AVDES context.
40 | */
41 | AVDES *av_des_alloc(void);
42 |
43 | /**
44 | * @brief Initializes an AVDES context.
45 | *
46 | * @param key_bits must be 64 or 192
47 | * @param decrypt 0 for encryption/CBC-MAC, 1 for decryption
48 | * @return zero on success, negative value otherwise
49 | */
50 | int av_des_init(struct AVDES *d, const uint8_t *key, int key_bits, int decrypt);
51 |
52 | /**
53 | * @brief Encrypts / decrypts using the DES algorithm.
54 | *
55 | * @param count number of 8 byte blocks
56 | * @param dst destination array, can be equal to src, must be 8-byte aligned
57 | * @param src source array, can be equal to dst, must be 8-byte aligned, may be NULL
58 | * @param iv initialization vector for CBC mode, if NULL then ECB will be used,
59 | * must be 8-byte aligned
60 | * @param decrypt 0 for encryption, 1 for decryption
61 | */
62 | void av_des_crypt(struct AVDES *d, uint8_t *dst, const uint8_t *src, int count, uint8_t *iv, int decrypt);
63 |
64 | /**
65 | * @brief Calculates CBC-MAC using the DES algorithm.
66 | *
67 | * @param count number of 8 byte blocks
68 | * @param dst destination array, can be equal to src, must be 8-byte aligned
69 | * @param src source array, can be equal to dst, must be 8-byte aligned, may be NULL
70 | */
71 | void av_des_mac(struct AVDES *d, uint8_t *dst, const uint8_t *src, int count);
72 |
73 | /**
74 | * @}
75 | */
76 |
77 | #endif /* AVUTIL_DES_H */
78 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavutil/display.h:
--------------------------------------------------------------------------------
1 | /*
2 | * Copyright (c) 2014 Vittorio Giovara
3 | *
4 | * This file is part of FFmpeg.
5 | *
6 | * FFmpeg is free software; you can redistribute it and/or
7 | * modify it under the terms of the GNU Lesser General Public
8 | * License as published by the Free Software Foundation; either
9 | * version 2.1 of the License, or (at your option) any later version.
10 | *
11 | * FFmpeg is distributed in the hope that it will be useful,
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 | * Lesser General Public License for more details.
15 | *
16 | * You should have received a copy of the GNU Lesser General Public
17 | * License along with FFmpeg; if not, write to the Free Software
18 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19 | */
20 |
21 | #ifndef AVUTIL_DISPLAY_H
22 | #define AVUTIL_DISPLAY_H
23 |
24 | #include
25 | #include "common.h"
26 |
27 | /**
28 | * The display transformation matrix specifies an affine transformation that
29 | * should be applied to video frames for correct presentation. It is compatible
30 | * with the matrices stored in the ISO/IEC 14496-12 container format.
31 | *
32 | * The data is a 3x3 matrix represented as a 9-element array:
33 | *
34 | * | a b u |
35 | * (a, b, u, c, d, v, x, y, w) -> | c d v |
36 | * | x y w |
37 | *
38 | * All numbers are stored in native endianness, as 16.16 fixed-point values,
39 | * except for u, v and w, which are stored as 2.30 fixed-point values.
40 | *
41 | * The transformation maps a point (p, q) in the source (pre-transformation)
42 | * frame to the point (p', q') in the destination (post-transformation) frame as
43 | * follows:
44 | * | a b u |
45 | * (p, q, 1) . | c d v | = z * (p', q', 1)
46 | * | x y w |
47 | *
48 | * The transformation can also be more explicitly written in components as
49 | * follows:
50 | * p' = (a * p + c * q + x) / z;
51 | * q' = (b * p + d * q + y) / z;
52 | * z = u * p + v * q + w
53 | */
54 |
55 | /**
56 | * Extract the rotation component of the transformation matrix.
57 | *
58 | * @param matrix the transformation matrix
59 | * @return the angle (in degrees) by which the transformation rotates the frame
60 | * counterclockwise. The angle will be in range [-180.0, 180.0],
61 | * or NaN if the matrix is singular.
62 | *
63 | * @note floating point numbers are inherently inexact, so callers are
64 | * recommended to round the return value to nearest integer before use.
65 | */
66 | double av_display_rotation_get(const int32_t matrix[9]);
67 |
68 | /**
69 | * Initialize a transformation matrix describing a pure counterclockwise
70 | * rotation by the specified angle (in degrees).
71 | *
72 | * @param matrix an allocated transformation matrix (will be fully overwritten
73 | * by this function)
74 | * @param angle rotation angle in degrees.
75 | */
76 | void av_display_rotation_set(int32_t matrix[9], double angle);
77 |
78 | /**
79 | * Flip the input matrix horizontally and/or vertically.
80 | *
81 | * @param matrix an allocated transformation matrix
82 | * @param hflip whether the matrix should be flipped horizontally
83 | * @param vflip whether the matrix should be flipped vertically
84 | */
85 | void av_display_matrix_flip(int32_t matrix[9], int hflip, int vflip);
86 |
87 | #endif /* AVUTIL_DISPLAY_H */
88 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavutil/downmix_info.h:
--------------------------------------------------------------------------------
1 | /*
2 | * Copyright (c) 2014 Tim Walker
3 | *
4 | * This file is part of FFmpeg.
5 | *
6 | * FFmpeg is free software; you can redistribute it and/or
7 | * modify it under the terms of the GNU Lesser General Public
8 | * License as published by the Free Software Foundation; either
9 | * version 2.1 of the License, or (at your option) any later version.
10 | *
11 | * FFmpeg is distributed in the hope that it will be useful,
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 | * Lesser General Public License for more details.
15 | *
16 | * You should have received a copy of the GNU Lesser General Public
17 | * License along with FFmpeg; if not, write to the Free Software
18 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19 | */
20 |
21 | #ifndef AVUTIL_DOWNMIX_INFO_H
22 | #define AVUTIL_DOWNMIX_INFO_H
23 |
24 | #include "frame.h"
25 |
26 | /**
27 | * @file
28 | * audio downmix medatata
29 | */
30 |
31 | /**
32 | * @addtogroup lavu_audio
33 | * @{
34 | */
35 |
36 | /**
37 | * @defgroup downmix_info Audio downmix metadata
38 | * @{
39 | */
40 |
41 | /**
42 | * Possible downmix types.
43 | */
44 | enum AVDownmixType {
45 | AV_DOWNMIX_TYPE_UNKNOWN, /**< Not indicated. */
46 | AV_DOWNMIX_TYPE_LORO, /**< Lo/Ro 2-channel downmix (Stereo). */
47 | AV_DOWNMIX_TYPE_LTRT, /**< Lt/Rt 2-channel downmix, Dolby Surround compatible. */
48 | AV_DOWNMIX_TYPE_DPLII, /**< Lt/Rt 2-channel downmix, Dolby Pro Logic II compatible. */
49 | AV_DOWNMIX_TYPE_NB /**< Number of downmix types. Not part of ABI. */
50 | };
51 |
52 | /**
53 | * This structure describes optional metadata relevant to a downmix procedure.
54 | *
55 | * All fields are set by the decoder to the value indicated in the audio
56 | * bitstream (if present), or to a "sane" default otherwise.
57 | */
58 | typedef struct AVDownmixInfo {
59 | /**
60 | * Type of downmix preferred by the mastering engineer.
61 | */
62 | enum AVDownmixType preferred_downmix_type;
63 |
64 | /**
65 | * Absolute scale factor representing the nominal level of the center
66 | * channel during a regular downmix.
67 | */
68 | double center_mix_level;
69 |
70 | /**
71 | * Absolute scale factor representing the nominal level of the center
72 | * channel during an Lt/Rt compatible downmix.
73 | */
74 | double center_mix_level_ltrt;
75 |
76 | /**
77 | * Absolute scale factor representing the nominal level of the surround
78 | * channels during a regular downmix.
79 | */
80 | double surround_mix_level;
81 |
82 | /**
83 | * Absolute scale factor representing the nominal level of the surround
84 | * channels during an Lt/Rt compatible downmix.
85 | */
86 | double surround_mix_level_ltrt;
87 |
88 | /**
89 | * Absolute scale factor representing the level at which the LFE data is
90 | * mixed into L/R channels during downmixing.
91 | */
92 | double lfe_mix_level;
93 | } AVDownmixInfo;
94 |
95 | /**
96 | * Get a frame's AV_FRAME_DATA_DOWNMIX_INFO side data for editing.
97 | *
98 | * If the side data is absent, it is created and added to the frame.
99 | *
100 | * @param frame the frame for which the side data is to be obtained or created
101 | *
102 | * @return the AVDownmixInfo structure to be edited by the caller, or NULL if
103 | * the structure cannot be allocated.
104 | */
105 | AVDownmixInfo *av_downmix_info_update_side_data(AVFrame *frame);
106 |
107 | /**
108 | * @}
109 | */
110 |
111 | /**
112 | * @}
113 | */
114 |
115 | #endif /* AVUTIL_DOWNMIX_INFO_H */
116 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavutil/ffversion.h:
--------------------------------------------------------------------------------
1 | /* Automatically generated by version.sh, do not manually edit! */
2 | #ifndef AVUTIL_FFVERSION_H
3 | #define AVUTIL_FFVERSION_H
4 | #define FFMPEG_VERSION "3.2.12"
5 | #endif /* AVUTIL_FFVERSION_H */
6 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavutil/file.h:
--------------------------------------------------------------------------------
1 | /*
2 | * This file is part of FFmpeg.
3 | *
4 | * FFmpeg is free software; you can redistribute it and/or
5 | * modify it under the terms of the GNU Lesser General Public
6 | * License as published by the Free Software Foundation; either
7 | * version 2.1 of the License, or (at your option) any later version.
8 | *
9 | * FFmpeg is distributed in the hope that it will be useful,
10 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 | * Lesser General Public License for more details.
13 | *
14 | * You should have received a copy of the GNU Lesser General Public
15 | * License along with FFmpeg; if not, write to the Free Software
16 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17 | */
18 |
19 | #ifndef AVUTIL_FILE_H
20 | #define AVUTIL_FILE_H
21 |
22 | #include
23 |
24 | #include "avutil.h"
25 |
26 | /**
27 | * @file
28 | * Misc file utilities.
29 | */
30 |
31 | /**
32 | * Read the file with name filename, and put its content in a newly
33 | * allocated buffer or map it with mmap() when available.
34 | * In case of success set *bufptr to the read or mmapped buffer, and
35 | * *size to the size in bytes of the buffer in *bufptr.
36 | * The returned buffer must be released with av_file_unmap().
37 | *
38 | * @param log_offset loglevel offset used for logging
39 | * @param log_ctx context used for logging
40 | * @return a non negative number in case of success, a negative value
41 | * corresponding to an AVERROR error code in case of failure
42 | */
43 | av_warn_unused_result
44 | int av_file_map(const char *filename, uint8_t **bufptr, size_t *size,
45 | int log_offset, void *log_ctx);
46 |
47 | /**
48 | * Unmap or free the buffer bufptr created by av_file_map().
49 | *
50 | * @param size size in bytes of bufptr, must be the same as returned
51 | * by av_file_map()
52 | */
53 | void av_file_unmap(uint8_t *bufptr, size_t size);
54 |
55 | /**
56 | * Wrapper to work around the lack of mkstemp() on mingw.
57 | * Also, tries to create file in /tmp first, if possible.
58 | * *prefix can be a character constant; *filename will be allocated internally.
59 | * @return file descriptor of opened file (or negative value corresponding to an
60 | * AVERROR code on error)
61 | * and opened file name in **filename.
62 | * @note On very old libcs it is necessary to set a secure umask before
63 | * calling this, av_tempfile() can't call umask itself as it is used in
64 | * libraries and could interfere with the calling application.
65 | * @deprecated as fd numbers cannot be passed saftely between libs on some platforms
66 | */
67 | int av_tempfile(const char *prefix, char **filename, int log_offset, void *log_ctx);
68 |
69 | #endif /* AVUTIL_FILE_H */
70 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavutil/hmac.h:
--------------------------------------------------------------------------------
1 | /*
2 | * Copyright (C) 2012 Martin Storsjo
3 | *
4 | * This file is part of FFmpeg.
5 | *
6 | * FFmpeg is free software; you can redistribute it and/or
7 | * modify it under the terms of the GNU Lesser General Public
8 | * License as published by the Free Software Foundation; either
9 | * version 2.1 of the License, or (at your option) any later version.
10 | *
11 | * FFmpeg is distributed in the hope that it will be useful,
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 | * Lesser General Public License for more details.
15 | *
16 | * You should have received a copy of the GNU Lesser General Public
17 | * License along with FFmpeg; if not, write to the Free Software
18 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19 | */
20 |
21 | #ifndef AVUTIL_HMAC_H
22 | #define AVUTIL_HMAC_H
23 |
24 | #include
25 |
26 | #include "version.h"
27 | /**
28 | * @defgroup lavu_hmac HMAC
29 | * @ingroup lavu_crypto
30 | * @{
31 | */
32 |
33 | enum AVHMACType {
34 | AV_HMAC_MD5,
35 | AV_HMAC_SHA1,
36 | AV_HMAC_SHA224,
37 | AV_HMAC_SHA256,
38 | AV_HMAC_SHA384 = 12,
39 | AV_HMAC_SHA512,
40 | };
41 |
42 | typedef struct AVHMAC AVHMAC;
43 |
44 | /**
45 | * Allocate an AVHMAC context.
46 | * @param type The hash function used for the HMAC.
47 | */
48 | AVHMAC *av_hmac_alloc(enum AVHMACType type);
49 |
50 | /**
51 | * Free an AVHMAC context.
52 | * @param ctx The context to free, may be NULL
53 | */
54 | void av_hmac_free(AVHMAC *ctx);
55 |
56 | /**
57 | * Initialize an AVHMAC context with an authentication key.
58 | * @param ctx The HMAC context
59 | * @param key The authentication key
60 | * @param keylen The length of the key, in bytes
61 | */
62 | void av_hmac_init(AVHMAC *ctx, const uint8_t *key, unsigned int keylen);
63 |
64 | /**
65 | * Hash data with the HMAC.
66 | * @param ctx The HMAC context
67 | * @param data The data to hash
68 | * @param len The length of the data, in bytes
69 | */
70 | void av_hmac_update(AVHMAC *ctx, const uint8_t *data, unsigned int len);
71 |
72 | /**
73 | * Finish hashing and output the HMAC digest.
74 | * @param ctx The HMAC context
75 | * @param out The output buffer to write the digest into
76 | * @param outlen The length of the out buffer, in bytes
77 | * @return The number of bytes written to out, or a negative error code.
78 | */
79 | int av_hmac_final(AVHMAC *ctx, uint8_t *out, unsigned int outlen);
80 |
81 | /**
82 | * Hash an array of data with a key.
83 | * @param ctx The HMAC context
84 | * @param data The data to hash
85 | * @param len The length of the data, in bytes
86 | * @param key The authentication key
87 | * @param keylen The length of the key, in bytes
88 | * @param out The output buffer to write the digest into
89 | * @param outlen The length of the out buffer, in bytes
90 | * @return The number of bytes written to out, or a negative error code.
91 | */
92 | int av_hmac_calc(AVHMAC *ctx, const uint8_t *data, unsigned int len,
93 | const uint8_t *key, unsigned int keylen,
94 | uint8_t *out, unsigned int outlen);
95 |
96 | /**
97 | * @}
98 | */
99 |
100 | #endif /* AVUTIL_HMAC_H */
101 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavutil/hwcontext_cuda.h:
--------------------------------------------------------------------------------
1 | /*
2 | * This file is part of FFmpeg.
3 | *
4 | * FFmpeg is free software; you can redistribute it and/or
5 | * modify it under the terms of the GNU Lesser General Public
6 | * License as published by the Free Software Foundation; either
7 | * version 2.1 of the License, or (at your option) any later version.
8 | *
9 | * FFmpeg is distributed in the hope that it will be useful,
10 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 | * Lesser General Public License for more details.
13 | *
14 | * You should have received a copy of the GNU Lesser General Public
15 | * License along with FFmpeg; if not, write to the Free Software
16 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17 | */
18 |
19 |
20 | #ifndef AVUTIL_HWCONTEXT_CUDA_H
21 | #define AVUTIL_HWCONTEXT_CUDA_H
22 |
23 | #include
24 |
25 | #include "pixfmt.h"
26 |
27 | /**
28 | * @file
29 | * An API-specific header for AV_HWDEVICE_TYPE_CUDA.
30 | *
31 | * This API supports dynamic frame pools. AVHWFramesContext.pool must return
32 | * AVBufferRefs whose data pointer is a CUdeviceptr.
33 | */
34 |
35 | /**
36 | * This struct is allocated as AVHWDeviceContext.hwctx
37 | */
38 | typedef struct AVCUDADeviceContext {
39 | CUcontext cuda_ctx;
40 | } AVCUDADeviceContext;
41 |
42 | /**
43 | * AVHWFramesContext.hwctx is currently not used
44 | */
45 |
46 | #endif /* AVUTIL_HWCONTEXT_CUDA_H */
47 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavutil/hwcontext_dxva2.h:
--------------------------------------------------------------------------------
1 | /*
2 | * This file is part of FFmpeg.
3 | *
4 | * FFmpeg is free software; you can redistribute it and/or
5 | * modify it under the terms of the GNU Lesser General Public
6 | * License as published by the Free Software Foundation; either
7 | * version 2.1 of the License, or (at your option) any later version.
8 | *
9 | * FFmpeg is distributed in the hope that it will be useful,
10 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 | * Lesser General Public License for more details.
13 | *
14 | * You should have received a copy of the GNU Lesser General Public
15 | * License along with FFmpeg; if not, write to the Free Software
16 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17 | */
18 |
19 |
20 | #ifndef AVUTIL_HWCONTEXT_DXVA2_H
21 | #define AVUTIL_HWCONTEXT_DXVA2_H
22 |
23 | /**
24 | * @file
25 | * An API-specific header for AV_HWDEVICE_TYPE_DXVA2.
26 | *
27 | * Only fixed-size pools are supported.
28 | *
29 | * For user-allocated pools, AVHWFramesContext.pool must return AVBufferRefs
30 | * with the data pointer set to a pointer to IDirect3DSurface9.
31 | */
32 |
33 | #include
34 | #include
35 |
36 | /**
37 | * This struct is allocated as AVHWDeviceContext.hwctx
38 | */
39 | typedef struct AVDXVA2DeviceContext {
40 | IDirect3DDeviceManager9 *devmgr;
41 | } AVDXVA2DeviceContext;
42 |
43 | /**
44 | * This struct is allocated as AVHWFramesContext.hwctx
45 | */
46 | typedef struct AVDXVA2FramesContext {
47 | /**
48 | * The surface type (e.g. DXVA2_VideoProcessorRenderTarget or
49 | * DXVA2_VideoDecoderRenderTarget). Must be set by the caller.
50 | */
51 | DWORD surface_type;
52 |
53 | /**
54 | * The surface pool. When an external pool is not provided by the caller,
55 | * this will be managed (allocated and filled on init, freed on uninit) by
56 | * libavutil.
57 | */
58 | IDirect3DSurface9 **surfaces;
59 | int nb_surfaces;
60 |
61 | /**
62 | * Certain drivers require the decoder to be destroyed before the surfaces.
63 | * To allow internally managed pools to work properly in such cases, this
64 | * field is provided.
65 | *
66 | * If it is non-NULL, libavutil will call IDirectXVideoDecoder_Release() on
67 | * it just before the internal surface pool is freed.
68 | */
69 | IDirectXVideoDecoder *decoder_to_release;
70 | } AVDXVA2FramesContext;
71 |
72 | #endif /* AVUTIL_HWCONTEXT_DXVA2_H */
73 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavutil/hwcontext_qsv.h:
--------------------------------------------------------------------------------
1 | /*
2 | * This file is part of FFmpeg.
3 | *
4 | * FFmpeg is free software; you can redistribute it and/or
5 | * modify it under the terms of the GNU Lesser General Public
6 | * License as published by the Free Software Foundation; either
7 | * version 2.1 of the License, or (at your option) any later version.
8 | *
9 | * FFmpeg is distributed in the hope that it will be useful,
10 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 | * Lesser General Public License for more details.
13 | *
14 | * You should have received a copy of the GNU Lesser General Public
15 | * License along with FFmpeg; if not, write to the Free Software
16 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17 | */
18 |
19 | #ifndef AVUTIL_HWCONTEXT_QSV_H
20 | #define AVUTIL_HWCONTEXT_QSV_H
21 |
22 | #include
23 |
24 | /**
25 | * @file
26 | * An API-specific header for AV_HWDEVICE_TYPE_QSV.
27 | *
28 | * This API does not support dynamic frame pools. AVHWFramesContext.pool must
29 | * contain AVBufferRefs whose data pointer points to an mfxFrameSurface1 struct.
30 | */
31 |
32 | /**
33 | * This struct is allocated as AVHWDeviceContext.hwctx
34 | */
35 | typedef struct AVQSVDeviceContext {
36 | mfxSession session;
37 | } AVQSVDeviceContext;
38 |
39 | /**
40 | * This struct is allocated as AVHWFramesContext.hwctx
41 | */
42 | typedef struct AVQSVFramesContext {
43 | mfxFrameSurface1 *surfaces;
44 | int nb_surfaces;
45 |
46 | /**
47 | * A combination of MFX_MEMTYPE_* describing the frame pool.
48 | */
49 | int frame_type;
50 | } AVQSVFramesContext;
51 |
52 | #endif /* AVUTIL_HWCONTEXT_QSV_H */
53 |
54 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavutil/hwcontext_vaapi.h:
--------------------------------------------------------------------------------
1 | /*
2 | * This file is part of FFmpeg.
3 | *
4 | * FFmpeg is free software; you can redistribute it and/or
5 | * modify it under the terms of the GNU Lesser General Public
6 | * License as published by the Free Software Foundation; either
7 | * version 2.1 of the License, or (at your option) any later version.
8 | *
9 | * FFmpeg is distributed in the hope that it will be useful,
10 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 | * Lesser General Public License for more details.
13 | *
14 | * You should have received a copy of the GNU Lesser General Public
15 | * License along with FFmpeg; if not, write to the Free Software
16 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17 | */
18 |
19 | #ifndef AVUTIL_HWCONTEXT_VAAPI_H
20 | #define AVUTIL_HWCONTEXT_VAAPI_H
21 |
22 | #include
23 |
24 | /**
25 | * @file
26 | * API-specific header for AV_HWDEVICE_TYPE_VAAPI.
27 | *
28 | * Dynamic frame pools are supported, but note that any pool used as a render
29 | * target is required to be of fixed size in order to be be usable as an
30 | * argument to vaCreateContext().
31 | *
32 | * For user-allocated pools, AVHWFramesContext.pool must return AVBufferRefs
33 | * with the data pointer set to a VASurfaceID.
34 | */
35 |
36 | /**
37 | * VAAPI connection details.
38 | *
39 | * Allocated as AVHWDeviceContext.hwctx
40 | */
41 | typedef struct AVVAAPIDeviceContext {
42 | /**
43 | * The VADisplay handle, to be filled by the user.
44 | */
45 | VADisplay display;
46 | } AVVAAPIDeviceContext;
47 |
48 | /**
49 | * VAAPI-specific data associated with a frame pool.
50 | *
51 | * Allocated as AVHWFramesContext.hwctx.
52 | */
53 | typedef struct AVVAAPIFramesContext {
54 | /**
55 | * Set by the user to apply surface attributes to all surfaces in
56 | * the frame pool. If null, default settings are used.
57 | */
58 | VASurfaceAttrib *attributes;
59 | int nb_attributes;
60 | /**
61 | * The surfaces IDs of all surfaces in the pool after creation.
62 | * Only valid if AVHWFramesContext.initial_pool_size was positive.
63 | * These are intended to be used as the render_targets arguments to
64 | * vaCreateContext().
65 | */
66 | VASurfaceID *surface_ids;
67 | int nb_surfaces;
68 | } AVVAAPIFramesContext;
69 |
70 | /**
71 | * VAAPI hardware pipeline configuration details.
72 | *
73 | * Allocated with av_hwdevice_hwconfig_alloc().
74 | */
75 | typedef struct AVVAAPIHWConfig {
76 | /**
77 | * ID of a VAAPI pipeline configuration.
78 | */
79 | VAConfigID config_id;
80 | } AVVAAPIHWConfig;
81 |
82 | #endif /* AVUTIL_HWCONTEXT_VAAPI_H */
83 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavutil/hwcontext_vdpau.h:
--------------------------------------------------------------------------------
1 | /*
2 | * This file is part of FFmpeg.
3 | *
4 | * FFmpeg is free software; you can redistribute it and/or
5 | * modify it under the terms of the GNU Lesser General Public
6 | * License as published by the Free Software Foundation; either
7 | * version 2.1 of the License, or (at your option) any later version.
8 | *
9 | * FFmpeg is distributed in the hope that it will be useful,
10 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 | * Lesser General Public License for more details.
13 | *
14 | * You should have received a copy of the GNU Lesser General Public
15 | * License along with FFmpeg; if not, write to the Free Software
16 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17 | */
18 |
19 | #ifndef AVUTIL_HWCONTEXT_VDPAU_H
20 | #define AVUTIL_HWCONTEXT_VDPAU_H
21 |
22 | #include
23 |
24 | /**
25 | * @file
26 | * An API-specific header for AV_HWDEVICE_TYPE_VDPAU.
27 | *
28 | * This API supports dynamic frame pools. AVHWFramesContext.pool must return
29 | * AVBufferRefs whose data pointer is a VdpVideoSurface.
30 | */
31 |
32 | /**
33 | * This struct is allocated as AVHWDeviceContext.hwctx
34 | */
35 | typedef struct AVVDPAUDeviceContext {
36 | VdpDevice device;
37 | VdpGetProcAddress *get_proc_address;
38 | } AVVDPAUDeviceContext;
39 |
40 | /**
41 | * AVHWFramesContext.hwctx is currently not used
42 | */
43 |
44 | #endif /* AVUTIL_HWCONTEXT_VDPAU_H */
45 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavutil/intfloat.h:
--------------------------------------------------------------------------------
1 | /*
2 | * Copyright (c) 2011 Mans Rullgard
3 | *
4 | * This file is part of FFmpeg.
5 | *
6 | * FFmpeg is free software; you can redistribute it and/or
7 | * modify it under the terms of the GNU Lesser General Public
8 | * License as published by the Free Software Foundation; either
9 | * version 2.1 of the License, or (at your option) any later version.
10 | *
11 | * FFmpeg is distributed in the hope that it will be useful,
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 | * Lesser General Public License for more details.
15 | *
16 | * You should have received a copy of the GNU Lesser General Public
17 | * License along with FFmpeg; if not, write to the Free Software
18 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19 | */
20 |
21 | #ifndef AVUTIL_INTFLOAT_H
22 | #define AVUTIL_INTFLOAT_H
23 |
24 | #include
25 | #include "attributes.h"
26 |
27 | union av_intfloat32 {
28 | uint32_t i;
29 | float f;
30 | };
31 |
32 | union av_intfloat64 {
33 | uint64_t i;
34 | double f;
35 | };
36 |
37 | /**
38 | * Reinterpret a 32-bit integer as a float.
39 | */
40 | static av_always_inline float av_int2float(uint32_t i)
41 | {
42 | union av_intfloat32 v;
43 | v.i = i;
44 | return v.f;
45 | }
46 |
47 | /**
48 | * Reinterpret a float as a 32-bit integer.
49 | */
50 | static av_always_inline uint32_t av_float2int(float f)
51 | {
52 | union av_intfloat32 v;
53 | v.f = f;
54 | return v.i;
55 | }
56 |
57 | /**
58 | * Reinterpret a 64-bit integer as a double.
59 | */
60 | static av_always_inline double av_int2double(uint64_t i)
61 | {
62 | union av_intfloat64 v;
63 | v.i = i;
64 | return v.f;
65 | }
66 |
67 | /**
68 | * Reinterpret a double as a 64-bit integer.
69 | */
70 | static av_always_inline uint64_t av_double2int(double f)
71 | {
72 | union av_intfloat64 v;
73 | v.f = f;
74 | return v.i;
75 | }
76 |
77 | #endif /* AVUTIL_INTFLOAT_H */
78 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavutil/lfg.h:
--------------------------------------------------------------------------------
1 | /*
2 | * Lagged Fibonacci PRNG
3 | * Copyright (c) 2008 Michael Niedermayer
4 | *
5 | * This file is part of FFmpeg.
6 | *
7 | * FFmpeg is free software; you can redistribute it and/or
8 | * modify it under the terms of the GNU Lesser General Public
9 | * License as published by the Free Software Foundation; either
10 | * version 2.1 of the License, or (at your option) any later version.
11 | *
12 | * FFmpeg is distributed in the hope that it will be useful,
13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 | * Lesser General Public License for more details.
16 | *
17 | * You should have received a copy of the GNU Lesser General Public
18 | * License along with FFmpeg; if not, write to the Free Software
19 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20 | */
21 |
22 | #ifndef AVUTIL_LFG_H
23 | #define AVUTIL_LFG_H
24 |
25 | typedef struct AVLFG {
26 | unsigned int state[64];
27 | int index;
28 | } AVLFG;
29 |
30 | void av_lfg_init(AVLFG *c, unsigned int seed);
31 |
32 | /**
33 | * Get the next random unsigned 32-bit number using an ALFG.
34 | *
35 | * Please also consider a simple LCG like state= state*1664525+1013904223,
36 | * it may be good enough and faster for your specific use case.
37 | */
38 | static inline unsigned int av_lfg_get(AVLFG *c){
39 | c->state[c->index & 63] = c->state[(c->index-24) & 63] + c->state[(c->index-55) & 63];
40 | return c->state[c->index++ & 63];
41 | }
42 |
43 | /**
44 | * Get the next random unsigned 32-bit number using a MLFG.
45 | *
46 | * Please also consider av_lfg_get() above, it is faster.
47 | */
48 | static inline unsigned int av_mlfg_get(AVLFG *c){
49 | unsigned int a= c->state[(c->index-55) & 63];
50 | unsigned int b= c->state[(c->index-24) & 63];
51 | return c->state[c->index++ & 63] = 2*a*b+a+b;
52 | }
53 |
54 | /**
55 | * Get the next two numbers generated by a Box-Muller Gaussian
56 | * generator using the random numbers issued by lfg.
57 | *
58 | * @param out array where the two generated numbers are placed
59 | */
60 | void av_bmg_get(AVLFG *lfg, double out[2]);
61 |
62 | #endif /* AVUTIL_LFG_H */
63 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavutil/lzo.h:
--------------------------------------------------------------------------------
1 | /*
2 | * LZO 1x decompression
3 | * copyright (c) 2006 Reimar Doeffinger
4 | *
5 | * This file is part of FFmpeg.
6 | *
7 | * FFmpeg is free software; you can redistribute it and/or
8 | * modify it under the terms of the GNU Lesser General Public
9 | * License as published by the Free Software Foundation; either
10 | * version 2.1 of the License, or (at your option) any later version.
11 | *
12 | * FFmpeg is distributed in the hope that it will be useful,
13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 | * Lesser General Public License for more details.
16 | *
17 | * You should have received a copy of the GNU Lesser General Public
18 | * License along with FFmpeg; if not, write to the Free Software
19 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20 | */
21 |
22 | #ifndef AVUTIL_LZO_H
23 | #define AVUTIL_LZO_H
24 |
25 | /**
26 | * @defgroup lavu_lzo LZO
27 | * @ingroup lavu_crypto
28 | *
29 | * @{
30 | */
31 |
32 | #include
33 |
34 | /** @name Error flags returned by av_lzo1x_decode
35 | * @{ */
36 | /// end of the input buffer reached before decoding finished
37 | #define AV_LZO_INPUT_DEPLETED 1
38 | /// decoded data did not fit into output buffer
39 | #define AV_LZO_OUTPUT_FULL 2
40 | /// a reference to previously decoded data was wrong
41 | #define AV_LZO_INVALID_BACKPTR 4
42 | /// a non-specific error in the compressed bitstream
43 | #define AV_LZO_ERROR 8
44 | /** @} */
45 |
46 | #define AV_LZO_INPUT_PADDING 8
47 | #define AV_LZO_OUTPUT_PADDING 12
48 |
49 | /**
50 | * @brief Decodes LZO 1x compressed data.
51 | * @param out output buffer
52 | * @param outlen size of output buffer, number of bytes left are returned here
53 | * @param in input buffer
54 | * @param inlen size of input buffer, number of bytes left are returned here
55 | * @return 0 on success, otherwise a combination of the error flags above
56 | *
57 | * Make sure all buffers are appropriately padded, in must provide
58 | * AV_LZO_INPUT_PADDING, out must provide AV_LZO_OUTPUT_PADDING additional bytes.
59 | */
60 | int av_lzo1x_decode(void *out, int *outlen, const void *in, int *inlen);
61 |
62 | /**
63 | * @}
64 | */
65 |
66 | #endif /* AVUTIL_LZO_H */
67 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavutil/macros.h:
--------------------------------------------------------------------------------
1 | /*
2 | * This file is part of FFmpeg.
3 | *
4 | * FFmpeg is free software; you can redistribute it and/or
5 | * modify it under the terms of the GNU Lesser General Public
6 | * License as published by the Free Software Foundation; either
7 | * version 2.1 of the License, or (at your option) any later version.
8 | *
9 | * FFmpeg is distributed in the hope that it will be useful,
10 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 | * Lesser General Public License for more details.
13 | *
14 | * You should have received a copy of the GNU Lesser General Public
15 | * License along with FFmpeg; if not, write to the Free Software
16 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17 | */
18 |
19 | /**
20 | * @file
21 | * @ingroup lavu
22 | * Utility Preprocessor macros
23 | */
24 |
25 | #ifndef AVUTIL_MACROS_H
26 | #define AVUTIL_MACROS_H
27 |
28 | /**
29 | * @addtogroup preproc_misc Preprocessor String Macros
30 | *
31 | * String manipulation macros
32 | *
33 | * @{
34 | */
35 |
36 | #define AV_STRINGIFY(s) AV_TOSTRING(s)
37 | #define AV_TOSTRING(s) #s
38 |
39 | #define AV_GLUE(a, b) a ## b
40 | #define AV_JOIN(a, b) AV_GLUE(a, b)
41 |
42 | /**
43 | * @}
44 | */
45 |
46 | #define AV_PRAGMA(s) _Pragma(#s)
47 |
48 | #define FFALIGN(x, a) (((x)+(a)-1)&~((a)-1))
49 |
50 | #endif /* AVUTIL_MACROS_H */
51 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavutil/mastering_display_metadata.h:
--------------------------------------------------------------------------------
1 | /**
2 | * Copyright (c) 2016 Neil Birkbeck
3 | *
4 | * This file is part of FFmpeg.
5 | *
6 | * FFmpeg is free software; you can redistribute it and/or
7 | * modify it under the terms of the GNU Lesser General Public
8 | * License as published by the Free Software Foundation; either
9 | * version 2.1 of the License, or (at your option) any later version.
10 | *
11 | * FFmpeg is distributed in the hope that it will be useful,
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 | * Lesser General Public License for more details.
15 | *
16 | * You should have received a copy of the GNU Lesser General Public
17 | * License along with FFmpeg; if not, write to the Free Software
18 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19 | */
20 |
21 | #ifndef AVUTIL_MASTERING_DISPLAY_METADATA_H
22 | #define AVUTIL_MASTERING_DISPLAY_METADATA_H
23 |
24 | #include "frame.h"
25 | #include "rational.h"
26 |
27 |
28 | /**
29 | * Mastering display metadata capable of representing the color volume of
30 | * the display used to master the content (SMPTE 2086:2014).
31 | *
32 | * To be used as payload of a AVFrameSideData or AVPacketSideData with the
33 | * appropriate type.
34 | *
35 | * @note The struct should be allocated with av_mastering_display_metadata_alloc()
36 | * and its size is not a part of the public ABI.
37 | */
38 | typedef struct AVMasteringDisplayMetadata {
39 | /**
40 | * CIE 1931 xy chromaticity coords of color primaries (r, g, b order).
41 | */
42 | AVRational display_primaries[3][2];
43 |
44 | /**
45 | * CIE 1931 xy chromaticity coords of white point.
46 | */
47 | AVRational white_point[2];
48 |
49 | /**
50 | * Min luminance of mastering display (cd/m^2).
51 | */
52 | AVRational min_luminance;
53 |
54 | /**
55 | * Max luminance of mastering display (cd/m^2).
56 | */
57 | AVRational max_luminance;
58 |
59 | /**
60 | * Flag indicating whether the display primaries (and white point) are set.
61 | */
62 | int has_primaries;
63 |
64 | /**
65 | * Flag indicating whether the luminance (min_ and max_) have been set.
66 | */
67 | int has_luminance;
68 |
69 | } AVMasteringDisplayMetadata;
70 |
71 | /**
72 | * Allocate an AVMasteringDisplayMetadata structure and set its fields to
73 | * default values. The resulting struct can be freed using av_freep().
74 | *
75 | * @return An AVMasteringDisplayMetadata filled with default values or NULL
76 | * on failure.
77 | */
78 | AVMasteringDisplayMetadata *av_mastering_display_metadata_alloc(void);
79 |
80 | /**
81 | * Allocate a complete AVMasteringDisplayMetadata and add it to the frame.
82 | *
83 | * @param frame The frame which side data is added to.
84 | *
85 | * @return The AVMasteringDisplayMetadata structure to be filled by caller.
86 | */
87 | AVMasteringDisplayMetadata *av_mastering_display_metadata_create_side_data(AVFrame *frame);
88 |
89 | #endif /* AVUTIL_MASTERING_DISPLAY_METADATA_H */
90 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavutil/md5.h:
--------------------------------------------------------------------------------
1 | /*
2 | * copyright (c) 2006 Michael Niedermayer
3 | *
4 | * This file is part of FFmpeg.
5 | *
6 | * FFmpeg is free software; you can redistribute it and/or
7 | * modify it under the terms of the GNU Lesser General Public
8 | * License as published by the Free Software Foundation; either
9 | * version 2.1 of the License, or (at your option) any later version.
10 | *
11 | * FFmpeg is distributed in the hope that it will be useful,
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 | * Lesser General Public License for more details.
15 | *
16 | * You should have received a copy of the GNU Lesser General Public
17 | * License along with FFmpeg; if not, write to the Free Software
18 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19 | */
20 |
21 | /**
22 | * @file
23 | * @ingroup lavu_md5
24 | * Public header for MD5 hash function implementation.
25 | */
26 |
27 | #ifndef AVUTIL_MD5_H
28 | #define AVUTIL_MD5_H
29 |
30 | #include
31 |
32 | #include "attributes.h"
33 | #include "version.h"
34 |
35 | /**
36 | * @defgroup lavu_md5 MD5
37 | * @ingroup lavu_hash
38 | * MD5 hash function implementation.
39 | *
40 | * @{
41 | */
42 |
43 | extern const int av_md5_size;
44 |
45 | struct AVMD5;
46 |
47 | /**
48 | * Allocate an AVMD5 context.
49 | */
50 | struct AVMD5 *av_md5_alloc(void);
51 |
52 | /**
53 | * Initialize MD5 hashing.
54 | *
55 | * @param ctx pointer to the function context (of size av_md5_size)
56 | */
57 | void av_md5_init(struct AVMD5 *ctx);
58 |
59 | /**
60 | * Update hash value.
61 | *
62 | * @param ctx hash function context
63 | * @param src input data to update hash with
64 | * @param len input data length
65 | */
66 | void av_md5_update(struct AVMD5 *ctx, const uint8_t *src, int len);
67 |
68 | /**
69 | * Finish hashing and output digest value.
70 | *
71 | * @param ctx hash function context
72 | * @param dst buffer where output digest value is stored
73 | */
74 | void av_md5_final(struct AVMD5 *ctx, uint8_t *dst);
75 |
76 | /**
77 | * Hash an array of data.
78 | *
79 | * @param dst The output buffer to write the digest into
80 | * @param src The data to hash
81 | * @param len The length of the data, in bytes
82 | */
83 | void av_md5_sum(uint8_t *dst, const uint8_t *src, const int len);
84 |
85 | /**
86 | * @}
87 | */
88 |
89 | #endif /* AVUTIL_MD5_H */
90 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavutil/motion_vector.h:
--------------------------------------------------------------------------------
1 | /*
2 | * This file is part of FFmpeg.
3 | *
4 | * FFmpeg is free software; you can redistribute it and/or
5 | * modify it under the terms of the GNU Lesser General Public
6 | * License as published by the Free Software Foundation; either
7 | * version 2.1 of the License, or (at your option) any later version.
8 | *
9 | * FFmpeg is distributed in the hope that it will be useful,
10 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 | * Lesser General Public License for more details.
13 | *
14 | * You should have received a copy of the GNU Lesser General Public
15 | * License along with FFmpeg; if not, write to the Free Software
16 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17 | */
18 |
19 | #ifndef AVUTIL_MOTION_VECTOR_H
20 | #define AVUTIL_MOTION_VECTOR_H
21 |
22 | #include
23 |
24 | typedef struct AVMotionVector {
25 | /**
26 | * Where the current macroblock comes from; negative value when it comes
27 | * from the past, positive value when it comes from the future.
28 | * XXX: set exact relative ref frame reference instead of a +/- 1 "direction".
29 | */
30 | int32_t source;
31 | /**
32 | * Width and height of the block.
33 | */
34 | uint8_t w, h;
35 | /**
36 | * Absolute source position. Can be outside the frame area.
37 | */
38 | int16_t src_x, src_y;
39 | /**
40 | * Absolute destination position. Can be outside the frame area.
41 | */
42 | int16_t dst_x, dst_y;
43 | /**
44 | * Extra flag information.
45 | * Currently unused.
46 | */
47 | uint64_t flags;
48 | /**
49 | * Motion vector
50 | * src_x = dst_x + motion_x / motion_scale
51 | * src_y = dst_y + motion_y / motion_scale
52 | */
53 | int32_t motion_x, motion_y;
54 | uint16_t motion_scale;
55 | } AVMotionVector;
56 |
57 | #endif /* AVUTIL_MOTION_VECTOR_H */
58 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavutil/murmur3.h:
--------------------------------------------------------------------------------
1 | /*
2 | * Copyright (C) 2013 Reimar Döffinger
3 | *
4 | * This file is part of FFmpeg.
5 | *
6 | * FFmpeg is free software; you can redistribute it and/or
7 | * modify it under the terms of the GNU Lesser General Public
8 | * License as published by the Free Software Foundation; either
9 | * version 2.1 of the License, or (at your option) any later version.
10 | *
11 | * FFmpeg is distributed in the hope that it will be useful,
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 | * Lesser General Public License for more details.
15 | *
16 | * You should have received a copy of the GNU Lesser General Public
17 | * License along with FFmpeg; if not, write to the Free Software
18 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19 | */
20 |
21 | /**
22 | * @file
23 | * @ingroup lavu_murmur3
24 | * Public header for MurmurHash3 hash function implementation.
25 | */
26 |
27 | #ifndef AVUTIL_MURMUR3_H
28 | #define AVUTIL_MURMUR3_H
29 |
30 | #include
31 |
32 | /**
33 | * @defgroup lavu_murmur3 Murmur3
34 | * @ingroup lavu_hash
35 | * MurmurHash3 hash function implementation.
36 | *
37 | * MurmurHash3 is a non-cryptographic hash function, of which three
38 | * incompatible versions were created by its inventor Austin Appleby:
39 | *
40 | * - 32-bit output
41 | * - 128-bit output for 32-bit platforms
42 | * - 128-bit output for 64-bit platforms
43 | *
44 | * FFmpeg only implements the last variant: 128-bit output designed for 64-bit
45 | * platforms. Even though the hash function was designed for 64-bit platforms,
46 | * the function in reality works on 32-bit systems too, only with reduced
47 | * performance.
48 | *
49 | * @anchor lavu_murmur3_seedinfo
50 | * By design, MurmurHash3 requires a seed to operate. In response to this,
51 | * libavutil provides two functions for hash initiation, one that requires a
52 | * seed (av_murmur3_init_seeded()) and one that uses a fixed arbitrary integer
53 | * as the seed, and therefore does not (av_murmur3_init()).
54 | *
55 | * To make hashes comparable, you should provide the same seed for all calls to
56 | * this hash function -- if you are supplying one yourself, that is.
57 | *
58 | * @{
59 | */
60 |
61 | /**
62 | * Allocate an AVMurMur3 hash context.
63 | *
64 | * @return Uninitialized hash context or `NULL` in case of error
65 | */
66 | struct AVMurMur3 *av_murmur3_alloc(void);
67 |
68 | /**
69 | * Initialize or reinitialize an AVMurMur3 hash context with a seed.
70 | *
71 | * @param[out] c Hash context
72 | * @param[in] seed Random seed
73 | *
74 | * @see av_murmur3_init()
75 | * @see @ref lavu_murmur3_seedinfo "Detailed description" on a discussion of
76 | * seeds for MurmurHash3.
77 | */
78 | void av_murmur3_init_seeded(struct AVMurMur3 *c, uint64_t seed);
79 |
80 | /**
81 | * Initialize or reinitialize an AVMurMur3 hash context.
82 | *
83 | * Equivalent to av_murmur3_init_seeded() with a built-in seed.
84 | *
85 | * @param[out] c Hash context
86 | *
87 | * @see av_murmur3_init_seeded()
88 | * @see @ref lavu_murmur3_seedinfo "Detailed description" on a discussion of
89 | * seeds for MurmurHash3.
90 | */
91 | void av_murmur3_init(struct AVMurMur3 *c);
92 |
93 | /**
94 | * Update hash context with new data.
95 | *
96 | * @param[out] c Hash context
97 | * @param[in] src Input data to update hash with
98 | * @param[in] len Number of bytes to read from `src`
99 | */
100 | void av_murmur3_update(struct AVMurMur3 *c, const uint8_t *src, int len);
101 |
102 | /**
103 | * Finish hashing and output digest value.
104 | *
105 | * @param[in,out] c Hash context
106 | * @param[out] dst Buffer where output digest value is stored
107 | */
108 | void av_murmur3_final(struct AVMurMur3 *c, uint8_t dst[16]);
109 |
110 | /**
111 | * @}
112 | */
113 |
114 | #endif /* AVUTIL_MURMUR3_H */
115 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavutil/pixelutils.h:
--------------------------------------------------------------------------------
1 | /*
2 | * This file is part of FFmpeg.
3 | *
4 | * FFmpeg is free software; you can redistribute it and/or
5 | * modify it under the terms of the GNU Lesser General Public
6 | * License as published by the Free Software Foundation; either
7 | * version 2.1 of the License, or (at your option) any later version.
8 | *
9 | * FFmpeg is distributed in the hope that it will be useful,
10 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 | * Lesser General Public License for more details.
13 | *
14 | * You should have received a copy of the GNU Lesser General Public
15 | * License along with FFmpeg; if not, write to the Free Software
16 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17 | */
18 |
19 | #ifndef AVUTIL_PIXELUTILS_H
20 | #define AVUTIL_PIXELUTILS_H
21 |
22 | #include
23 | #include
24 | #include "common.h"
25 |
26 | /**
27 | * Sum of abs(src1[x] - src2[x])
28 | */
29 | typedef int (*av_pixelutils_sad_fn)(const uint8_t *src1, ptrdiff_t stride1,
30 | const uint8_t *src2, ptrdiff_t stride2);
31 |
32 | /**
33 | * Get a potentially optimized pointer to a Sum-of-absolute-differences
34 | * function (see the av_pixelutils_sad_fn prototype).
35 | *
36 | * @param w_bits 1<
3 | *
4 | * This file is part of FFmpeg.
5 | *
6 | * FFmpeg is free software; you can redistribute it and/or
7 | * modify it under the terms of the GNU Lesser General Public
8 | * License as published by the Free Software Foundation; either
9 | * version 2.1 of the License, or (at your option) any later version.
10 | *
11 | * FFmpeg is distributed in the hope that it will be useful,
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 | * Lesser General Public License for more details.
15 | *
16 | * You should have received a copy of the GNU Lesser General Public
17 | * License along with FFmpeg; if not, write to the Free Software
18 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19 | */
20 |
21 | #ifndef AVUTIL_RANDOM_SEED_H
22 | #define AVUTIL_RANDOM_SEED_H
23 |
24 | #include
25 | /**
26 | * @addtogroup lavu_crypto
27 | * @{
28 | */
29 |
30 | /**
31 | * Get a seed to use in conjunction with random functions.
32 | * This function tries to provide a good seed at a best effort bases.
33 | * Its possible to call this function multiple times if more bits are needed.
34 | * It can be quite slow, which is why it should only be used as seed for a faster
35 | * PRNG. The quality of the seed depends on the platform.
36 | */
37 | uint32_t av_get_random_seed(void);
38 |
39 | /**
40 | * @}
41 | */
42 |
43 | #endif /* AVUTIL_RANDOM_SEED_H */
44 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavutil/rc4.h:
--------------------------------------------------------------------------------
1 | /*
2 | * RC4 encryption/decryption/pseudo-random number generator
3 | *
4 | * This file is part of FFmpeg.
5 | *
6 | * FFmpeg is free software; you can redistribute it and/or
7 | * modify it under the terms of the GNU Lesser General Public
8 | * License as published by the Free Software Foundation; either
9 | * version 2.1 of the License, or (at your option) any later version.
10 | *
11 | * FFmpeg is distributed in the hope that it will be useful,
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 | * Lesser General Public License for more details.
15 | *
16 | * You should have received a copy of the GNU Lesser General Public
17 | * License along with FFmpeg; if not, write to the Free Software
18 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19 | */
20 |
21 | #ifndef AVUTIL_RC4_H
22 | #define AVUTIL_RC4_H
23 |
24 | #include
25 |
26 | /**
27 | * @defgroup lavu_rc4 RC4
28 | * @ingroup lavu_crypto
29 | * @{
30 | */
31 |
32 | typedef struct AVRC4 {
33 | uint8_t state[256];
34 | int x, y;
35 | } AVRC4;
36 |
37 | /**
38 | * Allocate an AVRC4 context.
39 | */
40 | AVRC4 *av_rc4_alloc(void);
41 |
42 | /**
43 | * @brief Initializes an AVRC4 context.
44 | *
45 | * @param key_bits must be a multiple of 8
46 | * @param decrypt 0 for encryption, 1 for decryption, currently has no effect
47 | * @return zero on success, negative value otherwise
48 | */
49 | int av_rc4_init(struct AVRC4 *d, const uint8_t *key, int key_bits, int decrypt);
50 |
51 | /**
52 | * @brief Encrypts / decrypts using the RC4 algorithm.
53 | *
54 | * @param count number of bytes
55 | * @param dst destination array, can be equal to src
56 | * @param src source array, can be equal to dst, may be NULL
57 | * @param iv not (yet) used for RC4, should be NULL
58 | * @param decrypt 0 for encryption, 1 for decryption, not (yet) used
59 | */
60 | void av_rc4_crypt(struct AVRC4 *d, uint8_t *dst, const uint8_t *src, int count, uint8_t *iv, int decrypt);
61 |
62 | /**
63 | * @}
64 | */
65 |
66 | #endif /* AVUTIL_RC4_H */
67 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavutil/replaygain.h:
--------------------------------------------------------------------------------
1 | /*
2 | * This file is part of FFmpeg.
3 | *
4 | * FFmpeg is free software; you can redistribute it and/or
5 | * modify it under the terms of the GNU Lesser General Public
6 | * License as published by the Free Software Foundation; either
7 | * version 2.1 of the License, or (at your option) any later version.
8 | *
9 | * FFmpeg is distributed in the hope that it will be useful,
10 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 | * Lesser General Public License for more details.
13 | *
14 | * You should have received a copy of the GNU Lesser General Public
15 | * License along with FFmpeg; if not, write to the Free Software
16 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17 | */
18 |
19 | #ifndef AVUTIL_REPLAYGAIN_H
20 | #define AVUTIL_REPLAYGAIN_H
21 |
22 | #include
23 |
24 | /**
25 | * ReplayGain information (see
26 | * http://wiki.hydrogenaudio.org/index.php?title=ReplayGain_1.0_specification).
27 | * The size of this struct is a part of the public ABI.
28 | */
29 | typedef struct AVReplayGain {
30 | /**
31 | * Track replay gain in microbels (divide by 100000 to get the value in dB).
32 | * Should be set to INT32_MIN when unknown.
33 | */
34 | int32_t track_gain;
35 | /**
36 | * Peak track amplitude, with 100000 representing full scale (but values
37 | * may overflow). 0 when unknown.
38 | */
39 | uint32_t track_peak;
40 | /**
41 | * Same as track_gain, but for the whole album.
42 | */
43 | int32_t album_gain;
44 | /**
45 | * Same as track_peak, but for the whole album,
46 | */
47 | uint32_t album_peak;
48 | } AVReplayGain;
49 |
50 | #endif /* AVUTIL_REPLAYGAIN_H */
51 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavutil/ripemd.h:
--------------------------------------------------------------------------------
1 | /*
2 | * Copyright (C) 2007 Michael Niedermayer
3 | * Copyright (C) 2013 James Almer
4 | *
5 | * This file is part of FFmpeg.
6 | *
7 | * FFmpeg is free software; you can redistribute it and/or
8 | * modify it under the terms of the GNU Lesser General Public
9 | * License as published by the Free Software Foundation; either
10 | * version 2.1 of the License, or (at your option) any later version.
11 | *
12 | * FFmpeg is distributed in the hope that it will be useful,
13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 | * Lesser General Public License for more details.
16 | *
17 | * You should have received a copy of the GNU Lesser General Public
18 | * License along with FFmpeg; if not, write to the Free Software
19 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20 | */
21 |
22 | /**
23 | * @file
24 | * @ingroup lavu_ripemd
25 | * Public header for RIPEMD hash function implementation.
26 | */
27 |
28 | #ifndef AVUTIL_RIPEMD_H
29 | #define AVUTIL_RIPEMD_H
30 |
31 | #include
32 |
33 | #include "attributes.h"
34 | #include "version.h"
35 |
36 | /**
37 | * @defgroup lavu_ripemd RIPEMD
38 | * @ingroup lavu_hash
39 | * RIPEMD hash function implementation.
40 | *
41 | * @{
42 | */
43 |
44 | extern const int av_ripemd_size;
45 |
46 | struct AVRIPEMD;
47 |
48 | /**
49 | * Allocate an AVRIPEMD context.
50 | */
51 | struct AVRIPEMD *av_ripemd_alloc(void);
52 |
53 | /**
54 | * Initialize RIPEMD hashing.
55 | *
56 | * @param context pointer to the function context (of size av_ripemd_size)
57 | * @param bits number of bits in digest (128, 160, 256 or 320 bits)
58 | * @return zero if initialization succeeded, -1 otherwise
59 | */
60 | int av_ripemd_init(struct AVRIPEMD* context, int bits);
61 |
62 | /**
63 | * Update hash value.
64 | *
65 | * @param context hash function context
66 | * @param data input data to update hash with
67 | * @param len input data length
68 | */
69 | void av_ripemd_update(struct AVRIPEMD* context, const uint8_t* data, unsigned int len);
70 |
71 | /**
72 | * Finish hashing and output digest value.
73 | *
74 | * @param context hash function context
75 | * @param digest buffer where output digest value is stored
76 | */
77 | void av_ripemd_final(struct AVRIPEMD* context, uint8_t *digest);
78 |
79 | /**
80 | * @}
81 | */
82 |
83 | #endif /* AVUTIL_RIPEMD_H */
84 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavutil/sha.h:
--------------------------------------------------------------------------------
1 | /*
2 | * Copyright (C) 2007 Michael Niedermayer
3 | *
4 | * This file is part of FFmpeg.
5 | *
6 | * FFmpeg is free software; you can redistribute it and/or
7 | * modify it under the terms of the GNU Lesser General Public
8 | * License as published by the Free Software Foundation; either
9 | * version 2.1 of the License, or (at your option) any later version.
10 | *
11 | * FFmpeg is distributed in the hope that it will be useful,
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 | * Lesser General Public License for more details.
15 | *
16 | * You should have received a copy of the GNU Lesser General Public
17 | * License along with FFmpeg; if not, write to the Free Software
18 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19 | */
20 |
21 | /**
22 | * @file
23 | * @ingroup lavu_sha
24 | * Public header for SHA-1 & SHA-256 hash function implementations.
25 | */
26 |
27 | #ifndef AVUTIL_SHA_H
28 | #define AVUTIL_SHA_H
29 |
30 | #include
31 |
32 | #include "attributes.h"
33 | #include "version.h"
34 |
35 | /**
36 | * @defgroup lavu_sha SHA
37 | * @ingroup lavu_hash
38 | * SHA-1 and SHA-256 (Secure Hash Algorithm) hash function implementations.
39 | *
40 | * This module supports the following SHA hash functions:
41 | *
42 | * - SHA-1: 160 bits
43 | * - SHA-224: 224 bits, as a variant of SHA-2
44 | * - SHA-256: 256 bits, as a variant of SHA-2
45 | *
46 | * @see For SHA-384, SHA-512, and variants thereof, see @ref lavu_sha512.
47 | *
48 | * @{
49 | */
50 |
51 | extern const int av_sha_size;
52 |
53 | struct AVSHA;
54 |
55 | /**
56 | * Allocate an AVSHA context.
57 | */
58 | struct AVSHA *av_sha_alloc(void);
59 |
60 | /**
61 | * Initialize SHA-1 or SHA-2 hashing.
62 | *
63 | * @param context pointer to the function context (of size av_sha_size)
64 | * @param bits number of bits in digest (SHA-1 - 160 bits, SHA-2 224 or 256 bits)
65 | * @return zero if initialization succeeded, -1 otherwise
66 | */
67 | int av_sha_init(struct AVSHA* context, int bits);
68 |
69 | /**
70 | * Update hash value.
71 | *
72 | * @param context hash function context
73 | * @param data input data to update hash with
74 | * @param len input data length
75 | */
76 | void av_sha_update(struct AVSHA* context, const uint8_t* data, unsigned int len);
77 |
78 | /**
79 | * Finish hashing and output digest value.
80 | *
81 | * @param context hash function context
82 | * @param digest buffer where output digest value is stored
83 | */
84 | void av_sha_final(struct AVSHA* context, uint8_t *digest);
85 |
86 | /**
87 | * @}
88 | */
89 |
90 | #endif /* AVUTIL_SHA_H */
91 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavutil/sha512.h:
--------------------------------------------------------------------------------
1 | /*
2 | * Copyright (C) 2007 Michael Niedermayer
3 | * Copyright (C) 2013 James Almer
4 | *
5 | * This file is part of FFmpeg.
6 | *
7 | * FFmpeg is free software; you can redistribute it and/or
8 | * modify it under the terms of the GNU Lesser General Public
9 | * License as published by the Free Software Foundation; either
10 | * version 2.1 of the License, or (at your option) any later version.
11 | *
12 | * FFmpeg is distributed in the hope that it will be useful,
13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 | * Lesser General Public License for more details.
16 | *
17 | * You should have received a copy of the GNU Lesser General Public
18 | * License along with FFmpeg; if not, write to the Free Software
19 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20 | */
21 |
22 | /**
23 | * @file
24 | * @ingroup lavu_sha512
25 | * Public header for SHA-512 implementation.
26 | */
27 |
28 | #ifndef AVUTIL_SHA512_H
29 | #define AVUTIL_SHA512_H
30 |
31 | #include
32 |
33 | #include "attributes.h"
34 | #include "version.h"
35 |
36 | /**
37 | * @defgroup lavu_sha512 SHA-512
38 | * @ingroup lavu_hash
39 | * SHA-512 (Secure Hash Algorithm) hash function implementations.
40 | *
41 | * This module supports the following SHA-2 hash functions:
42 | *
43 | * - SHA-512/224: 224 bits
44 | * - SHA-512/256: 256 bits
45 | * - SHA-384: 384 bits
46 | * - SHA-512: 512 bits
47 | *
48 | * @see For SHA-1, SHA-256, and variants thereof, see @ref lavu_sha.
49 | *
50 | * @{
51 | */
52 |
53 | extern const int av_sha512_size;
54 |
55 | struct AVSHA512;
56 |
57 | /**
58 | * Allocate an AVSHA512 context.
59 | */
60 | struct AVSHA512 *av_sha512_alloc(void);
61 |
62 | /**
63 | * Initialize SHA-2 512 hashing.
64 | *
65 | * @param context pointer to the function context (of size av_sha512_size)
66 | * @param bits number of bits in digest (224, 256, 384 or 512 bits)
67 | * @return zero if initialization succeeded, -1 otherwise
68 | */
69 | int av_sha512_init(struct AVSHA512* context, int bits);
70 |
71 | /**
72 | * Update hash value.
73 | *
74 | * @param context hash function context
75 | * @param data input data to update hash with
76 | * @param len input data length
77 | */
78 | void av_sha512_update(struct AVSHA512* context, const uint8_t* data, unsigned int len);
79 |
80 | /**
81 | * Finish hashing and output digest value.
82 | *
83 | * @param context hash function context
84 | * @param digest buffer where output digest value is stored
85 | */
86 | void av_sha512_final(struct AVSHA512* context, uint8_t *digest);
87 |
88 | /**
89 | * @}
90 | */
91 |
92 | #endif /* AVUTIL_SHA512_H */
93 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavutil/tea.h:
--------------------------------------------------------------------------------
1 | /*
2 | * A 32-bit implementation of the TEA algorithm
3 | * Copyright (c) 2015 Vesselin Bontchev
4 | *
5 | * This file is part of FFmpeg.
6 | *
7 | * FFmpeg is free software; you can redistribute it and/or
8 | * modify it under the terms of the GNU Lesser General Public
9 | * License as published by the Free Software Foundation; either
10 | * version 2.1 of the License, or (at your option) any later version.
11 | *
12 | * FFmpeg is distributed in the hope that it will be useful,
13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 | * Lesser General Public License for more details.
16 | *
17 | * You should have received a copy of the GNU Lesser General Public
18 | * License along with FFmpeg; if not, write to the Free Software
19 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20 | */
21 |
22 | #ifndef AVUTIL_TEA_H
23 | #define AVUTIL_TEA_H
24 |
25 | #include
26 |
27 | /**
28 | * @file
29 | * @brief Public header for libavutil TEA algorithm
30 | * @defgroup lavu_tea TEA
31 | * @ingroup lavu_crypto
32 | * @{
33 | */
34 |
35 | extern const int av_tea_size;
36 |
37 | struct AVTEA;
38 |
39 | /**
40 | * Allocate an AVTEA context
41 | * To free the struct: av_free(ptr)
42 | */
43 | struct AVTEA *av_tea_alloc(void);
44 |
45 | /**
46 | * Initialize an AVTEA context.
47 | *
48 | * @param ctx an AVTEA context
49 | * @param key a key of 16 bytes used for encryption/decryption
50 | * @param rounds the number of rounds in TEA (64 is the "standard")
51 | */
52 | void av_tea_init(struct AVTEA *ctx, const uint8_t key[16], int rounds);
53 |
54 | /**
55 | * Encrypt or decrypt a buffer using a previously initialized context.
56 | *
57 | * @param ctx an AVTEA context
58 | * @param dst destination array, can be equal to src
59 | * @param src source array, can be equal to dst
60 | * @param count number of 8 byte blocks
61 | * @param iv initialization vector for CBC mode, if NULL then ECB will be used
62 | * @param decrypt 0 for encryption, 1 for decryption
63 | */
64 | void av_tea_crypt(struct AVTEA *ctx, uint8_t *dst, const uint8_t *src,
65 | int count, uint8_t *iv, int decrypt);
66 |
67 | /**
68 | * @}
69 | */
70 |
71 | #endif /* AVUTIL_TEA_H */
72 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavutil/threadmessage.h:
--------------------------------------------------------------------------------
1 | /*
2 | * This file is part of FFmpeg.
3 | *
4 | * FFmpeg is free software; you can redistribute it and/or
5 | * modify it under the terms of the GNU Lesser General Public License
6 | * as published by the Free Software Foundation; either
7 | * version 2.1 of the License, or (at your option) any later version.
8 | *
9 | * FFmpeg is distributed in the hope that it will be useful,
10 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 | * GNU Lesser General Public License for more details.
13 | *
14 | * You should have received a copy of the GNU Lesser General Public License
15 | * along with FFmpeg; if not, write to the Free Software Foundation, Inc.,
16 | * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17 | */
18 |
19 | #ifndef AVUTIL_THREADMESSAGE_H
20 | #define AVUTIL_THREADMESSAGE_H
21 |
22 | typedef struct AVThreadMessageQueue AVThreadMessageQueue;
23 |
24 | typedef enum AVThreadMessageFlags {
25 |
26 | /**
27 | * Perform non-blocking operation.
28 | * If this flag is set, send and recv operations are non-blocking and
29 | * return AVERROR(EAGAIN) immediately if they can not proceed.
30 | */
31 | AV_THREAD_MESSAGE_NONBLOCK = 1,
32 |
33 | } AVThreadMessageFlags;
34 |
35 | /**
36 | * Allocate a new message queue.
37 | *
38 | * @param mq pointer to the message queue
39 | * @param nelem maximum number of elements in the queue
40 | * @param elsize size of each element in the queue
41 | * @return >=0 for success; <0 for error, in particular AVERROR(ENOSYS) if
42 | * lavu was built without thread support
43 | */
44 | int av_thread_message_queue_alloc(AVThreadMessageQueue **mq,
45 | unsigned nelem,
46 | unsigned elsize);
47 |
48 | /**
49 | * Free a message queue.
50 | *
51 | * The message queue must no longer be in use by another thread.
52 | */
53 | void av_thread_message_queue_free(AVThreadMessageQueue **mq);
54 |
55 | /**
56 | * Send a message on the queue.
57 | */
58 | int av_thread_message_queue_send(AVThreadMessageQueue *mq,
59 | void *msg,
60 | unsigned flags);
61 |
62 | /**
63 | * Receive a message from the queue.
64 | */
65 | int av_thread_message_queue_recv(AVThreadMessageQueue *mq,
66 | void *msg,
67 | unsigned flags);
68 |
69 | /**
70 | * Set the sending error code.
71 | *
72 | * If the error code is set to non-zero, av_thread_message_queue_send() will
73 | * return it immediately. Conventional values, such as AVERROR_EOF or
74 | * AVERROR(EAGAIN), can be used to cause the sending thread to stop or
75 | * suspend its operation.
76 | */
77 | void av_thread_message_queue_set_err_send(AVThreadMessageQueue *mq,
78 | int err);
79 |
80 | /**
81 | * Set the receiving error code.
82 | *
83 | * If the error code is set to non-zero, av_thread_message_queue_recv() will
84 | * return it immediately when there are no longer available messages.
85 | * Conventional values, such as AVERROR_EOF or AVERROR(EAGAIN), can be used
86 | * to cause the receiving thread to stop or suspend its operation.
87 | */
88 | void av_thread_message_queue_set_err_recv(AVThreadMessageQueue *mq,
89 | int err);
90 |
91 | /**
92 | * Set the optional free message callback function which will be called if an
93 | * operation is removing messages from the queue.
94 | */
95 | void av_thread_message_queue_set_free_func(AVThreadMessageQueue *mq,
96 | void (*free_func)(void *msg));
97 |
98 | /**
99 | * Flush the message queue
100 | *
101 | * This function is mostly equivalent to reading and free-ing every message
102 | * except that it will be done in a single operation (no lock/unlock between
103 | * reads).
104 | */
105 | void av_thread_message_flush(AVThreadMessageQueue *mq);
106 |
107 | #endif /* AVUTIL_THREADMESSAGE_H */
108 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavutil/time.h:
--------------------------------------------------------------------------------
1 | /*
2 | * Copyright (c) 2000-2003 Fabrice Bellard
3 | *
4 | * This file is part of FFmpeg.
5 | *
6 | * FFmpeg is free software; you can redistribute it and/or
7 | * modify it under the terms of the GNU Lesser General Public
8 | * License as published by the Free Software Foundation; either
9 | * version 2.1 of the License, or (at your option) any later version.
10 | *
11 | * FFmpeg is distributed in the hope that it will be useful,
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 | * Lesser General Public License for more details.
15 | *
16 | * You should have received a copy of the GNU Lesser General Public
17 | * License along with FFmpeg; if not, write to the Free Software
18 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19 | */
20 |
21 | #ifndef AVUTIL_TIME_H
22 | #define AVUTIL_TIME_H
23 |
24 | #include
25 |
26 | /**
27 | * Get the current time in microseconds.
28 | */
29 | int64_t av_gettime(void);
30 |
31 | /**
32 | * Get the current time in microseconds since some unspecified starting point.
33 | * On platforms that support it, the time comes from a monotonic clock
34 | * This property makes this time source ideal for measuring relative time.
35 | * The returned values may not be monotonic on platforms where a monotonic
36 | * clock is not available.
37 | */
38 | int64_t av_gettime_relative(void);
39 |
40 | /**
41 | * Indicates with a boolean result if the av_gettime_relative() time source
42 | * is monotonic.
43 | */
44 | int av_gettime_relative_is_monotonic(void);
45 |
46 | /**
47 | * Sleep for a period of time. Although the duration is expressed in
48 | * microseconds, the actual delay may be rounded to the precision of the
49 | * system timer.
50 | *
51 | * @param usec Number of microseconds to sleep.
52 | * @return zero on success or (negative) error code.
53 | */
54 | int av_usleep(unsigned usec);
55 |
56 | #endif /* AVUTIL_TIME_H */
57 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavutil/timestamp.h:
--------------------------------------------------------------------------------
1 | /*
2 | * This file is part of FFmpeg.
3 | *
4 | * FFmpeg is free software; you can redistribute it and/or
5 | * modify it under the terms of the GNU Lesser General Public
6 | * License as published by the Free Software Foundation; either
7 | * version 2.1 of the License, or (at your option) any later version.
8 | *
9 | * FFmpeg is distributed in the hope that it will be useful,
10 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 | * Lesser General Public License for more details.
13 | *
14 | * You should have received a copy of the GNU Lesser General Public
15 | * License along with FFmpeg; if not, write to the Free Software
16 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17 | */
18 |
19 | /**
20 | * @file
21 | * timestamp utils, mostly useful for debugging/logging purposes
22 | */
23 |
24 | #ifndef AVUTIL_TIMESTAMP_H
25 | #define AVUTIL_TIMESTAMP_H
26 |
27 | #include "common.h"
28 |
29 | #if defined(__cplusplus) && !defined(__STDC_FORMAT_MACROS) && !defined(PRId64)
30 | #error missing -D__STDC_FORMAT_MACROS / #define __STDC_FORMAT_MACROS
31 | #endif
32 |
33 | #define AV_TS_MAX_STRING_SIZE 32
34 |
35 | /**
36 | * Fill the provided buffer with a string containing a timestamp
37 | * representation.
38 | *
39 | * @param buf a buffer with size in bytes of at least AV_TS_MAX_STRING_SIZE
40 | * @param ts the timestamp to represent
41 | * @return the buffer in input
42 | */
43 | static inline char *av_ts_make_string(char *buf, int64_t ts)
44 | {
45 | if (ts == AV_NOPTS_VALUE) snprintf(buf, AV_TS_MAX_STRING_SIZE, "NOPTS");
46 | else snprintf(buf, AV_TS_MAX_STRING_SIZE, "%" PRId64, ts);
47 | return buf;
48 | }
49 |
50 | /**
51 | * Convenience macro, the return value should be used only directly in
52 | * function arguments but never stand-alone.
53 | */
54 | #define av_ts2str(ts) av_ts_make_string((char[AV_TS_MAX_STRING_SIZE]){0}, ts)
55 |
56 | /**
57 | * Fill the provided buffer with a string containing a timestamp time
58 | * representation.
59 | *
60 | * @param buf a buffer with size in bytes of at least AV_TS_MAX_STRING_SIZE
61 | * @param ts the timestamp to represent
62 | * @param tb the timebase of the timestamp
63 | * @return the buffer in input
64 | */
65 | static inline char *av_ts_make_time_string(char *buf, int64_t ts, AVRational *tb)
66 | {
67 | if (ts == AV_NOPTS_VALUE) snprintf(buf, AV_TS_MAX_STRING_SIZE, "NOPTS");
68 | else snprintf(buf, AV_TS_MAX_STRING_SIZE, "%.6g", av_q2d(*tb) * ts);
69 | return buf;
70 | }
71 |
72 | /**
73 | * Convenience macro, the return value should be used only directly in
74 | * function arguments but never stand-alone.
75 | */
76 | #define av_ts2timestr(ts, tb) av_ts_make_time_string((char[AV_TS_MAX_STRING_SIZE]){0}, ts, tb)
77 |
78 | #endif /* AVUTIL_TIMESTAMP_H */
79 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavutil/twofish.h:
--------------------------------------------------------------------------------
1 | /*
2 | * An implementation of the TwoFish algorithm
3 | * Copyright (c) 2015 Supraja Meedinti
4 | *
5 | * This file is part of FFmpeg.
6 | *
7 | * FFmpeg is free software; you can redistribute it and/or
8 | * modify it under the terms of the GNU Lesser General Public
9 | * License as published by the Free Software Foundation; either
10 | * version 2.1 of the License, or (at your option) any later version.
11 | *
12 | * FFmpeg is distributed in the hope that it will be useful,
13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 | * Lesser General Public License for more details.
16 | *
17 | * You should have received a copy of the GNU Lesser General Public
18 | * License along with FFmpeg; if not, write to the Free Software
19 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20 | */
21 |
22 | #ifndef AVUTIL_TWOFISH_H
23 | #define AVUTIL_TWOFISH_H
24 |
25 | #include
26 |
27 |
28 | /**
29 | * @file
30 | * @brief Public header for libavutil TWOFISH algorithm
31 | * @defgroup lavu_twofish TWOFISH
32 | * @ingroup lavu_crypto
33 | * @{
34 | */
35 |
36 | extern const int av_twofish_size;
37 |
38 | struct AVTWOFISH;
39 |
40 | /**
41 | * Allocate an AVTWOFISH context
42 | * To free the struct: av_free(ptr)
43 | */
44 | struct AVTWOFISH *av_twofish_alloc(void);
45 |
46 | /**
47 | * Initialize an AVTWOFISH context.
48 | *
49 | * @param ctx an AVTWOFISH context
50 | * @param key a key of size ranging from 1 to 32 bytes used for encryption/decryption
51 | * @param key_bits number of keybits: 128, 192, 256 If less than the required, padded with zeroes to nearest valid value; return value is 0 if key_bits is 128/192/256, -1 if less than 0, 1 otherwise
52 | */
53 | int av_twofish_init(struct AVTWOFISH *ctx, const uint8_t *key, int key_bits);
54 |
55 | /**
56 | * Encrypt or decrypt a buffer using a previously initialized context
57 | *
58 | * @param ctx an AVTWOFISH context
59 | * @param dst destination array, can be equal to src
60 | * @param src source array, can be equal to dst
61 | * @param count number of 16 byte blocks
62 | * @paran iv initialization vector for CBC mode, NULL for ECB mode
63 | * @param decrypt 0 for encryption, 1 for decryption
64 | */
65 | void av_twofish_crypt(struct AVTWOFISH *ctx, uint8_t *dst, const uint8_t *src, int count, uint8_t* iv, int decrypt);
66 |
67 | /**
68 | * @}
69 | */
70 | #endif /* AVUTIL_TWOFISH_H */
71 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libavutil/xtea.h:
--------------------------------------------------------------------------------
1 | /*
2 | * A 32-bit implementation of the XTEA algorithm
3 | * Copyright (c) 2012 Samuel Pitoiset
4 | *
5 | * This file is part of FFmpeg.
6 | *
7 | * FFmpeg is free software; you can redistribute it and/or
8 | * modify it under the terms of the GNU Lesser General Public
9 | * License as published by the Free Software Foundation; either
10 | * version 2.1 of the License, or (at your option) any later version.
11 | *
12 | * FFmpeg is distributed in the hope that it will be useful,
13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 | * Lesser General Public License for more details.
16 | *
17 | * You should have received a copy of the GNU Lesser General Public
18 | * License along with FFmpeg; if not, write to the Free Software
19 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20 | */
21 |
22 | #ifndef AVUTIL_XTEA_H
23 | #define AVUTIL_XTEA_H
24 |
25 | #include
26 |
27 | /**
28 | * @file
29 | * @brief Public header for libavutil XTEA algorithm
30 | * @defgroup lavu_xtea XTEA
31 | * @ingroup lavu_crypto
32 | * @{
33 | */
34 |
35 | typedef struct AVXTEA {
36 | uint32_t key[16];
37 | } AVXTEA;
38 |
39 | /**
40 | * Allocate an AVXTEA context.
41 | */
42 | AVXTEA *av_xtea_alloc(void);
43 |
44 | /**
45 | * Initialize an AVXTEA context.
46 | *
47 | * @param ctx an AVXTEA context
48 | * @param key a key of 16 bytes used for encryption/decryption,
49 | * interpreted as big endian 32 bit numbers
50 | */
51 | void av_xtea_init(struct AVXTEA *ctx, const uint8_t key[16]);
52 |
53 | /**
54 | * Initialize an AVXTEA context.
55 | *
56 | * @param ctx an AVXTEA context
57 | * @param key a key of 16 bytes used for encryption/decryption,
58 | * interpreted as little endian 32 bit numbers
59 | */
60 | void av_xtea_le_init(struct AVXTEA *ctx, const uint8_t key[16]);
61 |
62 | /**
63 | * Encrypt or decrypt a buffer using a previously initialized context,
64 | * in big endian format.
65 | *
66 | * @param ctx an AVXTEA context
67 | * @param dst destination array, can be equal to src
68 | * @param src source array, can be equal to dst
69 | * @param count number of 8 byte blocks
70 | * @param iv initialization vector for CBC mode, if NULL then ECB will be used
71 | * @param decrypt 0 for encryption, 1 for decryption
72 | */
73 | void av_xtea_crypt(struct AVXTEA *ctx, uint8_t *dst, const uint8_t *src,
74 | int count, uint8_t *iv, int decrypt);
75 |
76 | /**
77 | * Encrypt or decrypt a buffer using a previously initialized context,
78 | * in little endian format.
79 | *
80 | * @param ctx an AVXTEA context
81 | * @param dst destination array, can be equal to src
82 | * @param src source array, can be equal to dst
83 | * @param count number of 8 byte blocks
84 | * @param iv initialization vector for CBC mode, if NULL then ECB will be used
85 | * @param decrypt 0 for encryption, 1 for decryption
86 | */
87 | void av_xtea_le_crypt(struct AVXTEA *ctx, uint8_t *dst, const uint8_t *src,
88 | int count, uint8_t *iv, int decrypt);
89 |
90 | /**
91 | * @}
92 | */
93 |
94 | #endif /* AVUTIL_XTEA_H */
95 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libswresample/version.h:
--------------------------------------------------------------------------------
1 | /*
2 | * Version macros.
3 | *
4 | * This file is part of libswresample
5 | *
6 | * libswresample is free software; you can redistribute it and/or
7 | * modify it under the terms of the GNU Lesser General Public
8 | * License as published by the Free Software Foundation; either
9 | * version 2.1 of the License, or (at your option) any later version.
10 | *
11 | * libswresample is distributed in the hope that it will be useful,
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 | * Lesser General Public License for more details.
15 | *
16 | * You should have received a copy of the GNU Lesser General Public
17 | * License along with libswresample; if not, write to the Free Software
18 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19 | */
20 |
21 | #ifndef SWRESAMPLE_VERSION_H
22 | #define SWRESAMPLE_VERSION_H
23 |
24 | /**
25 | * @file
26 | * Libswresample version macros
27 | */
28 |
29 | #include "libavutil/avutil.h"
30 |
31 | #define LIBSWRESAMPLE_VERSION_MAJOR 2
32 | #define LIBSWRESAMPLE_VERSION_MINOR 3
33 | #define LIBSWRESAMPLE_VERSION_MICRO 100
34 |
35 | #define LIBSWRESAMPLE_VERSION_INT AV_VERSION_INT(LIBSWRESAMPLE_VERSION_MAJOR, \
36 | LIBSWRESAMPLE_VERSION_MINOR, \
37 | LIBSWRESAMPLE_VERSION_MICRO)
38 | #define LIBSWRESAMPLE_VERSION AV_VERSION(LIBSWRESAMPLE_VERSION_MAJOR, \
39 | LIBSWRESAMPLE_VERSION_MINOR, \
40 | LIBSWRESAMPLE_VERSION_MICRO)
41 | #define LIBSWRESAMPLE_BUILD LIBSWRESAMPLE_VERSION_INT
42 |
43 | #define LIBSWRESAMPLE_IDENT "SwR" AV_STRINGIFY(LIBSWRESAMPLE_VERSION)
44 |
45 | #endif /* SWRESAMPLE_VERSION_H */
46 |
--------------------------------------------------------------------------------
/app/src/main/jniLibs/include/libswscale/version.h:
--------------------------------------------------------------------------------
1 | /*
2 | * This file is part of FFmpeg.
3 | *
4 | * FFmpeg is free software; you can redistribute it and/or
5 | * modify it under the terms of the GNU Lesser General Public
6 | * License as published by the Free Software Foundation; either
7 | * version 2.1 of the License, or (at your option) any later version.
8 | *
9 | * FFmpeg is distributed in the hope that it will be useful,
10 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 | * Lesser General Public License for more details.
13 | *
14 | * You should have received a copy of the GNU Lesser General Public
15 | * License along with FFmpeg; if not, write to the Free Software
16 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17 | */
18 |
19 | #ifndef SWSCALE_VERSION_H
20 | #define SWSCALE_VERSION_H
21 |
22 | /**
23 | * @file
24 | * swscale version macros
25 | */
26 |
27 | #include "libavutil/version.h"
28 |
29 | #define LIBSWSCALE_VERSION_MAJOR 4
30 | #define LIBSWSCALE_VERSION_MINOR 2
31 | #define LIBSWSCALE_VERSION_MICRO 100
32 |
33 | #define LIBSWSCALE_VERSION_INT AV_VERSION_INT(LIBSWSCALE_VERSION_MAJOR, \
34 | LIBSWSCALE_VERSION_MINOR, \
35 | LIBSWSCALE_VERSION_MICRO)
36 | #define LIBSWSCALE_VERSION AV_VERSION(LIBSWSCALE_VERSION_MAJOR, \
37 | LIBSWSCALE_VERSION_MINOR, \
38 | LIBSWSCALE_VERSION_MICRO)
39 | #define LIBSWSCALE_BUILD LIBSWSCALE_VERSION_INT
40 |
41 | #define LIBSWSCALE_IDENT "SwS" AV_STRINGIFY(LIBSWSCALE_VERSION)
42 |
43 | /**
44 | * FF_API_* defines may be placed below to indicate public API that will be
45 | * dropped at a future version bump. The defines themselves are not part of
46 | * the public API and may change, break or disappear at any time.
47 | */
48 |
49 | #ifndef FF_API_SWS_VECTOR
50 | #define FF_API_SWS_VECTOR (LIBSWSCALE_VERSION_MAJOR < 6)
51 | #endif
52 |
53 | #endif /* SWSCALE_VERSION_H */
54 |
--------------------------------------------------------------------------------
/app/src/main/res/drawable-v24/ic_launcher_foreground.xml:
--------------------------------------------------------------------------------
1 |
7 |
12 |
13 |
19 |
22 |
25 |
26 |
27 |
28 |
34 |
35 |
--------------------------------------------------------------------------------
/app/src/main/res/layout/activity_main.xml:
--------------------------------------------------------------------------------
1 |
2 |
9 |
10 |
15 |
16 |
21 |
26 |
27 |
32 |
37 |
42 |
47 |
--------------------------------------------------------------------------------
/app/src/main/res/layout/activity_wave_player.xml:
--------------------------------------------------------------------------------
1 |
2 |
6 |
7 |
12 |
--------------------------------------------------------------------------------
/app/src/main/res/mipmap-anydpi-v26/ic_launcher.xml:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
--------------------------------------------------------------------------------
/app/src/main/res/mipmap-anydpi-v26/ic_launcher_round.xml:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
--------------------------------------------------------------------------------
/app/src/main/res/mipmap-hdpi/ic_launcher.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/iamyours/FFmpegAudioPlayer/72582893a91ac9bd067285c571ceb05b4a966b22/app/src/main/res/mipmap-hdpi/ic_launcher.png
--------------------------------------------------------------------------------
/app/src/main/res/mipmap-hdpi/ic_launcher_round.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/iamyours/FFmpegAudioPlayer/72582893a91ac9bd067285c571ceb05b4a966b22/app/src/main/res/mipmap-hdpi/ic_launcher_round.png
--------------------------------------------------------------------------------
/app/src/main/res/mipmap-mdpi/ic_launcher.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/iamyours/FFmpegAudioPlayer/72582893a91ac9bd067285c571ceb05b4a966b22/app/src/main/res/mipmap-mdpi/ic_launcher.png
--------------------------------------------------------------------------------
/app/src/main/res/mipmap-mdpi/ic_launcher_round.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/iamyours/FFmpegAudioPlayer/72582893a91ac9bd067285c571ceb05b4a966b22/app/src/main/res/mipmap-mdpi/ic_launcher_round.png
--------------------------------------------------------------------------------
/app/src/main/res/mipmap-xhdpi/ic_launcher.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/iamyours/FFmpegAudioPlayer/72582893a91ac9bd067285c571ceb05b4a966b22/app/src/main/res/mipmap-xhdpi/ic_launcher.png
--------------------------------------------------------------------------------
/app/src/main/res/mipmap-xhdpi/ic_launcher_round.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/iamyours/FFmpegAudioPlayer/72582893a91ac9bd067285c571ceb05b4a966b22/app/src/main/res/mipmap-xhdpi/ic_launcher_round.png
--------------------------------------------------------------------------------
/app/src/main/res/mipmap-xxhdpi/ic_launcher.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/iamyours/FFmpegAudioPlayer/72582893a91ac9bd067285c571ceb05b4a966b22/app/src/main/res/mipmap-xxhdpi/ic_launcher.png
--------------------------------------------------------------------------------
/app/src/main/res/mipmap-xxhdpi/ic_launcher_round.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/iamyours/FFmpegAudioPlayer/72582893a91ac9bd067285c571ceb05b4a966b22/app/src/main/res/mipmap-xxhdpi/ic_launcher_round.png
--------------------------------------------------------------------------------
/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/iamyours/FFmpegAudioPlayer/72582893a91ac9bd067285c571ceb05b4a966b22/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png
--------------------------------------------------------------------------------
/app/src/main/res/mipmap-xxxhdpi/ic_launcher_round.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/iamyours/FFmpegAudioPlayer/72582893a91ac9bd067285c571ceb05b4a966b22/app/src/main/res/mipmap-xxxhdpi/ic_launcher_round.png
--------------------------------------------------------------------------------
/app/src/main/res/values/colors.xml:
--------------------------------------------------------------------------------
1 |
2 |
3 | #3F51B5
4 | #303F9F
5 | #FF4081
6 |
7 |
--------------------------------------------------------------------------------
/app/src/main/res/values/strings.xml:
--------------------------------------------------------------------------------
1 |
2 | FFmpegAudioPlayer
3 |
4 |
--------------------------------------------------------------------------------
/app/src/main/res/values/styles.xml:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
10 |
11 |
12 |
--------------------------------------------------------------------------------
/app/src/test/java/io/github/iamyours/ffmpegaudioplayer/ExampleUnitTest.kt:
--------------------------------------------------------------------------------
1 | package io.github.iamyours.ffmpegaudioplayer
2 |
3 | import org.junit.Test
4 |
5 | import org.junit.Assert.*
6 |
7 | /**
8 | * Example local unit test, which will execute on the development machine (host).
9 | *
10 | * See [testing documentation](http://d.android.com/tools/testing).
11 | */
12 | class ExampleUnitTest {
13 | @Test
14 | fun addition_isCorrect() {
15 | assertEquals(4, 2 + 2)
16 | }
17 | }
18 |
--------------------------------------------------------------------------------
/build.gradle:
--------------------------------------------------------------------------------
1 | // Top-level build file where you can add configuration options common to all sub-projects/modules.
2 |
3 | buildscript {
4 | ext.kotlin_version = '1.3.21'
5 | repositories {
6 | google()
7 | jcenter()
8 | }
9 | dependencies {
10 | classpath 'com.android.tools.build:gradle:3.4.2'
11 | classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"
12 |
13 | // NOTE: Do not place your application dependencies here; they belong
14 | // in the individual module build.gradle files
15 | }
16 | }
17 |
18 | allprojects {
19 | repositories {
20 | google()
21 | jcenter()
22 | }
23 | }
24 |
25 | task clean(type: Delete) {
26 | delete rootProject.buildDir
27 | }
28 |
--------------------------------------------------------------------------------
/build_android_all.sh:
--------------------------------------------------------------------------------
1 | #!/bin/sh
2 | MY_LIBS_NAME=ffmpeg-3.2.12
3 | MY_DIR=ffmpeg-3.2.12
4 |
5 | # cd ./${MY_DIR}
6 |
7 | #编译的过程中产生的中间件的存放目录,为了区分编译目录,源码目录,install目录
8 | MY_BUILD_DIR=binary
9 |
10 |
11 | NDK_PATH=/Users/yanxx/Desktop/soft/android-ndk-r15c
12 | BUILD_PLATFORM=darwin-x86_64
13 | TOOLCHAIN_VERSION=4.9
14 | ANDROID_VERSION=21
15 |
16 | ANDROID_ARMV5_CFLAGS="-march=armv5te"
17 | ANDROID_ARMV7_CFLAGS="-march=armv7-a -mfloat-abi=softfp -mfpu=neon" #-mfloat-abi=hard -mfpu=vfpv3-d16 #-mfloat-abi=hard -mfpu=vfp
18 | ANDROID_ARMV8_CFLAGS="-march=armv8-a"
19 | ANDROID_X86_CFLAGS="-march=i686 -mtune=intel -mssse3 -mfpmath=sse -m32"
20 | ANDROID_X86_64_CFLAGS="-march=x86-64 -msse4.2 -mpopcnt -m64 -mtune=intel"
21 |
22 |
23 | # params($1:arch,$2:arch_abi,$3:host,$4:cross_prefix,$5:cflags)
24 | build_bin() {
25 |
26 | echo "-------------------start build $2-------------------------"
27 |
28 | ARCH=$1 # arm arm64 x86 x86_64
29 | ANDROID_ARCH_ABI=$2 # armeabi armeabi-v7a x86 mips
30 |
31 | PREFIX=$(pwd)/dist/${MY_LIBS_NAME}/${ANDROID_ARCH_ABI}/
32 |
33 | HOST=$3
34 | SYSROOT=${NDK_PATH}/platforms/android-${ANDROID_VERSION}/arch-${ARCH}
35 |
36 | CFALGS=$5
37 |
38 |
39 | TOOLCHAIN=${NDK_PATH}/toolchains/${HOST}-${TOOLCHAIN_VERSION}/prebuilt/${BUILD_PLATFORM}
40 | CROSS_PREFIX=${TOOLCHAIN}/bin/$4-
41 |
42 | # build 中间件
43 | BUILD_DIR=./${MY_BUILD_DIR}/${ANDROID_ARCH_ABI}
44 |
45 | echo "pwd==$(pwd)"
46 | echo "ARCH==${ARCH}"
47 | echo "PREFIX==${PREFIX}"
48 | echo "HOST==${HOST}"
49 | echo "SYSROOT=${SYSROOT}"
50 | echo "CFALGS=$5"
51 | echo "CFALGS=${CFALGS}"
52 | echo "TOOLCHAIN==${TOOLCHAIN}"
53 | echo "CROSS_PREFIX=${CROSS_PREFIX}"
54 |
55 | #echo "-------------------------按任意键继续---------------------"
56 | #read -n 1
57 | #echo "-------------------------继续执行-------------------------"
58 |
59 | mkdir -p ${BUILD_DIR} #创建当前arch_abi的编译目录,比如:binary/armeabi-v7a
60 | cd ${BUILD_DIR} #此处 进了当前arch_abi的2级编译目录
61 |
62 | sh ../../configure \
63 | --prefix=${PREFIX} \
64 | --target-os=linux \
65 | --arch=${ARCH} \
66 | --sysroot=$SYSROOT \
67 | --enable-cross-compile \
68 | --cross-prefix=${CROSS_PREFIX} \
69 | --extra-cflags="$CFALGS -Os -fPIC -DANDROID -Wfatal-errors -Wno-deprecated" \
70 | --extra-ldflags="$ADDI_LDFLAGS" \
71 | --extra-cxxflags="-D__thumb__ -fexceptions -frtti" \
72 | --enable-shared \
73 | --disable-doc \
74 | --disable-ffmpeg \
75 | --disable-ffplay \
76 | --disable-ffprobe \
77 | --disable-symver \
78 | --disable-debug \
79 | --enable-small
80 |
81 | echo "--------------------"
82 |
83 | make clean
84 | make
85 | make install
86 |
87 | #从当前arch_abi编译目录跳出,对应上面的cd ${BUILD_DIR},以便function多次执行
88 | # cd ../../
89 |
90 | echo "-------------------$2 build end-------------------------"
91 | }
92 |
93 | # # build armeabi
94 | # build_bin arm armeabi arm-linux-androideabi arm-linux-androideabi "$ANDROID_ARMV5_CFLAGS"
95 |
96 | # #build armeabi-v7a
97 | # build_bin arm armeabi-v7a arm-linux-androideabi arm-linux-androideabi "$ANDROID_ARMV7_CFLAGS"
98 |
99 | # #build arm64-v8a
100 | # build_bin arm64 arm64-v8a aarch64-linux-android aarch64-linux-android "$ANDROID_ARMV8_CFLAGS"
101 |
102 | # #build x86
103 | # build_bin x86 x86 x86 i686-linux-android "$ANDROID_X86_CFLAGS"
104 |
105 | #build x86_64
106 | build_bin x86_64 x86_64 x86_64 x86_64-linux-android "$ANDROID_X86_64_CFLAGS"
107 |
--------------------------------------------------------------------------------
/gradle.properties:
--------------------------------------------------------------------------------
1 | # Project-wide Gradle settings.
2 | # IDE (e.g. Android Studio) users:
3 | # Gradle settings configured through the IDE *will override*
4 | # any settings specified in this file.
5 | # For more details on how to configure your build environment visit
6 | # http://www.gradle.org/docs/current/userguide/build_environment.html
7 | # Specifies the JVM arguments used for the daemon process.
8 | # The setting is particularly useful for tweaking memory settings.
9 | org.gradle.jvmargs=-Xmx1536m
10 | # When configured, Gradle will run in incubating parallel mode.
11 | # This option should only be used with decoupled projects. More details, visit
12 | # http://www.gradle.org/docs/current/userguide/multi_project_builds.html#sec:decoupled_projects
13 | # org.gradle.parallel=true
14 |
--------------------------------------------------------------------------------
/gradle/wrapper/gradle-wrapper.jar:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/iamyours/FFmpegAudioPlayer/72582893a91ac9bd067285c571ceb05b4a966b22/gradle/wrapper/gradle-wrapper.jar
--------------------------------------------------------------------------------
/gradle/wrapper/gradle-wrapper.properties:
--------------------------------------------------------------------------------
1 | #Wed Jan 16 10:27:09 CST 2019
2 | distributionBase=GRADLE_USER_HOME
3 | distributionPath=wrapper/dists
4 | zipStoreBase=GRADLE_USER_HOME
5 | zipStorePath=wrapper/dists
6 | distributionUrl=https\://services.gradle.org/distributions/gradle-5.4.1-all.zip
7 |
--------------------------------------------------------------------------------
/gradlew.bat:
--------------------------------------------------------------------------------
1 | @if "%DEBUG%" == "" @echo off
2 | @rem ##########################################################################
3 | @rem
4 | @rem Gradle startup script for Windows
5 | @rem
6 | @rem ##########################################################################
7 |
8 | @rem Set local scope for the variables with windows NT shell
9 | if "%OS%"=="Windows_NT" setlocal
10 |
11 | set DIRNAME=%~dp0
12 | if "%DIRNAME%" == "" set DIRNAME=.
13 | set APP_BASE_NAME=%~n0
14 | set APP_HOME=%DIRNAME%
15 |
16 | @rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
17 | set DEFAULT_JVM_OPTS=
18 |
19 | @rem Find java.exe
20 | if defined JAVA_HOME goto findJavaFromJavaHome
21 |
22 | set JAVA_EXE=java.exe
23 | %JAVA_EXE% -version >NUL 2>&1
24 | if "%ERRORLEVEL%" == "0" goto init
25 |
26 | echo.
27 | echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
28 | echo.
29 | echo Please set the JAVA_HOME variable in your environment to match the
30 | echo location of your Java installation.
31 |
32 | goto fail
33 |
34 | :findJavaFromJavaHome
35 | set JAVA_HOME=%JAVA_HOME:"=%
36 | set JAVA_EXE=%JAVA_HOME%/bin/java.exe
37 |
38 | if exist "%JAVA_EXE%" goto init
39 |
40 | echo.
41 | echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME%
42 | echo.
43 | echo Please set the JAVA_HOME variable in your environment to match the
44 | echo location of your Java installation.
45 |
46 | goto fail
47 |
48 | :init
49 | @rem Get command-line arguments, handling Windows variants
50 |
51 | if not "%OS%" == "Windows_NT" goto win9xME_args
52 |
53 | :win9xME_args
54 | @rem Slurp the command line arguments.
55 | set CMD_LINE_ARGS=
56 | set _SKIP=2
57 |
58 | :win9xME_args_slurp
59 | if "x%~1" == "x" goto execute
60 |
61 | set CMD_LINE_ARGS=%*
62 |
63 | :execute
64 | @rem Setup the command line
65 |
66 | set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar
67 |
68 | @rem Execute Gradle
69 | "%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %CMD_LINE_ARGS%
70 |
71 | :end
72 | @rem End local scope for the variables with windows NT shell
73 | if "%ERRORLEVEL%"=="0" goto mainEnd
74 |
75 | :fail
76 | rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of
77 | rem the _cmd.exe /c_ return code!
78 | if not "" == "%GRADLE_EXIT_CONSOLE%" exit 1
79 | exit /b 1
80 |
81 | :mainEnd
82 | if "%OS%"=="Windows_NT" endlocal
83 |
84 | :omega
85 |
--------------------------------------------------------------------------------
/settings.gradle:
--------------------------------------------------------------------------------
1 | include ':app'
2 |
--------------------------------------------------------------------------------