標題: 去年做的基于Qt的人臉識別系統(tǒng),這是在Qt客戶端上運行的完整代碼 [打印本頁]

作者: 54166    時間: 2020-3-29 21:15
標題: 去年做的基于Qt的人臉識別系統(tǒng),這是在Qt客戶端上運行的完整代碼
  1. #include "facedetectwnd.h"
  2. #include "ui_facedetectwnd.h"

  3. #include <QByteArray>
  4. #include <QHostAddress>

  5. #include "FaceDetect.h"

  6. FaceDetectThr::FaceDetectThr(QObject *parent):
  7.     QThread (parent)
  8. {
  9. }

  10. FaceDetectThr::~FaceDetectThr()
  11. {
  12. }

  13. void FaceDetectThr::run()
  14. {
  15. #define MAXLEN int(800*600)
  16.    int size;

  17.    //分配緩存:用于保存接收圖片數(shù)據(jù)
  18.    char *buffer  = new char[MAXLEN];

  19.         //分配套接字
  20.    QTcpSocket *s = new QTcpSocket;
  21.    // 連接服務器
  22.    s->connectToHost(QHostAddress("192.168.21.131"), 59999);
  23.    //等連接成功
  24.    if(!s->waitForConnected(~0)){
  25.        goto ERR_STEP;
  26.    }
  27.    //給界面發(fā)生連接成功信號
  28.    emit sigConnected();

  29.         //死循環(huán)
  30.    while(1){
  31.        char req[]= "clientack";

  32.                 //給服務器發(fā)送請求
  33.        s->write(req, sizeof(req));

  34.                 //等待套接字緩存可讀(給服務器發(fā)送請求后,服務器收到則采樣一張圖片,回發(fā)客戶端)
  35.        if(s->waitForReadyRead(~0)){
  36.                    //讀出4字節(jié)協(xié)議頭:圖片正文的長度
  37.            s->read((char *)&size, 4);
  38.            int len = size;
  39.            char *p1 = (char *)&len;
  40.            char *p2 = (char *)&size;
  41.            p1[0] = p2[3];
  42.            p1[1] = p2[2];
  43.            p1[2] = p2[1];
  44.            p1[3] = p2[0];

  45.            if(MAXLEN < len){
  46.                goto ERR_STEP;
  47.            }

  48.                         //循環(huán)接收len字節(jié)數(shù)據(jù)(不多收也不少收)
  49.            p1 = buffer;
  50.            int pos = len;
  51.            while(pos){
  52.                if(!s->waitForReadyRead(~0)){
  53.                    goto ERR_STEP;
  54.                }
  55.                size = int(s->read(p1, pos));
  56.                pos -= size;
  57.                p1 += size;
  58.            }
  59.            qDebug("len = %d, pos=%d\n", len, pos);

  60.                         //把接收來的圖片數(shù)據(jù)裝到字節(jié)數(shù)組
  61.            QByteArray arr;
  62.            arr.append(buffer, len);
  63.                    //定義管理圖片的QImage對象
  64.            QImage img;
  65.                    //把字節(jié)數(shù)組中圖片用img對象管理起來
  66.            img.loadFromData(arr);

  67.            //把QImage轉(zhuǎn)換成Mat格式
  68.            cv::Mat frame = ::QImage_to_Mat(img);
  69.            //人臉檢測
  70.            ::detectFaceOpenCV(frame);
  71.            //把Mat轉(zhuǎn)換成QImage
  72.            img = ::Mat_to_QImage(frame);

  73.            //把QImage轉(zhuǎn)換QPixmap
  74.            QPixmap pix = QPixmap::fromImage(img);

  75.                         //給界面發(fā)送信號
  76.            emit sigPixmap(pix);
  77.        }
  78.    }

  79. ERR_STEP:
  80.    qDebug("線程出錯退出");
  81.    delete [] buffer;
  82.    delete s;
  83.    emit sigDisconnected();
  84.    return;
  85. }

  86. FaceDetectWnd::FaceDetectWnd(QWidget *parent) :
  87.     QWidget(parent),
  88.     ui(new Ui::FaceDetectWnd)
  89. {
  90.     ui->setupUi(this);

  91.     //分配一個接收線程對象
  92.     detectThr = new FaceDetectThr;
  93.     connect(detectThr, SIGNAL(sigPixmap(QPixmap)),
  94.             this, SLOT(slotRecv(QPixmap)));
  95.     connect(detectThr, SIGNAL(sigConnected()),
  96.             this, SLOT(slotConnected()));
  97.     connect(detectThr, SIGNAL(sigDisconnected()),
  98.             this, SLOT(slotDisconnected()));

  99.     setWindowTitle("智能門崗");
  100. }

  101. FaceDetectWnd::~FaceDetectWnd()
  102. {
  103.     delete ui;
  104. }

  105. void FaceDetectWnd::slotConnected()
  106. {
  107.     setWindowTitle("連接成功");
  108.     ui->pushButton->setEnabled(true);
  109. }

  110. void FaceDetectWnd::slotDisconnected()
  111. {
  112.     setWindowTitle("連接斷開");
  113.     ui->pushButton->setText("連接");
  114.     ui->pushButton->setEnabled(true);
  115. }

  116. void FaceDetectWnd::slotRecv(QPixmap pix)
  117. {
  118.     ui->label->setPixmap(pix);
  119. }

  120. void FaceDetectWnd::on_pushButton_clicked()
  121. {
  122.     if("連接" == ui->pushButton->text()){
  123.         ui->pushButton->setText("斷開");
  124.         detectThr->start();
  125.         setWindowTitle("連接中...");
  126.         ui->pushButton->setEnabled(false);
  127.     }else{
  128.         ui->pushButton->setText("連接");
  129.         detectThr->terminate();
  130.     }
  131. }

復制代碼







歡迎光臨 (http://www.torrancerestoration.com/bbs/) Powered by Discuz! X3.1