X-Git-Url: http://47.100.26.94:8080/?a=blobdiff_plain;f=app%2Fsrc%2Fmain%2Fjava%2Fai%2Fsuanzi%2Frtmpclient%2FFfmpeg.java;h=d0556a73783a45ea2a1d113220c869ba4266fef2;hb=831cc09829bc6e18d8d0d8bb78063e89ea565ce9;hp=da3aed6c0cd67656b2ddc3996562ce2b7a325ca8;hpb=3e977e8fa8df4d0f336fd4dfce40168fcdfc0b07;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 da3aed6..d0556a7 100644 --- a/app/src/main/java/ai/suanzi/rtmpclient/Ffmpeg.java +++ b/app/src/main/java/ai/suanzi/rtmpclient/Ffmpeg.java @@ -1,11 +1,16 @@ package ai.suanzi.rtmpclient; +import android.util.Log; + public class Ffmpeg { static { - System.loadLibrary("x264"); - System.loadLibrary("postproc"); + 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"); @@ -15,10 +20,29 @@ 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(); + inithaha(640, 480); + //getPerfectDevice(); + } + + public native String getVersion(); - public native int init(int width, int height); + public native void init(); + public native int inithaha(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); }