Qt图像处理技术十一:得到QImage图像的马赛克图像

效果图

指数5

指数15

指数40

原理

马赛克的原理很简单,就是取一个值,让这个值作为一个方格子的长宽,如40*40px的格子,取这个区域的平均R G B值,然后这个区域的所有像素点都是这个RGB值即可

源码

cpp 复制代码
QImage applyMosaic(const QImage& oldImage, int blockSize) {
    if (oldImage.isNull() || blockSize <= 0) {
        return QImage(); // 返回空图片或处理错误
    }

    // 确保blockSize是偶数,并且不会使图像尺寸变得太小
    blockSize = (blockSize % 2 == 0) ? blockSize : blockSize + 1;
    if (oldImage.width() < blockSize || oldImage.height() < blockSize) {
        return oldImage; // 如果blockSize太大,直接返回原图
    }

    // 计算新图片的尺寸
    int newWidth = oldImage.width() / blockSize * blockSize;
    int newHeight = oldImage.height() / blockSize * blockSize;

    QImage newImage(newWidth, newHeight, oldImage.format());

    // 遍历每个块
    for (int y = 0; y < newHeight; y += blockSize) {
        for (int x = 0; x < newWidth; x += blockSize) {
            // 计算块的平均颜色
            QRgb averageColor = qRgb(0, 0, 0); // 初始化平均颜色为黑色
            int totalR = 0, totalG = 0, totalB = 0;
            int count = 0;

            for (int by = 0; by < blockSize && y + by < oldImage.height(); ++by) {
                for (int bx = 0; bx < blockSize && x + bx < oldImage.width(); ++bx) {
                    QRgb pixel = oldImage.pixel(x + bx, y + by);
                    totalR += qRed(pixel);
                    totalG += qGreen(pixel);
                    totalB += qBlue(pixel);
                    ++count;
                }
            }

            if (count > 0) { // 确保count不是0,避免除以0
                averageColor = qRgb(totalR / count, totalG / count, totalB / count);
            }

            // 用平均颜色填充整个块
            for (int by = 0; by < blockSize && y + by < newImage.height(); ++by) {
                for (int bx = 0; bx < blockSize && x + bx < newImage.width(); ++bx) {
                    newImage.setPixel(x + bx, y + by, averageColor);
                }
            }
        }
    }

    return newImage;
}
相关推荐
Tony小周2 小时前
使用QKeyEvent keyPress(QEvent::KeyPress, key模拟键盘发送事件,会导致主程序卡死
嵌入式硬件·qt
Larry_Yanan3 小时前
QML学习笔记(五十)QML与C++交互:QML中单例C++对象
开发语言·c++·笔记·qt·学习·ui·交互
std78795 小时前
MATLAB 实用案例三:图像边缘检测、数据拟合与可视化、信号处理
图像处理·opencv·计算机视觉
zhmhbest6 小时前
Qt 全球峰会 2025:中国站速递 —— 技术中立,拥抱更大生态
开发语言·qt·系统架构
躺平的赶海人7 小时前
Halcon实战:精准定位与提取:基于形态学处理的猴子眼睛区域检测完整方案
图像处理·计算机视觉·halcon·形态学操作
feiyangqingyun9 小时前
Qt实时绘制飞行轨迹/移动轨迹实时显示/带旋转角度/平滑移动/效果一级棒/地面站软件开发/无人机管理平台
qt·无人机·集群地面站
萧鼎9 小时前
深入掌握 OpenCV-Python:从图像处理到智能视觉
图像处理·python·opencv
十五年专注C++开发12 小时前
Qt-VLC: 一个集成VLC的开源跨平台媒体播放库
开发语言·qt·媒体·libvlc·vlc-qt
搞科研的小刘选手12 小时前
【多所高校合作】第四届图像处理、计算机视觉与机器学习国际学术会议(ICICML 2025)
图像处理·人工智能·机器学习·计算机视觉·数据挖掘·人脸识别·人机交互
Aevget15 小时前
QtitanNavigation助力能源数字化转型:打造清晰可控的系统导航体验
c++·qt·嵌入式·能源·界面控件·ui开发