X-Git-Url: http://47.100.26.94:8080/?a=blobdiff_plain;f=app%2Fsrc%2Fmain%2Fjava%2Fai%2Fsuanzi%2Frtmpclient%2FFfmpeg.java;h=4d61c9ddb7e4a661edace1b658d9b3f9a709c75b;hb=f04505b3a75a030de282ff394e8e11d2e93ace17;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..4d61c9d 100644 --- a/app/src/main/java/ai/suanzi/rtmpclient/Ffmpeg.java +++ b/app/src/main/java/ai/suanzi/rtmpclient/Ffmpeg.java @@ -1,9 +1,18 @@ package ai.suanzi.rtmpclient; +import android.util.Log; + +import org.apache.log4j.Logger; + 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 +22,36 @@ 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(); + } + + private Logger gLogger = Logger.getLogger("FFmpeg"); + public void print(String str){ + gLogger.error(str); + } + public native String getVersion(); + public native void init(); + public native int inithaha(int width, int height); + public native int initnew (int width, int height, String url); + //public native init inithahurl(ini) + 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); + public native void setRtmpUrl(String url); }