X-Git-Url: http://47.100.26.94:8080/?a=blobdiff_plain;ds=sidebyside;f=app%2Fsrc%2Fmain%2Fjava%2Fai%2Fsuanzi%2Frtmpclient%2FFfmpeg.java;h=eb3203f553d8ba337dadd64be0cd29804ac0fb8b;hb=b7202442677d0cf41e6e59870cd6c34e5619b8b9;hp=c705c01361bfc40f8843cc14276eed79807e1d91;hpb=214619593e74f6a04fa25f3614a99cf6b9704da5;p=rtmpclient.git diff --git a/app/src/main/java/ai/suanzi/rtmpclient/Ffmpeg.java b/app/src/main/java/ai/suanzi/rtmpclient/Ffmpeg.java index c705c01..eb3203f 100644 --- a/app/src/main/java/ai/suanzi/rtmpclient/Ffmpeg.java +++ b/app/src/main/java/ai/suanzi/rtmpclient/Ffmpeg.java @@ -1,11 +1,47 @@ package ai.suanzi.rtmpclient; +import android.util.Log; + public class Ffmpeg { static { + String arch = System.getProperty("os.arch"); + if (arch.equals("i686")){ + System.loadLibrary("x264"); + } + System.loadLibrary("avutil"); + System.loadLibrary("postproc"); + System.loadLibrary("swresample"); + System.loadLibrary("swscale"); + System.loadLibrary("avcodec"); + System.loadLibrary("avdevice"); + System.loadLibrary("avfilter"); + System.loadLibrary("avformat"); System.loadLibrary("ffmpeg-jni"); + } + + private static Ffmpeg instance = new Ffmpeg(); + public static Ffmpeg getInstance(){ + return instance; } + private Ffmpeg(){ + Log.e("Ffmpeg", "init"); + init(); + //getPerfectDevice(); + } + + public native String getVersion(); + public native void init(); + public native int init(int width, int height); + public native int flush(); + public native int close(); + public native int process(byte[] data); + public native int play(Object surface, String fname); + public native int push(Object surface); + public native int preview(Object surface); + public native String getPerfectDevice(); + public native int test(int fd); }