//IntPtr pd = IntPtr.Zero; private void ProcessFrame(RAWImage frame) { //if (pd == IntPtr.Zero) //{ // pd = CV.PedestrianDetectorInit(); // CV.PedestrianDetectorSetEngineSettings(pd, 0.5, 5, true, Color.YellowGreen); //} //long time; //CVPedestrians items = new CVPedestrians(); //int count = CV.PedestrianDetectorProcess(pd, frame, ref items, out time); //Trace.WriteLine($"Count: {count}, time: {time}"); var faces = faceDetector?.Process(frame); carCounter?.Process(frame); pedestrianDetector?.Process(frame); if (cbFDMosaic.Checked) { foreach (var face in faces) { var rect = face.Position; rect.Top -= 10; if (rect.Top < 0) { rect.Top = 0; } rect.Left -= 10; if (rect.Left < 0) { rect.Left = 0; } rect.Bottom += 10; if (rect.Bottom > frame.Height) { rect.Bottom = frame.Height; } rect.Right += 10; if (rect.Right > frame.Width) { rect.Right = frame.Width; } MFP.EffectMosaicROI(frame.Data, frame.Width, frame.Height, 45, rect); } } }
//IntPtr pd = IntPtr.Zero; private void ProcessFrame(RAWImage frame) { //if (pd == IntPtr.Zero) //{ // pd = CV.PedestrianDetectorInit(); // CV.PedestrianDetectorSetEngineSettings(pd, 0.5, 5, true, Color.YellowGreen); //} //long time; //CVPedestrians items = new CVPedestrians(); //int count = CV.PedestrianDetectorProcess(pd, frame, ref items, out time); //Trace.WriteLine($"Count: {count}, time: {time}"); faceDetector?.Process(frame); carCounter?.Process(frame); pedestrianDetector?.Process(frame); }