使用 OpenCV 对图像应用膨胀操作

膨胀是一种形态学图像处理操作,可增加前景对象的边界。在大多数情况下,前景像素是白色的。为了对图像应用膨胀操作,定义了内核(结构元素)。内核从左到右和从上到下遍历图像。如果内核中至少有一个像素为 1,则输入图像中的前景像素将被保留。否则,像素将设置为 0。通常,膨胀操作用于连接图像中对象的破碎部分。

OpenCV 提供了dilate对图像进行膨胀操作的功能。

  • python示例代码
import cv2
import numpy as np

inputImg = cv2.imread('test.jpg')
inputImg = cv2.cvtColor(inputImg, cv2.COLOR_BGR2GRAY)
_, inputImg = cv2.threshold(inputImg, 0, 255, cv2.THRESH_OTSU)

kernel = np.ones((4, 4))
outputImg = cv2.dilate(inputImg, kernel)

cv2.imshow('Input image', inputImg)
cv2.imshow('Output image', outputImg)
cv2.waitKey(0)
cv2.destroyAllWindows()
  • C++示例代码
#include <opencv2/opencv.hpp>

using namespace cv;

int main()
{
    Mat inputImg = imread("test.jpg");
    cvtColor(inputImg, inputImg, COLOR_BGR2GRAY);
    threshold(inputImg, inputImg, 0, 255, THRESH_OTSU);

    Mat kernel = getStructuringElement(MORPH_RECT, Size(4, 4));
    Mat outputImg;
    dilate(inputImg, outputImg, kernel);

    imshow("Input image", inputImg);
    imshow("Output image", outputImg);
    waitKey(0);
    destroyAllWindows();

    return 0;
}
  • Java示例代码
package app;

import org.opencv.core.*;
import org.opencv.highgui.HighGui;
import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;

public class Main
{
    static { System.loadLibrary(Core.NATIVE_LIBRARY_NAME); }

    public static void main(String[] args)
    {
        Mat inputImg = Imgcodecs.imread("test.jpg");
        Imgproc.cvtColor(inputImg, inputImg, Imgproc.COLOR_BGR2GRAY);
        Imgproc.threshold(inputImg, inputImg, 0, 255, Imgproc.THRESH_OTSU);

        Mat kernel = Imgproc.getStructuringElement(Imgproc.MORPH_RECT, new Size(4, 4));
        Mat outputImg = new Mat();
        Imgproc.dilate(inputImg, outputImg, kernel);

        HighGui.imshow("Input image", inputImg);
        HighGui.imshow("Output image", outputImg);
        HighGui.waitKey(0);
        HighGui.destroyAllWindows();

        System.exit(0);
    }
}

效果图:

使用 OpenCV 对图像应用膨胀操作

本文来自作者投稿,版权归原作者所有。如需转载,请注明出处:https://www.nxrte.com/jishu/17434.html

(0)

相关推荐

  • 基于opencv实战眼睛控制鼠标

    如何用眼睛来控制鼠标?一种基于单一前向视角的机器学习眼睛姿态估计方法。在此项目中,每次单击鼠标时,我们都会编写代码来裁剪你们的眼睛图像。使用这些数据,我们可以反向训练模型,从你们您…

    2022年9月8日
  • 使用 OpenCV 获取图像大小

    在图像处理过程中,往往需要知道图像的尺寸,如宽、高、通道数等。本教程提供了如何使用 OpenCV 获取图像大小的示例。 加载图像时,根据图像类型(例如灰度图像或彩色图像)将其存储在…

    2022年11月21日
  • OpenCV:图像直方图计算

    图像直方图为图像中像素强度的分布提供了有价值的见解。通过了解直方图,你可以获得有关图像对比度、亮度和整体色调分布的信息。这些知识对于图像增强、图像分割和特征提取等任务非常有用。 本…

    2023年7月22日
  • 使用 OpenCV 对图像进行中值滤波

    有多种算法可以减少图像中的噪声。其中之一是中值滤波器。该过滤器计算内核区域中所有像素的中值。然后将中心像素的值替换为计算出的中值。中值滤波器广泛用于去除“椒盐”型噪声。 OpenC…

    2022年11月18日
  • 使用 OpenCV 对图像进行开运算

    开运算是一种形态学图像处理操作,先对图像进行腐蚀操作,再进行膨胀操作。开运算允许移除小对象,同时保留较大对象的大小。 morphologyEx带参数的函数可MORPH_OPEN用于…

    2023年3月17日
  • 使用 OpenCV 从指定文件加载图像

    在处理图像时,第一步是从文件中加载图像。 OpenCV 提供了imread从文件加载图像的功能。此功能支持多种图像格式,如 PNG、JPEG、BMP、WebP 等。图像格式由图像的…

    2022年11月20日

发表回复

登录后才能评论