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=fae8409b985f89b2b750c0aa05a313ba61bb361b;hb=061580c83656bf358b01a6b78fd22ae9bd497728;hp=83ab06e46f43e7d0473209bfb54c7873e6c2ad0b;hpb=92dcc922db72fe328a68ae80d09ae5d391384c44;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 83ab06e..fae8409 100644 --- a/app/src/main/java/ai/suanzi/rtmpclient/Ffmpeg.java +++ b/app/src/main/java/ai/suanzi/rtmpclient/Ffmpeg.java @@ -1,9 +1,16 @@ 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"); @@ -13,5 +20,28 @@ public class Ffmpeg { 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, String url); + public native int preview(Object surface); + public native String getPerfectDevice(); + public native int test(int fd); }