Лицо Regonion OpenCV 2.2

Привет Я использую код для обнаружения лица. но я не собираюсь продолжать распознавание лиц. Но я получаю стек здесь, где, как для следующего шага. Тем не менее, я использую Эмгу версии 2.2

            if (faces.Length > 0)
            {
                foreach (var face in faces)
                {
                    ImageFrame.Draw(face.rect, new Bgr(Color.Green), 2);
                    //Extract face 
                    ExtractedFace = new Bitmap(face.rect.Width, face.rect.Height);

                    FaceConvas = Graphics.FromImage(ExtractedFace);
                    FaceConvas.DrawImage(GrayBmpInput, 0, 0, face.rect, GraphicsUnit.Pixel); 
                    ExtcFacesArr[faceNo] = ExtractedFace;
                    faceNo++;

                }

                faceNo = 0; 
                picExtcFaces.Image = ExtcFacesArr[faceNo];

                CamImageBox.Image = ImageFrame;
            }
        }

Где я должен продолжить распознавание лиц и иметь какие-либо хорошие ссылки онлайн в коде C#?

1 ответ

Решение

Ваш код почти верен, но я думаю, что вы не представляете, что делать дальше. Я делаю распознавание лиц в одном из моих приложений для отображения маски на лице. Я делаю так.

Image mask = Image.FromFile("mask.png");
public Bitmap getFacedBitmap(Bitmap bbb)
    {
        using (Image<Bgr, byte> nextFrame = new Image<Bgr, byte>(bbb))
        {
            if (nextFrame != null)
            {
                // there's only one channel (greyscale), hence the zero index
                //var faces = nextFrame.DetectHaarCascade(haar)[0];
                Image<Gray, byte> grayframe = nextFrame.Convert<Gray, byte>();
                //Image<Gray, Byte> gray = nextFrame.Convert<Gray, Byte>();

                var faces = grayframe.DetectHaarCascade(haar, 1.3, 2, HAAR_DETECTION_TYPE.SCALE_IMAGE, new Size(nextFrame.Width / 8, nextFrame.Height / 8))[0];
                if (faces.Length > 0)
                {
                   foreach (var face in faces)
                  {
                      //ImageFrame.Draw(face.rect, new Bgr(Color.Green), 2);
                      //                     
                      using(Graphics g = Graphics.FromImage(bbb))
                     {
                       g.DrawImage(mask,face.rect);
                       g.Save()
                     }
                  }

               }
           }
       }
    retun bbb;
  }
Другие вопросы по тегам