From a5fc9f0acaa8b92c8d78f060cd4cdabab2793c62 Mon Sep 17 00:00:00 2001 From: houxiao <houxiao@454eff88-639b-444f-9e54-f578c98de674> Date: 星期四, 17 八月 2017 10:30:34 +0800 Subject: [PATCH] merge home base --- VisitFace/RtspNativeCodec/app/src/main/java/cn/com/basic/face/util/RtspFaceNative.java | 97 ++++++++++++++++++++++++++++++++++++++++++++---- 1 files changed, 88 insertions(+), 9 deletions(-) diff --git a/VisitFace/RtspNativeCodec/app/src/main/java/cn/com/basic/face/util/RtspFaceNative.java b/VisitFace/RtspNativeCodec/app/src/main/java/cn/com/basic/face/util/RtspFaceNative.java index 4267ef1..c058faf 100644 --- a/VisitFace/RtspNativeCodec/app/src/main/java/cn/com/basic/face/util/RtspFaceNative.java +++ b/VisitFace/RtspNativeCodec/app/src/main/java/cn/com/basic/face/util/RtspFaceNative.java @@ -1,45 +1,124 @@ package cn.com.basic.face.util; +import android.graphics.Canvas; +import android.graphics.drawable.Drawable; import android.util.Log; import android.view.Surface; +import android.view.SurfaceHolder; +import android.widget.ImageButton; +import android.graphics.Bitmap; +import android.widget.ImageView; + +import com.example.nativecodec.NativeCodec; + +import java.nio.ByteBuffer; + import java.util.ArrayList; /** * Created by houxiao on 2017/3/21 0021. */ +class NativeImgIdx { + public int st_track_id; + public int offset; + public int size; + public int type; + public int width; + public int height; +} + +class RefByteArray +{ + public byte[] arr; + public byte[][] arr2; +} + + public class RtspFaceNative { //cn.com.basic.face.util.RtspFaceNative public static native void init(); - public static native void setSurface(int cameraIdx, Surface surface); + public static native void setLocalIP(String ipaddr); + public static native void setSurface(int cameraIdx, Surface surfaceRender); public static native boolean createPlayer(int cameraIdx, String uri); public static native void shutdown(int cameraIdx); // typedef void (* Java_com_example_nativecodec_NativeCodec_FaceCallback_func)(int cameraIdx, int count); public static native boolean setFaceCallback(int cameraIdx, String className, String funcName); public static native void lockFace(int cameraIdx); public static native void releaseFace(int cameraIdx); - public static native int getFaceList(int cameraIdx, byte[] faceListPb); - public static native ArrayList<NativeImgIdx> getFaceImages(int cameraIdx, byte[] faceImages); + public static native int getFaceList(int cameraIdx, int dbId, RefByteArray faceListPb); + //public static native ArrayList<NativeImgIdx> getFaceImages(int cameraIdx, RefByteArray faceImages); + public static native ArrayList<NativeImg> getFaceImages(int cameraIdx); + + public static native void dbgFaceAdd(NativeImg faceImage); + public static native String dbgGetLog(); + public static native void dbgSetStfaceLicense(String lic); + + //public static native void dbgReadTexture(); + + public static native void setCaptureSurface(Surface surfaceCapture); + public static native void startCapturePlayer(String uri); + public static native void stopCapturePlayer(); + public static native ArrayList<NativeImg> getCaptureImages(); + public static native void teleCall(String phoneNumber); + public static native void teleHang(); + public static native void teleShutdown(); + + public static native void setFaceLabel(int cameraIdx, int stTrackId, String phoneNumber); + + public static int COMPANY_ID = 1001; public static void faceCallBack(int cameraIdx, int count) { Log.i("@@@", "RtspFaceNative.faceCallBack, cameraIdx=" + cameraIdx + ", count=" + count); + // something else + if (count <= 0) + return; + lockFace(cameraIdx); - byte[] faceListPb = new byte[1024 * 1024 * 1]; - int s = getFaceList(cameraIdx, faceListPb); + RefByteArray faceListPb = new RefByteArray(); + int s = getFaceList(cameraIdx, COMPANY_ID, faceListPb); Log.i("@@@", "RtspFaceNative.faceCallBack, getFaceList, cameraIdx=" + cameraIdx + ", size=" + s); - byte[] faceImages = new byte[1024 * 1024 * 1]; - ArrayList<NativeImgIdx> faceImagesIdx = getFaceImages(cameraIdx, faceImages); + //RefByteArray faceImages = new RefByteArray(); + //ArrayList<NativeImgIdx> faceImagesIdx = getFaceImages(cameraIdx, faceImages); + //int c = 0; + //if (faceImagesIdx != null) + // c = faceImagesIdx.size(); + //Log.i("@@@", "RtspFaceNative.faceCallBack, getFaceImages, cameraIdx=" + cameraIdx + ", count=" + c); + + ArrayList<NativeImg> faceImages = getFaceImages(cameraIdx); int c = 0; - if (faceImagesIdx != null) - c = faceImagesIdx.size(); + if (faceImages != null) + c = faceImages.size(); Log.i("@@@", "RtspFaceNative.faceCallBack, getFaceImages, cameraIdx=" + cameraIdx + ", count=" + c); + for (int i = 0; i < c; i++) + { + Log.i("@@@", "cameraIdx=" + cameraIdx + + ", i=" + i + + ", st_track_id=" + faceImages.get(i).st_track_id+ + ", size=" + faceImages.get(i).size+ + ", w=" + faceImages.get(i).width + + ", h=" + faceImages.get(i).height + + ", image[0]=" + faceImages.get(i).image[0] + + ", image[1]=" + faceImages.get(i).image[1]); + + if (i == 0) + { + //Bitmap bitmap = Bitmap.createBitmap(faceImages.get(i).width, faceImages.get(i).height, Bitmap.Config.RGB_565); + //ByteBuffer byteBuffer = ByteBuffer.wrap(faceImages.get(i).image, 0, faceImages.get(i).size); + //bitmap.copyPixelsFromBuffer(byteBuffer); + //NativeCodec.setFaceDrawable(bitmap); + + NativeCodec.setFaceDrawable(faceImages.get(i)); + } + } + releaseFace(cameraIdx); } -- Gitblit v1.8.0