在Qt中,图片处理是一个重要的领域,它包括加载、保存、缩放、旋转、裁剪、滤镜等操作。

1. 图像格式支持

Qt支持多种图像格式,包括PNG、JPEG、BMP、GIF等。Qt中的QImage类提供了对这些图像格式的支持,你可以使用QImage加载和保存不同格式的图像。
以下是Qt默认支持的图像格式列表:

  1. BMP(.bmp): Windows位图格式。
  2. GIF(.gif): 图形交换格式,支持动画。
  3. JPG/JPEG(.jpg, .jpeg): 联合照片专家小组(Joint Photographic Experts Group)格式。
  4. PNG(.png): 可移植网络图形格式,支持无损压缩。
  5. PBM(.pbm): Portable Bitmap格式,一种简单的二进制图像格式。
  6. PGM(.pgm): Portable Graymap格式,一种灰度图像格式。
  7. PPM(.ppm): Portable Pixmap格式,一种彩色图像格式。
  8. XBM(.xbm): X BitMap格式,一种用于X窗口系统的位图格式。
  9. XPM(.xpm): X PixMap格式,一种用于X窗口系统的彩色图像格式。

除了以上格式,Qt还支持以下一些特殊格式:

  • Mac PICT(.pct): Macintosh PICT图像格式。
  • TGA(.tga): Truevision Targa图像格式。
  • TIFF(.tiff): 标记图像文件格式。
  • WBMP(.wbmp): 无线位图格式,用于移动设备。

请注意,具体的支持格式取决于Qt的编译配置。在编译Qt时,你可以选择启用或禁用特定的图像格式支持。如果你需要支持某个特定的图像格式,确保在编译Qt时启用了相应的支持选项。

2. 加载和保存图像

2.1 QImaeg加载图像

使用 QImage 的构造函数或 load() 函数可以从文件、内存或设备加载图像。你可以传递图像文件的路径给构造函数,或者使用 load() 函数加载图像文件。

QImage image("path/to/image.png"); // 从文件加载
// 或者
QImage image;
image.load("path/to/image.png"); // 从文件加载

2.2 QImaeg保存图像

使用 save() 函数可以将 QImage 保存为文件。你可以指定文件名以及图像格式(如 PNG、JPEG 等)。

image.save("output/path/image.png"); // 保存为PNG格式
// 或者
image.save("output/path/image.jpg", "JPEG"); // 保存为JPEG格式

2.3QImage 加载和保存图像的实例

以下是一个简单的实例,演示了如何使用 QImage 加载图像并将其保存为不同的格式。

#include <QImage>
#include <QDebug>

int main() {
    // 加载图像
    QImage image("path/to/input.png");
    
    // 检查图像是否成功加载
    if (image.isNull()) {
        qDebug() << "Failed to load image.";
        return 1;
    }

    // 保存图像为不同格式
    if (image.save("path/to/output.png")) {
        qDebug() << "Image saved as PNG.";
    } else {
        qDebug() << "Failed to save image as PNG.";
    }

    if (image.save("path/to/output.jpg", "JPEG")) {
        qDebug() << "Image saved as JPEG.";
    } else {
        qDebug() << "Failed to save image as JPEG.";
    }

    if (image.save("path/to/output.bmp", "BMP")) {
        qDebug() << "Image saved as BMP.";
    } else {
        qDebug() << "Failed to save image as BMP.";
    }

    return 0;
}

在这个例子中,首先加载了一个图像文件(假设路径为 “path/to/input.png”),然后将其保存为不同格式的文件。save() 函数的第二个参数可以指定保存的图像格式,如 “PNG”、“JPEG”、“BMP” 等。根据你的需要,可以选择适当的格式。在实际应用中,请替换实际的文件路径和格式。

3 QImage图像大小和缩放

3.1 获取图像大小

使用 size() 函数可以获取图像的大小,返回一个 QSize 对象,其中包含图像的宽度和高度。

QSize imageSize = image.size();
int width = imageSize.width();
int height = imageSize.height();

3.2 缩放图像

使用 scaled() 函数可以对图像进行缩放。该函数接受目标宽度和高度作为参数,返回一个新的 QImage 对象,表示缩放后的图像。你也可以选择使用不同的缩放模式,如保持宽高比例或拉伸到指定大小。

// 缩放为指定的宽度和高度
QImage scaledImage = image.scaled(100, 100);

// 缩放并保持宽高比例
QImage aspectRatioImage = image.scaled(100, 100, Qt::KeepAspectRatio);

// 拉伸到指定的宽度和高度
QImage stretchedImage = image.scaled(100, 100, Qt::IgnoreAspectRatio);

3.3 QImage 图像大小和缩放的实例

以下是一个简单的实例,演示了如何获取图像的大小并对图像进行缩放。

#include <QImage>
#include <QDebug>

int main() {
    // 加载图像
    QImage image("path/to/image.png");
    
    // 检查图像是否成功加载
    if (image.isNull()) {
        qDebug() << "Failed to load image.";
        return 1;
    }

    // 获取图像大小
    QSize imageSize = image.size();
    int width = imageSize.width();
    int height = imageSize.height();
    qDebug() << "Original Image Size: " << width << "x" << height;

    // 缩放图像为指定的宽度和高度
    QImage scaledImage = image.scaled(50, 50);
    int scaledWidth = scaledImage.width();
    int scaledHeight = scaledImage.height();
    qDebug() << "Scaled Image Size: " << scaledWidth << "x" << scaledHeight;

    return 0;
}

在这个例子中,首先加载了一个图像文件(假设路径为 “path/to/image.png”),然后获取了原始图像的大小,并将其缩放为50x50的尺寸。请替换实际的文件路径和缩放目标尺寸。

4 QtImage图像旋转和裁剪

4.1 旋转图像

使用 transformed() 函数可以对图像进行旋转。该函数接受一个 QMatrix 对象作为参数,该对象描述了旋转的角度和其他变换信息。

QMatrix matrix;
matrix.rotate(90);  // 旋转90度
QImage rotatedImage = image.transformed(matrix);

4.2 裁剪图像

使用 copy() 函数可以对图像进行裁剪。该函数接受起始点的坐标和裁剪区域的宽度和高度作为参数。

QImage croppedImage = image.copy(x, y, width, height);

4.3 QImage 旋转和裁剪的实例

以下是一个简单的实例,演示了如何对图像进行旋转和裁剪。

#include <QImage>
#include <QMatrix>
#include <QDebug>

int main() {
    // 加载图像
    QImage image("path/to/image.png");
    
    // 检查图像是否成功加载
    if (image.isNull()) {
        qDebug() << "Failed to load image.";
        return 1;
    }

    // 旋转图像
    QMatrix matrix;
    matrix.rotate(90);  // 旋转90度
    QImage rotatedImage = image.transformed(matrix);
    rotatedImage.save("path/to/rotated_image.png");  // 保存旋转后的图像

    // 裁剪图像
    int x = 50;
    int y = 50;
    int width = 100;
    int height = 100;
    QImage croppedImage = image.copy(x, y, width, height);
    croppedImage.save("path/to/cropped_image.png");  // 保存裁剪后的图像

    return 0;
}

在这个例子中,首先加载了一个图像文件(假设路径为 “path/to/image.png”),然后对图像进行了90度的旋转和裁剪操作,并将结果保存为新的图像文件。请替换实际的文件路径和裁剪区域的坐标、宽度、高度。

5. Qt图像滤镜

Qt提供了QImageFilter类,用于应用各种滤镜效果。滤镜可以用于图像处理,例如模糊、亮度、对比度等。以下是一些常见的滤镜效果:

5.1 模糊滤镜

  • 使用模糊滤镜可以使图像变得模糊,模糊度由滤镜的半径决定。
  QImage blurredImage = image.filter(QImage::Filter_GaussianBlur, 5);  // 半径为5的高斯模糊

5.2 亮度调整

  • 通过亮度滤镜可以调整图像的亮度,值范围通常在-100到100之间。
 QImage brightenedImage = image.filter(QImage::Filter_Brightness, 50);  // 增加50个亮度单位

5.3 对比度调整

  • 通过对比度滤镜可以调整图像的对比度,值范围通常在-100到100之间。
QImage contrastedImage = image.filter(QImage::Filter_Contrast, 20);  // 增加20个对比度单位

5.4 Qt 图像滤镜的实例

以下是一个简单的实例,演示了如何使用QImageFilter应用模糊滤镜、亮度滤镜和对比度滤镜:

#include <QImage>
#include <QDebug>

int main() {
    // 加载图像
    QImage image("path/to/image.png");
    
    // 检查图像是否成功加载
    if (image.isNull()) {
        qDebug() << "Failed to load image.";
        return 1;
    }

    // 应用模糊滤镜
    QImage blurredImage = image.filter(QImage::Filter_GaussianBlur, 5);

    // 应用亮度滤镜
    QImage brightenedImage = image.filter(QImage::Filter_Brightness, 50);  // 增加50个亮度单位

    // 应用对比度滤镜
    QImage contrastedImage = image.filter(QImage::Filter_Contrast, 20);  // 增加20个对比度单位

    // 保存处理后的图像
    blurredImage.save("path/to/blurred_image.png");
    brightenedImage.save("path/to/brightened_image.png");
    contrastedImage.save("path/to/contrasted_image.png");

    return 0;
}

在这个例子中,首先加载了一个图像文件(假设路径为 “path/to/image.png”),然后分别应用了模糊滤镜、亮度滤镜和对比度滤镜,并将处理后的图像保存为新的文件。请替换实际的文件路径和滤镜参数值。

10-23 08:12