Михаиллл
Михаиллл8. Dezember 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
Stabiles Hosting des sozialen Netzwerks EVILEG. Wir empfehlen VDS-Hosting für Django-Projekte.

Magst du es? In sozialen Netzwerken teilen!

4
Михаиллл
  • 8. Dezember 2019 10:19

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

    qml_puthon_user
    • 8. Dezember 2019 10:21

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

      Михаиллл
      • 11. Dezember 2019 08:12
      • Die Antwort wurde als Lösung markiert.

      Так работает.
      Взял этот пример 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));
          }
      
      
      }
      

        Kommentare

        Nur autorisierte Benutzer können Kommentare posten.
        Bitte Anmelden oder Registrieren
        Letzte Kommentare
        ИМ
        Игорь Максимов5. Oktober 2024 07:51
        Django – Lektion 064. So schreiben Sie eine Python-Markdown-Erweiterung Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
        d
        dblas55. Juli 2024 11:02
        QML - Lektion 016. SQLite-Datenbank und das Arbeiten damit in QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
        k
        kmssr8. Februar 2024 18:43
        Qt Linux - Lektion 001. Autorun Qt-Anwendung unter Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
        Qt WinAPI - Lektion 007. Arbeiten mit ICMP-Ping in Qt Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
        EVA
        EVA25. Dezember 2023 10:30
        Boost - statisches Verknüpfen im CMake-Projekt unter Windows Ошибка LNK1104 часто возникает, когда компоновщик не может найти или открыть файл библиотеки. В вашем случае, это файл libboost_locale-vc142-mt-gd-x64-1_74.lib из библиотеки Boost для C+…
        Jetzt im Forum diskutieren
        J
        JacobFib17. Oktober 2024 03:27
        добавить qlineseries в функции Пользователь может получить любые разъяснения по интересующим вопросам, касающимся обработки его персональных данных, обратившись к Оператору с помощью электронной почты https://topdecorpro.ru…
        JW
        Jhon Wick1. Oktober 2024 15:52
        Indian Food Restaurant In Columbus OH| Layla’s Kitchen Indian Restaurant If you're looking for a truly authentic https://www.laylaskitchenrestaurantohio.com/ , Layla’s Kitchen Indian Restaurant is your go-to destination. Located at 6152 Cleveland Ave, Colu…
        КГ
        Кирилл Гусарев27. September 2024 09:09
        Не запускается программа на Qt: точка входа в процедуру не найдена в библиотеке DLL Написал программу на C++ Qt в Qt Creator, сбилдил Release с помощью MinGW 64-bit, бинарнику напихал dll-ки с помощью windeployqt.exe. При попытке запуска моей сбилженной программы выдаёт три оши…
        F
        Fynjy22. Juli 2024 04:15
        при создании qml проекта Kits есть но недоступны для выбора Поставил Qt Creator 11.0.2. Qt 6.4.3 При создании проекта Qml не могу выбрать Kits, они все недоступны, хотя настроены и при создании обычного Qt Widget приложения их можно выбрать. В чем может …

        Folgen Sie uns in sozialen Netzwerken