Михаиллл
МихаилллЖел. 8, 2019, 7: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
Михаиллл
  • Жел. 8, 2019, 10:19 Т.Ж.

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

    qml_puthon_user
    • Жел. 8, 2019, 10:21 Т.Ж.

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

      Михаиллл
      • Жел. 11, 2019, 8: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));
          }
      
      
      }
      

        Пікірлер

        Тек рұқсаты бар пайдаланушылар ғана пікір қалдыра алады.
        Кіріңіз немесе Тіркеліңіз
        OI
        • Ora Iro
        • Жел. 24, 2024, 6:38 Т.Ж.

        C++ - Тест 001. Первая программа и типы данных

        • Нәтиже:40ұпай,
        • Бағалау ұпайлары-8
        AD

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

        • Нәтиже:50ұпай,
        • Бағалау ұпайлары-4
        m
        • molni99
        • Қаз. 26, 2024, 1:37 Т.Ж.

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

        • Нәтиже:80ұпай,
        • Бағалау ұпайлары4
        Соңғы пікірлер
        ИМ
        Игорь МаксимовҚар. 22, 2024, 11:51 Т.Ж.
        Django - Оқулық 017. Теңшелген Django кіру беті Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
        Evgenii Legotckoi
        Evgenii LegotckoiҚаз. 31, 2024, 2:37 Т.Қ.
        Django - Сабақ 064. Python Markdown кеңейтімін қалай жазуға болады Добрый день. Да, можно. Либо через такие же плагины, либо с постобработкой через python библиотеку Beautiful Soup
        A
        ALO1ZEҚаз. 19, 2024, 8:19 Т.Ж.
        Qt Creator көмегімен fb3 файл оқу құралы Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
        ИМ
        Игорь МаксимовҚаз. 5, 2024, 7:51 Т.Ж.
        Django - Сабақ 064. Python Markdown кеңейтімін қалай жазуға болады Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
        d
        dblas5Шілде 5, 2024, 11:02 Т.Ж.
        QML - Сабақ 016. SQLite деректер қоры және онымен QML Qt-та жұмыс істеу Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
        Енді форумда талқылаңыз
        Evgenii Legotckoi
        Evgenii LegotckoiМаусым 24, 2024, 3:11 Т.Қ.
        добавить qlineseries в функции Я тут. Работы оень много. Отправил его в бан.
        t
        tonypeachey1Қар. 15, 2024, 6:04 Т.Ж.
        google domain [url=https://google.com/]domain[/url] domain [http://www.example.com link title]
        NSProject
        NSProjectМаусым 4, 2022, 3:49 Т.Ж.
        Всё ещё разбираюсь с кешем. В следствии прочтения данной статьи. Я принял для себя решение сделать кеширование свойств менеджера модели LikeDislike. И так как установка evileg_core для меня не была возможна, ибо он писался…
        9
        9AnonimҚаз. 25, 2024, 9:10 Т.Ж.
        Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…

        Бізді әлеуметтік желілерде бақылаңыз