From 5f12988a77d078a5e5155c9a301e45bfd288d7e5 Mon Sep 17 00:00:00 2001 From: xuxiuxi <xuxiuxi@454eff88-639b-444f-9e54-f578c98de674> Date: 星期五, 11 八月 2017 16:02:50 +0800 Subject: [PATCH] --- VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/fragment/SurveillanceFragment.java | 110 +++++++++++++++++++++++++++++++++++++++++++++++++++++- 1 files changed, 107 insertions(+), 3 deletions(-) diff --git a/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/fragment/SurveillanceFragment.java b/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/fragment/SurveillanceFragment.java index 01d36d3..49b6366 100644 --- a/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/fragment/SurveillanceFragment.java +++ b/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/fragment/SurveillanceFragment.java @@ -1,7 +1,10 @@ package cn.com.basic.face.fragment; -import android.app.AlarmManager; import android.content.Context; +import android.graphics.Bitmap; +import android.graphics.BitmapFactory; +import android.graphics.Canvas; +import android.net.Uri; import android.net.wifi.WifiManager; import android.os.Build; import android.os.Bundle; @@ -17,12 +20,17 @@ import com.bsk.zhangbo.demoforbsk.R; +import cn.com.basic.face.base.BaseApplication; import cn.com.basic.face.base.BaseFragment; import cn.com.basic.face.base.MainActivity; import cn.com.basic.face.discern.common.CommonVariables; -import cn.com.basic.face.service.DeviceMng; +import cn.com.basic.face.discern.query.item.SurveillanceQueryItem; import cn.com.basic.face.thread.StartCameraThread; +import cn.com.basic.face.util.FileUtil; +import cn.com.basic.face.util.MjpegInputStream; +import cn.com.basic.face.util.MjpegView; +import cn.com.basic.face.util.NativeImg; import cn.com.basic.face.util.RtspFaceNative; import cn.com.basic.face.service.SurveillanceMng; @@ -32,8 +40,9 @@ import com.lidroid.xutils.view.annotation.ViewInject; import com.lidroid.xutils.view.annotation.event.OnClick; +import com.luxand.FSDK; -import java.io.DataOutputStream; +import java.io.File; import java.net.InetAddress; import java.net.NetworkInterface; import java.net.SocketException; @@ -67,6 +76,8 @@ private RelativeLayout fragment_supervisory_enter_camera_relative_layout; @ViewInject(R.id.fragment_surveillance_bottom_linear_layout) private LinearLayout fragment_surveillance_bottom_linear_layout; + @ViewInject(R.id.myVideoView) + private MjpegView myVideoView; StartCameraThread startEnterCameraThread = null; StartCameraThread startExitCameraThread = null; @@ -187,6 +198,99 @@ fragment_supervisory_enter_camera_relative_layout.addView(MainActivity.getInstance().mPreview); fragment_supervisory_enter_camera_relative_layout.addView(MainActivity.getInstance().mDraw); } + Uri vidUri = Uri.parse("http://192.168.1.13:8080/video"); + //myVideoView.setVideoURI(vidUri); + //myVideoView.setVideoPath("http://192.168.1.13:8080/video"); + //myVideoView.start(); + if (1!=1) { + new Thread() { + @Override + public void run() { + FSDK.HCamera cameraHandle = new FSDK.HCamera(); + boolean opened = false; + int res = FSDK.ActivateLibrary(""); + if (res == FSDK.FSDKE_OK) { + FSDK.Initialize(); + + FSDK.FSDK_VIDEOCOMPRESSIONTYPE type = new FSDK.FSDK_VIDEOCOMPRESSIONTYPE(); + type.type=FSDK.FSDK_VIDEOCOMPRESSIONTYPE.FSDK_MJPEG; + FSDK.OpenIPVideoCamera(type,"http://192.168.1.13:8080/video", + "username","password",500, cameraHandle); + opened = true; + } + int tracId = 0; + while(true) { + try { + if (opened) { + FSDK.HImage imageHandle = new FSDK.HImage(); + int res1 = FSDK.GrabFrame(cameraHandle, imageHandle); + if (res1 == FSDK.FSDKE_OK) {// grab the current frame from the camera + FSDK.TFaces FacePositions = new FSDK.TFaces(); + int res3 = FSDK.DetectMultipleFaces(imageHandle, FacePositions); + if(res3 == FSDK.FSDKE_OK) { + if (FacePositions.faces != null) { + for (FSDK.TFacePosition fp : FacePositions.faces ) { + System.out.println("2:"+fp.xc); + int x1 = (int)(fp.xc - 1.2*fp.w / 2); + int y1 = (int)(fp.yc - 1.4*fp.w / 2); + int x2 = (int)(fp.xc + 1.2*fp.w / 2); + int y2 = (int)(fp.yc + 1.4*fp.w / 2); + FSDK.HImage img2 = new FSDK.HImage(); + FSDK.CreateEmptyImage(img2); + FSDK.CopyRect(imageHandle, x1, y1, x2, y2, img2); + FSDK.SetJpegCompressionQuality(100); + String fileName = MainActivity.getInstance().getFilesDir()+"/"+System.currentTimeMillis()+".jpg"; + int res4 = FSDK.SaveImageToFile(img2, fileName); + if (res4 == FSDK.FSDKE_OK) { + System.out.println(fileName); + } + List bitmapList = new ArrayList(); + for (int i = 0; i < 1; i++) { + NativeImg nativeImg = new NativeImg(); + nativeImg.image = FileUtil.readFile(new File(fileName)); + nativeImg.size = nativeImg.image.length; + SurveillanceQueryItem surveillanceQueryItem = new SurveillanceQueryItem(); + surveillanceQueryItem.setNativeImg(nativeImg); + nativeImg.st_track_id = ++tracId; + surveillanceQueryItem.setStTrackId(nativeImg.st_track_id); + BitmapFactory.Options options = new BitmapFactory.Options(); + options.inMutable = true; + Bitmap bmp = BitmapFactory.decodeByteArray(nativeImg.image, 0, nativeImg.image.length, options); + Canvas canvas1 = new Canvas(bmp); + + surveillanceQueryItem.setBitmap(bmp); + surveillanceQueryItem.setWidth("100"); + surveillanceQueryItem.setHeight("100"); + surveillanceQueryItem.setRegisterOrCheckIn(CommonVariables.Surveillance.OFFLINE_SURVEILLANCE_ITEM_TYPE); + surveillanceQueryItem.setCreateTime(new Date()); + bitmapList.add(surveillanceQueryItem); + + if (BaseApplication.getInstance().networkAvailable()) { + SurveillanceMng.getInstance().addBitmap(bitmapList, nativeImg.image, 0, CommonVariables.Camera.IN+"", nativeImg.image); + } else { + SurveillanceMng.getInstance().addOfflineBitmap(bitmapList, nativeImg.image, CommonVariables.Camera.IN+""); + } + } + + } + } + } + + } + } + Thread.sleep(5); + } catch (Exception e) { + e.printStackTrace(); + } + } + /*myVideoView.setSource(MjpegInputStream.read("http://192.168.1.13:8080/video")); + myVideoView.setDisplayMode(MjpegView.SIZE_BEST_FIT); + myVideoView.showFps(false); + */ + } + }.start(); + } + //fragment_supervisory_enter_camera.setVisibility(View.GONE); fragment_supervisory_enter_camera.getHolder().addCallback(new SurfaceHolder.Callback() { public void surfaceCreated(SurfaceHolder holder) { if (CommonVariables.EMULATOR) { -- Gitblit v1.8.0