色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

Linux下QT配合OpenCV完成圖像處理(實現人臉檢測)

DS小龍哥-嵌入式技術 ? 來源:DS小龍哥-嵌入式技術 ? 作者:DS小龍哥-嵌入式技 ? 2022-08-14 09:28 ? 次閱讀

一、環境介紹

ubuntu版本: VM虛擬機運行ubuntu18.04 64位

OpenCV版本: 3.4.9

QT版本: 5.12

OpenCV 是一個基于 BSD 許可(開源)發行的跨平臺計算機視覺機器學習軟件庫,可以運行在 Linux、Windows、Android 和 Mac OS 操作系統上。

OpenCV 的全稱是 Open Source Computer Vision Library,是一個跨平臺的計算機視覺庫。OpenCV 是由英特爾公司發起并參與開發,以 BSD 許可證授權發行,可以在商業和研究領域中免費使用。OpenCV 可用于開發實時的圖像處理、計算機視覺以及模式識別程序。

OpenCV 用 C++語言編寫,它具有 C ++,PythonJavaMATLAB 接口,并支持 Windows,Linux,Android 和 Mac OS,OpenCV 主要傾向于實時視覺應用,并在可用時利用 MMX 和 SSE 指令, 如今也提供對于 C#、Ch、Ruby,GO 的支持。

二、建立QT工程加入OpenCV依賴庫

下面編寫例子很簡單,使用OpenCV自帶的分類器,檢測一張圖中的人臉,并圈出來。

opencv源碼自帶的人臉檢測分類器目錄:opencv-3.4.9/data/haarcascades_cuda/haarcascade_frontalface_alt2.xml

xxx.pro工程文件代碼:

QT       += core gui

greaterThan(QT_MAJOR_VERSION, 4): QT += widgets

CONFIG += c++11

# The following define makes your compiler emit warnings if you use
# any Qt feature that has been marked deprecated (the exact warnings
# depend on your compiler). Please consult the documentation of the
# deprecated API in order to know how to port your code away from it.
DEFINES += QT_DEPRECATED_WARNINGS

# You can also make your code fail to compile if it uses deprecated APIs.
# In order to do so, uncomment the following line.
# You can also select to disable deprecated APIs only up to a certain version of Qt.
#DEFINES += QT_DISABLE_DEPRECATED_BEFORE=0x060000    # disables all the APIs deprecated before Qt 6.0.0

SOURCES += \
    main.cpp \
    widget.cpp

HEADERS += \
    widget.h

FORMS += \
    widget.ui

# Default rules for deployment.
qnx: target.path = /tmp/$${TARGET}/bin
else: unix:!android: target.path = /opt/$${TARGET}/bin
!isEmpty(target.path): INSTALLS += target

#linu平臺的路徑設置
linux {
#添加opencv頭文件的路徑,需要根據自己的頭文件路徑進行修改
INCLUDEPATH+=/home/wbyq/work_pc/opencv-3.4.9/_install/install/include\
             /home/wbyq/work_pc/opencv-3.4.9/_install/install/include/opencv\
             /home/wbyq/work_pc/opencv-3.4.9/_install/install/include/opencv2

LIBS+=/home/wbyq/work_pc/opencv-3.4.9/_install/install/lib/libopencv_calib3d.so
LIBS+=/home/wbyq/work_pc/opencv-3.4.9/_install/install/lib/libopencv_core.so
LIBS+=/home/wbyq/work_pc/opencv-3.4.9/_install/install/lib/libopencv_dnn.so
LIBS+=/home/wbyq/work_pc/opencv-3.4.9/_install/install/lib/libopencv_features2d.so
LIBS+=/home/wbyq/work_pc/opencv-3.4.9/_install/install/lib/libopencv_flann.so
LIBS+=/home/wbyq/work_pc/opencv-3.4.9/_install/install/lib/libopencv_highgui.so
LIBS+=/home/wbyq/work_pc/opencv-3.4.9/_install/install/lib/libopencv_imgcodecs.so
LIBS+=/home/wbyq/work_pc/opencv-3.4.9/_install/install/lib/libopencv_imgproc.so
LIBS+=/home/wbyq/work_pc/opencv-3.4.9/_install/install/lib/libopencv_ml.so
LIBS+=/home/wbyq/work_pc/opencv-3.4.9/_install/install/lib/libopencv_objdetect.so
LIBS+=/home/wbyq/work_pc/opencv-3.4.9/_install/install/lib/libopencv_photo.so
LIBS+=/home/wbyq/work_pc/opencv-3.4.9/_install/install/lib/libopencv_shape.so
LIBS+=/home/wbyq/work_pc/opencv-3.4.9/_install/install/lib/libopencv_stitching.so
LIBS+=/home/wbyq/work_pc/opencv-3.4.9/_install/install/lib/libopencv_superres.so
LIBS+=/home/wbyq/work_pc/opencv-3.4.9/_install/install/lib/libopencv_videoio.so
LIBS+=/home/wbyq/work_pc/opencv-3.4.9/_install/install/lib/libopencv_video.so
}

widget.cpp文件代碼:

#include "widget.h"
#include "ui_widget.h"

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);
    opencv_face();
}

Widget::~Widget()
{
    delete ui;
}

//分類器的路徑
#define source_xml_addr "/home/wbyq/work_pc/opencv-3.4.9/data/haarcascades_cuda/haarcascade_frontalface_alt2.xml"

//將要檢測的圖片路徑
#define source_pix_addr "/mnt/hgfs/linux-share-dir/1.jpg"

//人臉檢測代碼
void Widget::opencv_face()
{
    static CvMemStorage* storage = 0;
    static CvHaarClassifierCascade* cascade = 0;

    fprintf( stderr, "start------------------------------>1 \n" );

    const char*cascade_name =source_xml_addr;

    //加載分類器
    cascade = (CvHaarClassifierCascade*)cvLoad( cascade_name, 0, 0, 0 );
    if( !cascade )
    {
        fprintf( stderr, "ERROR: Could not load classifier cascade\n" );
        return ;
    }

    //創建內存空間
    storage = cvCreateMemStorage(0);

    //加載需要檢測的圖片
    const char* filename =source_pix_addr;
    IplImage* img = cvLoadImage( filename, 1 );

    if(img ==nullptr )
    {
        fprintf( stderr, "jpg load error! \n" );
        return;
    }

     fprintf( stderr, "start------------------------------>2 \n" );

    double scale=1.2;
    static CvScalar colors[] = {
        {{0,0,255}},{{0,128,255}},{{0,255,255}},{{0,255,0}},
        {{255,128,0}},{{255,255,0}},{{255,0,0}},{{255,0,255}}
    };//Just some pretty colors to draw with
    IplImage* gray = cvCreateImage(cvSize(img->width,img->height),8,1);
    IplImage* small_img=cvCreateImage(cvSize(cvRound(img->width/scale),cvRound(img->height/scale)),8,1);
    cvCvtColor(img,gray, CV_BGR2GRAY);
    cvResize(gray, small_img, CV_INTER_LINEAR);

    cvEqualizeHist(small_img,small_img); //直方圖均衡

    cvClearMemStorage(storage);

    double t = (double)cvGetTickCount();
    CvSeq* objects = cvHaarDetectObjects(small_img,
                                           cascade,
                                           storage,
                                           1.1,
                                           2,
                                           0/*CV_HAAR_DO_CANNY_PRUNING*/,
                                           cvSize(30,30));

       t = (double)cvGetTickCount() - t;

     fprintf( stderr, "start------------------------------>3 \n" );

    //遍歷找到對象和周圍畫盒
    for(int i=0;i<(objects->total);++i)
    {
        CvRect* r=(CvRect*)cvGetSeqElem(objects,i);
        cvRectangle(img, cvPoint(r->x*scale,r->y*scale), cvPoint((r->x+r->width)*scale,(r->y+r->height)*scale), colors[i%8]);
    }

     fprintf( stderr, "start------------------------------>4 \n" );

    for( int i = 0; i < (objects? objects->total : 0); i++ )
    {
        CvRect* r = (CvRect*)cvGetSeqElem( objects, i );
        CvPoint center;
        int radius;
        center.x = cvRound((r->x + r->width*0.5)*scale);
        center.y = cvRound((r->y + r->height*0.5)*scale);
        radius = cvRound((r->width + r->height)*0.25*scale);
        cvCircle( img, center, radius, colors[i%8], 3, 8, 0 );
    }

    show_face(img);  //顯示檢測的結果

    cvReleaseImage(&gray);
    cvReleaseImage(&small_img);

    //釋放圖片
    cvReleaseImage( &img );
}
//顯示檢測的結果
void Widget::show_face(IplImage* img)
{
    /*將opecv的圖片轉為qimage格式*/
    uchar *imgData=(uchar *)img->imageData;

    QImage  my_image(imgData,img->width,img->height,QImage::Format_RGB888);
    my_image =my_image.rgbSwapped(); //BGR格式轉RGB
    QPixmap my_pix; //創建畫圖類

    my_pix.convertFromImage(my_image);

    /*在控件上顯示*/
    ui->label_display_face->setPixmap(my_pix);
}

widget.h文件代碼:

#ifndef WIDGET_H
#define WIDGET_H

#include 
//opencv include
#include 
#include 
#include 

QT_BEGIN_NAMESPACE
namespace Ui { class Widget; }
QT_END_NAMESPACE

class Widget : public QWidget
{
    Q_OBJECT

public:
    Widget(QWidget *parent = nullptr);
    void opencv_face();
    ~Widget();
    void show_face(IplImage* img);
private:
    Ui::Widget *ui;
};
#endif // WIDGET_H

運行代碼檢測結果如下:

img
審核編輯:湯梓紅
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 圖像處理
    +關注

    關注

    27

    文章

    1293

    瀏覽量

    56770
  • Linux
    +關注

    關注

    87

    文章

    11311

    瀏覽量

    209687
  • OpenCV
    +關注

    關注

    31

    文章

    635

    瀏覽量

    41372
收藏 人收藏

    評論

    相關推薦

    樹莓派上使用OpenCV和Python實現實時人臉檢測

    本文介紹了如何在樹莓派上,使用 OpenCV 和 Python 完成人臉檢測項目。該項目不僅描述了識別人臉所需要的具體步驟,同時還提供了很多擴展知識。此外,該項目并不需要讀者了解詳細的
    的頭像 發表于 03-06 09:00 ?5.1w次閱讀

    基于openCV人臉檢測系統的設計

    通過對基于Adaboost人臉檢測算法的研究,利用該算法與計算機視覺類庫openCV進行人臉檢測系統的設計,
    發表于 12-23 14:19

    Qt使用openCV

    使用QtOpenCV進行數字圖像處理了還是很不錯的,參考網上一個帖子分享一經驗:環境:Windows
    發表于 11-22 16:12

    【NanoPi2申請】基于opencv人臉識別門禁系統

    防與監控的系統,望批準!謝謝!項目描述:項目簡述:本項目旨在一個較高性能的嵌入式平臺上搭建一個linux系統,利用opencv編程實現人臉識別。為了
    發表于 12-18 14:34

    基于QT+OpenCv的目標跟蹤算法實現

    目標跟蹤算法作為一種有著非常廣泛的應用的算法,在航空航天、智能交通、智能設備等領域有著非常廣泛的應用。本系列博客將教大家在410c開發板上基于linux操作系統環境,采用QT+Opencv實現
    發表于 09-21 10:42

    ARM LinuxOpenCV的移植和使用方法

    的應用領域非常廣泛,包括圖像拼接、圖像降噪、產品質檢、人機交互、人臉識別、動作識別、動作跟蹤、無人駕駛等。本篇介紹ARM Linux
    發表于 11-03 07:01

    基于linux操作系統實現一個人臉識別門禁系統

    形成組網,實現一個人臉識別門禁系統。客戶端為嵌入式Linux設備,采用QT庫顯示界面,通過攝像頭采集圖像。服務器為PC上 Ubuntu系統,
    發表于 12-14 06:24

    基于QT+OpenCV人臉識別-米爾iMX8M Plus開發板的項目應用

    opencv人臉檢測分類器。OpenCV編譯完成后已經提供好了的。因為這里還需要涉及到訓練模型,有了模型后才能更好地識別,所以還是簡單介
    發表于 05-17 17:43

    基于openCV人臉檢測識別系統的設計

    通過對基于Adaboost人臉檢測算法的研究,利用該算法與計算機視覺類庫openCV進行人臉檢測系統的設計,
    發表于 06-15 10:53 ?477次下載
    基于<b class='flag-5'>openCV</b>的<b class='flag-5'>人臉</b><b class='flag-5'>檢測</b>識別系統的設計

    openCV人臉檢測系統的設計方案探究

    摘要: 通過對基于 Adaboost 人臉檢測算法的研究,利用該算法與計算機視覺類庫 openCV 進行人臉檢測系統的設計,
    發表于 10-20 16:39 ?3次下載

    關于人臉識別技術原理分析和應用

    臉識別系統可以在Linux 操作系統利用QT庫來開發圖形界面,以OpenCV 圖像處理庫為基礎
    的頭像 發表于 08-26 11:42 ?4683次閱讀

    畢業設計:電子/通信/物聯網/計算機專業選題目參考(嵌入式linux/單片機STM32/web/圖像

    :基于Opencv+Qt人臉識別門禁系統(電腦端/電腦+開發板)項目簡介:采用OpencvQt實現
    發表于 12-29 18:54 ?6次下載
    畢業設計:電子/通信/物聯網/計算機專業選題目參考(嵌入式<b class='flag-5'>linux</b>/單片機STM32/web/<b class='flag-5'>圖像</b>)

    QT+OpenCV人臉識別—米爾iMX8MPlus開發板項目

    本篇測評由電子工程世界的優秀測評者“流行科技”提供。 此次測試的開源項目,是基于QT+OpenCV人臉識別打卡項目。本次體驗使用的是開源的代碼,此代碼本來是運行在WIN的,為了測試稍微進行了修改
    的頭像 發表于 05-18 18:00 ?2441次閱讀
    <b class='flag-5'>QT+OpenCV</b><b class='flag-5'>人臉</b>識別—米爾iMX8MPlus開發板項目

    LinuxQT+OpenCV實現人臉實時檢測(攝像頭)

    標簽上。人臉檢測分類器采用OpenCV自帶的分類器,程序主要目的是介紹OpenCV配合QT如何進
    的頭像 發表于 08-14 09:29 ?2181次閱讀
    <b class='flag-5'>Linux</b><b class='flag-5'>下</b><b class='flag-5'>QT+OpenCV</b><b class='flag-5'>實現</b><b class='flag-5'>人臉</b>實時<b class='flag-5'>檢測</b>(攝像頭)

    Android系統OpenCV人臉檢測模塊的設計

    電子發燒友網站提供《Android系統OpenCV人臉檢測模塊的設計.pdf》資料免費下載
    發表于 10-23 09:37 ?0次下載
    Android系統<b class='flag-5'>下</b><b class='flag-5'>OpenCV</b>的<b class='flag-5'>人臉</b><b class='flag-5'>檢測</b>模塊的設計
    主站蜘蛛池模板: xxx粗大长欧美| 最近中文字幕MV免费高清在线| 亚洲三级黄色| 国产精品爆乳尤物99精品| 欧美狂野乱码一二三四区| 中文文字幕文字幕亚洲色| 国内精自品线一区91| 亚洲 日本 中文字幕 制服| 丰满老熟女白浆直流| 日本免费无码A专区在线观看| 99久久做夜夜爱天天做精品| 美国caopo超碰在线视频| 在线视频中文字幕| 麻豆人妻无码性色AV| 97蜜桃网123.com| 欧美成a人片免费看久久| xxx成熟xxx| 日韩高清特级特黄毛片| 国产h视频在线观看免费| 无码观看AAAAAAAA片| 国产午夜不卡| 野花日本大全免费观看3中文版| 九九九色成人网| 60岁老年熟妇在线无码| 青青草原影视| 国产精品久久久久久免费播放| 性欧美金发洋妞xxxxbbbb| 韩国伦理片2018在线播放免费观看 | 久久re视频这里精品一本到99| 亚洲综合色在线视频久| 麻豆一区二区三区蜜桃免费| 99久久精品免费看国产一区二区三区| 女的把腿张开男的往里面插| 吃春药后的女教师| 亚洲 综合 自拍 精品 在线| 久久999视频| qovd伦理| 亚洲国产女人aaa毛片在线| 久久一er精这里有精品| 被送到黑人性奴俱乐部| 亚洲AV福利天堂一区二区三|