欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

OpenCV+Qt實現圖像處理操作工具的示例代碼

 更新時間:2022年08月03日 15:15:34   作者:我今年十六歲  
這篇文章主要介紹了利用OpenCV+Qt實現圖像處理操作工具,可以實現雪花屏、高斯模糊、中值濾波、毛玻璃等操作,感興趣的可以了解一下

一、目標

Qt界面實現 雪花屏 高斯模糊 中值濾波 毛玻璃 灰度化 XY方向模糊 雙邊模糊 腐蝕 [圖像處理操作]

要求左邊原圖,右邊效果圖

結果展示如下:[圖像處理實現有點多,就不一個一個地展示了,各別展示如下]

雪花屏

毛玻璃

灰度化處理

二、使用Qt界面

使用到Qt中的UI設計界面

設計好界面之后最好先保存

對每一個按鈕設計槽函數

三、圖像處理操作完整代碼

難點在于:Qt是QImage而OpenCV是Mat,需要Mat轉QImage才能在Qt界面中進行圖片的正常顯示

頭文件中導入opencv包 

#ifndef WIDGET_H
#define WIDGET_H
#include<opencv2/opencv.hpp>
#include <QWidget>
using namespace cv;
 
QT_BEGIN_NAMESPACE
namespace Ui {class Widget;}
QT_END_NAMESPACE
 
class Widget : public QWidget
{
    Q_OBJECT
public:
//  Widget(QWidget *parent = nullptr);
    explicit Widget(QWidget *parent = 0);
    ~Widget();
 
private slots:
    void on_pushButton_clicked();//雪花屏
    void on_pushButton_2_clicked();//高斯模糊
    void on_pushButton_3_clicked();//中值濾波
    void on_pushButton_4_clicked();//毛玻璃
    void on_pushButton_5_clicked();//灰度化
    void on_pushButton_6_clicked();//XY方向模糊
    void on_pushButton_7_clicked();//雙邊模糊
    void on_pushButton_8_clicked();//腐蝕
private:
    Ui::Widget *ui;
    Mat srcimage;//原圖
};
 
#endif // WIDGET_H

源文件中實現圖像處理方法 

#include "widget.h"
#include "ui_widget.h"
 
Widget::Widget(QWidget *parent) :
    QWidget(parent),
    ui(new Ui::Widget)
{
    ui->setupUi(this);
}
 
Widget::~Widget()
{
    delete ui;
}
 
//雪花屏
void Widget::on_pushButton_clicked()
{
    //讀取原始圖片
    Mat srcimage = imread("D:/000imageopencv/efls111.jpg");
    //Mat轉QImage 顏色
    cvtColor(srcimage,srcimage,CV_BGR2RGB);
    //Mat轉QImage 像素   oldlabel放置原圖
    QImage disimage = QImage(srcimage.data,srcimage.cols,srcimage.rows,srcimage.cols*srcimage.channels(),QImage::Format_RGB888);
    disimage = disimage.scaled(ui->oldlabel->width(),ui->oldlabel->height());
    ui->oldlabel->setPixmap(QPixmap::fromImage(disimage));
 
    //像素二維矩陣函數
    int rows = srcimage.rows;
    //像素二維矩陣列數
    int cols = srcimage.cols * srcimage.channels();
    for(int i=0;i<rows;i++)
    {
        uchar * data = srcimage.ptr<uchar>(i);
        for(int j=0;j<cols;j++)
        {
            //雪花屏特效
            int q = rand()%cols;
            data[q]=155;//某些通道隨機改成155
        }
    }
    //Mat轉QImage 像素   newlabel放置圖像處理后圖片
    QImage disimage2 = QImage(srcimage.data,srcimage.cols,srcimage.rows,srcimage.cols*srcimage.channels(),QImage::Format_RGB888);
    disimage2 = disimage2.scaled(ui->newlabel->width(),ui->newlabel->height());
    ui->newlabel->setPixmap(QPixmap::fromImage(disimage2));
}
 
//高斯模糊
void Widget::on_pushButton_2_clicked()
{
    //讀取原始圖片
    Mat srcimage = imread("D:/000imageopencv/efls111.jpg");
    //Mat轉QImage 顏色
    cvtColor(srcimage,srcimage,CV_BGR2RGB);
    //Mat轉QImage 像素   oldlabel放置原圖
    QImage disimage = QImage(srcimage.data,srcimage.cols,srcimage.rows,srcimage.cols*srcimage.channels(),QImage::Format_RGB888);
 
    Mat retimage;
    //高斯模糊
    GaussianBlur(srcimage,retimage,Size(5,5),0,0);
 
    //Mat轉QImage 像素   newlabel放置圖像處理后圖片
    QImage disimage2 = QImage(retimage.data,retimage.cols,retimage.rows,retimage.cols*retimage.channels(),QImage::Format_RGB888);
    disimage2 = disimage2.scaled(ui->newlabel->width(),ui->newlabel->height());
    ui->newlabel->setPixmap(QPixmap::fromImage(disimage2));
}
 
//中值濾波
void Widget::on_pushButton_3_clicked()
{
    //讀取原始圖片
    Mat srcimage = imread("D:/000imageopencv/efls111.jpg");
    //Mat轉QImage 顏色
    cvtColor(srcimage,srcimage,CV_BGR2RGB);
    //Mat轉QImage 像素   oldlabel放置原圖
    QImage disimage = QImage(srcimage.data,srcimage.cols,srcimage.rows,srcimage.cols*srcimage.channels(),QImage::Format_RGB888);
    disimage = disimage.scaled(ui->oldlabel->width(),ui->oldlabel->height());
    ui->oldlabel->setPixmap(QPixmap::fromImage(disimage));
 
    Mat retumage;
    //中值濾波
    medianBlur(srcimage,retumage,5);
 
    //Mat轉QImage 像素   newlabel放置圖像處理后圖片
    QImage disimage2 = QImage(retumage.data,retumage.cols,retumage.rows,retumage.cols*retumage.channels(),QImage::Format_RGB888);
    disimage2 = disimage2.scaled(ui->newlabel->width(),ui->newlabel->height());
    ui->newlabel->setPixmap(QPixmap::fromImage(disimage2));
}
 
//毛玻璃
void Widget::on_pushButton_4_clicked()
{
    //讀取原始圖片
    Mat srcimage = imread("D:/000imageopencv/efls111.jpg");
    //Mat轉QImage 顏色
    cvtColor(srcimage,srcimage,CV_BGR2RGB);
    //Mat轉QImage 像素   oldlabel放置原圖
    QImage disimage = QImage(srcimage.data,srcimage.cols,srcimage.rows,srcimage.cols*srcimage.channels(),QImage::Format_RGB888);
    disimage = disimage.scaled(ui->oldlabel->width(),ui->oldlabel->height());
    ui->oldlabel->setPixmap(QPixmap::fromImage(disimage));
 
    //毛玻璃
    RNG rng;
    int random;
    int num = 5;
    for(int i=0;i<srcimage.rows -num;i++)
    {
        for(int j=0;j<srcimage.cols -num;j++)
        {
            //通過rng返回0-15隨機數
            random = rng.uniform(0,num);
            srcimage.at<Vec3b>(i,j)[0] = srcimage.at<Vec3b>(i+random,j+random)[0];
            srcimage.at<Vec3b>(i,j)[1] = srcimage.at<Vec3b>(i+random,j+random)[1];
            srcimage.at<Vec3b>(i,j)[2] = srcimage.at<Vec3b>(i+random,j+random)[2];
        }
    }
 
    //Mat轉QImage 像素   newlabel放置圖像處理后圖片
    QImage disimage2 = QImage(srcimage.data,srcimage.cols,srcimage.rows,srcimage.cols*srcimage.channels(),QImage::Format_RGB888);
    disimage2 = disimage2.scaled(ui->newlabel->width(),ui->newlabel->height());
    ui->newlabel->setPixmap(QPixmap::fromImage(disimage2));
}
 
//灰度化
void Widget::on_pushButton_5_clicked()
{
    //讀取原始圖片
    Mat srcimage = imread("D:/000imageopencv/efls111.jpg");
    //Mat轉QImage 顏色
    cvtColor(srcimage,srcimage,CV_BGR2RGB);
    //Mat轉QImage 像素   oldlabel放置原圖
    QImage disimage = QImage(srcimage.data,srcimage.cols,srcimage.rows,srcimage.cols*srcimage.channels(),QImage::Format_RGB888);
    disimage = disimage.scaled(ui->oldlabel->width(),ui->oldlabel->height());
    ui->oldlabel->setPixmap(QPixmap::fromImage(disimage));
 
    Mat retumage;
    //灰度處理 灰度是單通道8位 QImage是24位三通道
    cvtColor(srcimage,retumage,CV_BGR2GRAY);
    cvtColor(retumage,retumage,CV_GRAY2BGR);
 
    //Mat轉QImage 像素   newlabel放置圖像處理后圖片
    QImage disimage2 = QImage(retumage.data,retumage.cols,retumage.rows,retumage.cols*retumage.channels(),QImage::Format_RGB888);
    disimage2 = disimage2.scaled(ui->newlabel->width(),ui->newlabel->height());
    ui->newlabel->setPixmap(QPixmap::fromImage(disimage2));
}
 
//XY方向模糊
void Widget::on_pushButton_6_clicked()
{
    //讀取原始圖片
    Mat srcimage = imread("D:/000imageopencv/efls111.jpg");
    //Mat轉QImage 顏色
    cvtColor(srcimage,srcimage,CV_BGR2RGB);
    //Mat轉QImage 像素   oldlabel放置原圖
    QImage disimage = QImage(srcimage.data,srcimage.cols,srcimage.rows,srcimage.cols*srcimage.channels(),QImage::Format_RGB888);
    disimage = disimage.scaled(ui->oldlabel->width(),ui->oldlabel->height());
    ui->oldlabel->setPixmap(QPixmap::fromImage(disimage));
 
    Mat retumage;
    //xy軸模糊
    blur(srcimage,retumage,Size(10,10));
 
    //Mat轉QImage 像素   newlabel放置圖像處理后圖片
    QImage disimage2 = QImage(retumage.data,retumage.cols,retumage.rows,retumage.cols*retumage.channels(),QImage::Format_RGB888);
    disimage2 = disimage2.scaled(ui->newlabel->width(),ui->newlabel->height());
    ui->newlabel->setPixmap(QPixmap::fromImage(disimage2));
}
 
//雙邊模糊
void Widget::on_pushButton_7_clicked()
{
    //讀取原始圖片
    Mat srcimage = imread("D:/000imageopencv/efls111.jpg");
    //Mat轉QImage 顏色
    cvtColor(srcimage,srcimage,CV_BGR2RGB);
    //Mat轉QImage 像素   oldlabel放置原圖
    QImage disimage = QImage(srcimage.data,srcimage.cols,srcimage.rows,srcimage.cols*srcimage.channels(),QImage::Format_RGB888);
    disimage = disimage.scaled(ui->oldlabel->width(),ui->oldlabel->height());
    ui->oldlabel->setPixmap(QPixmap::fromImage(disimage));
 
    Mat retumage;
    //雙倍模糊
    cv::bilateralFilter(srcimage,retumage,15,120,10,4);
 
    //Mat轉QImage 像素   newlabel放置圖像處理后圖片
    QImage disimage2 = QImage(retumage.data,retumage.cols,retumage.rows,retumage.cols*retumage.channels(),QImage::Format_RGB888);
    disimage2 = disimage2.scaled(ui->newlabel->width(),ui->newlabel->height());
    ui->newlabel->setPixmap(QPixmap::fromImage(disimage2));
}
 
//腐蝕
void Widget::on_pushButton_8_clicked()
{
    //讀取原始圖片
    Mat srcimage = imread("D:/000imageopencv/efls111.jpg");
    //Mat轉QImage 顏色
    cvtColor(srcimage,srcimage,CV_BGR2RGB);
    //Mat轉QImage 像素   oldlabel放置原圖
    QImage disimage = QImage(srcimage.data,srcimage.cols,srcimage.rows,srcimage.cols*srcimage.channels(),QImage::Format_RGB888);
    disimage = disimage.scaled(ui->oldlabel->width(),ui->oldlabel->height());
    ui->oldlabel->setPixmap(QPixmap::fromImage(disimage));
 
    Mat retumage;
    //腐蝕
    Mat element = cv::getStructuringElement(MORPH_RECT,Size(5,5));
    cv::erode(srcimage,retumage,element);
 
    //Mat轉QImage 像素   newlabel放置圖像處理后圖片
    QImage disimage2 = QImage(retumage.data,retumage.cols,retumage.rows,retumage.cols*retumage.channels(),QImage::Format_RGB888);
    disimage2 = disimage2.scaled(ui->newlabel->width(),ui->newlabel->height());
    ui->newlabel->setPixmap(QPixmap::fromImage(disimage2));
}

主入口Qt窗口顯示 

#include "widget.h"
#include <QApplication>
 
int main(int argc, char *argv[])
{
    QApplication a(argc, argv);
    Widget w;
    w.show();
    return a.exec();
}

以上就是OpenCV+Qt實現圖像處理操作工具的示例代碼的詳細內容,更多關于OpenCV Qt圖像處理的資料請關注腳本之家其它相關文章!

相關文章

  • C語言實現簡單員工工資管理系統

    C語言實現簡單員工工資管理系統

    這篇文章主要為大家詳細介紹了C語言實現簡單員工工資管理系統,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • 深入理解C++函數棧幀

    深入理解C++函數棧幀

    本文主要介紹了C++函數棧幀,詳細的介紹了C++函數棧幀的概念以及使用,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-07-07
  • C++結構體字節(jié)對齊示例

    C++結構體字節(jié)對齊示例

    這篇文章主要為大家介紹了C++結構體字節(jié)對齊示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-06-06
  • C++多線程之帶返回值的線程處理函數解讀

    C++多線程之帶返回值的線程處理函數解讀

    這篇文章主要介紹了C++多線程之帶返回值的線程處理函數解讀,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • C語言實現將彩色bmp圖像轉化為灰圖、灰度圖像反色

    C語言實現將彩色bmp圖像轉化為灰圖、灰度圖像反色

    這篇文章主要為大家詳細介紹了C語言實現將彩色bmp圖像轉化為灰圖、灰度圖像反色,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-10-10
  • C語言實現會員計費系統

    C語言實現會員計費系統

    這篇文章主要為大家詳細介紹了C語言實現會員計費系統,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • C++標準模板庫函數sort的那些事兒

    C++標準模板庫函數sort的那些事兒

    sort函數是標準模板庫的函數,已知開始和結束的地址即可進行排序,可以用于比較任何容器(必須滿足隨機迭代器),任何元素,任何條件,執(zhí)行速度一般比qsort要快
    2013-09-09
  • C語言實現字符串替換的示例代碼

    C語言實現字符串替換的示例代碼

    本文主要介紹了C語言實現字符串替換的示例代碼,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-01-01
  • 項目之C++如何實現數據庫連接池

    項目之C++如何實現數據庫連接池

    這篇文章主要介紹了項目之C++如何實現數據庫連接池問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • 利用C語言替換文件中某一行的方法

    利用C語言替換文件中某一行的方法

    大家都知道C語言提供了文件操作,但是替換文件的某一行比較麻煩,下面是我使用的一個方法,現在分享給大家,有需要的朋友們可以參考借鑒。
    2016-09-09

最新評論