Михаиллл
Михаиллл08 грудня 2019 р. 07:32

Как распознать лицо в OpenCV используя cv::face::drawFacemarks()

OpenCV

Добрый день.
Хотел бы распознать лицо с использованием OpenCV.
Тут нашел пример, кое что сделал, что бы его запустить, но остановился на facemark->loadModel();
Скажите пожалуйста, какая модель нужна?
Есть ли примеры распознавания лица на с++?

        std::vector<cv::Rect> faces;
        std::vector<std::vector<cv::Point2f> > landmarks;
        //cv::Ptr<cv::face::Facemark> facemark = cv::face::createFacemarkLBF();
        //cv::Ptr<cv::face::Facemark> facemark = cv::face::createFacemarkAAM();
        cv::Ptr<cv::face::Facemark> facemark = cv::face::createFacemarkKazemi();
        facemark->loadModel();

        facemark->getFaces(img, faces);
        facemark->fit(img, faces, landmarks);
        for(int j=0;j<rects.size();j++){
            cv::face::drawFacemarks(frame, landmarks[j], Scalar(0,0,255));
        }
Рекомендуємо хостинг TIMEWEB
Рекомендуємо хостинг TIMEWEB
Стабільний хостинг, на якому розміщується соціальна мережа EVILEG. Для проектів на Django радимо VDS хостинг.

Вам це подобається? Поділіться в соціальних мережах!

4
Михаиллл
  • 08 грудня 2019 р. 10:19

Спасибо, но у меня выдает ошибки в файле drawLandmarks.hpp.
Скажите пожалуйста, у Вас компилируется?

    qml_puthon_user
    • 08 грудня 2019 р. 10:21

    Тут не подскажу, пишу на питоне.)

      Михаиллл
      • 11 грудня 2019 р. 08:12
      • Відповідь була позначена як рішення.

      Так работает.
      Взял этот пример https://api-2d3d-cad.com/face_recognition_with_opencv/

      void MainWindow::on_pushButton_4_clicked() //фото определение лица
      {
      
          // Load Face cascade (.xml file)
          //cv::CascadeClassifier face_cascade;
          //face_cascade.load("haarcascade_frontalface_alt2.xml");
      
      
      
          //qDebug()<<myImageOriginal.format();
      
          //cvMatOriginal = cv::imread("dragon.jpeg");  //0 - 3 количество цветов
      
          //myImageOriginal.load(":/Images/Images/1.jpg");
          //ui->label1->setPixmap(QPixmap::fromImage(myImageOriginal,Qt::AutoColor).scaled(ui->label1->width(), ui->label1->height(), Qt::KeepAspectRatio));
          cv::Mat mat(myImageOriginal.height(), myImageOriginal.width(), CV_8UC4, myImageOriginal.bits());
          //cv::cvtColor(mat, cvMatProcessed, cv::COLOR_BGR2RGB);
          cvMatOriginal = mat;
      
      
          if(!cvMatOriginal.data){
              qDebug()<<"not load image in cv::Mat";
          }
          else{
              qDebug()<<"load image in cv::Mat";
      
      
              std::vector<cv::Rect> faces;
              std::vector<std::vector<cv::Point2f> > landmarks;
              cv::Ptr<cv::face::Facemark> facemark = cv::face::createFacemarkLBF();
              //cv::Ptr<cv::face::Facemark> facemark = cv::face::createFacemarkAAM();
              //cv::Ptr<cv::face::Facemark> facemark = cv::face::createFacemarkKazemi();
              facemark->loadModel("lbfmodel.yaml");
              CascadeClassifier faceDetector("haarcascade_frontalface_alt2.xml");
              Mat frame, gray;
              frame = cvMatOriginal;
              cvtColor(frame, gray, COLOR_BGR2GRAY);
              faceDetector.detectMultiScale(gray, faces);
              bool success = facemark->fit(frame, faces, landmarks);
              if (success)
              {
                  // If successful, render the landmarks on the face
                  for (size_t i = 0; i < faces.size(); i++)
                  {
                      cv::rectangle(frame, faces[i], Scalar(0, 255, 0), 3);
                  }
              }
      
      
      
              cv::cvtColor(cvMatOriginal, cvMatProcessed, cv::COLOR_BGR2RGB); //перевод BRG в RGB
              QImage imageFromCvMat = QImage((uchar*) cvMatProcessed.data, cvMatProcessed.cols, cvMatProcessed.rows, cvMatProcessed.step, QImage::Format_RGB888); //перевод Мат в QImage
      
      
              qDebug()<<imageFromCvMat.size()<<myImageOriginal.size()<<cvMatOriginal.rows;
              ui->label2->setPixmap(QPixmap::fromImage(imageFromCvMat, Qt::AutoColor).scaled(ui->label2->width(), ui->label2->height(), Qt::KeepAspectRatio));
          }
      
      
      }
      

        Коментарі

        Only authorized users can post comments.
        Please, Log in or Sign up
        AD

        C++ - Тест 004. Указатели, Массивы и Циклы

        • Результат:50бали,
        • Рейтинг балів-4
        m
        • molni99
        • 26 жовтня 2024 р. 01:37

        C++ - Тест 004. Указатели, Массивы и Циклы

        • Результат:80бали,
        • Рейтинг балів4
        m
        • molni99
        • 26 жовтня 2024 р. 01:29

        C++ - Тест 004. Указатели, Массивы и Циклы

        • Результат:20бали,
        • Рейтинг балів-10
        Останні коментарі
        ИМ
        Игорь Максимов22 листопада 2024 р. 11:51
        Django - Підручник 017. Налаштуйте сторінку входу до Django Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
        Evgenii Legotckoi
        Evgenii Legotckoi31 жовтня 2024 р. 14:37
        Django - Урок 064. Як написати розширення для Python Markdown Добрый день. Да, можно. Либо через такие же плагины, либо с постобработкой через python библиотеку Beautiful Soup
        A
        ALO1ZE19 жовтня 2024 р. 08:19
        Читалка файлів fb3 на Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
        ИМ
        Игорь Максимов05 жовтня 2024 р. 07:51
        Django - Урок 064. Як написати розширення для Python Markdown Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
        d
        dblas505 липня 2024 р. 11:02
        QML - Урок 016. База даних SQLite та робота з нею в QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
        Тепер обговоріть на форумі
        Evgenii Legotckoi
        Evgenii Legotckoi24 червня 2024 р. 15:11
        добавить qlineseries в функции Я тут. Работы оень много. Отправил его в бан.
        t
        tonypeachey115 листопада 2024 р. 06:04
        google domain [url=https://google.com/]domain[/url] domain [http://www.example.com link title]
        NSProject
        NSProject04 червня 2022 р. 03:49
        Всё ещё разбираюсь с кешем. В следствии прочтения данной статьи. Я принял для себя решение сделать кеширование свойств менеджера модели LikeDislike. И так как установка evileg_core для меня не была возможна, ибо он писался…
        9
        9Anonim25 жовтня 2024 р. 09:10
        Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…

        Слідкуйте за нами в соціальних мережах