在OpenCV中使用图像像素

2022年8月13日12:13:57在OpenCV中使用图像像素已关闭评论


    在OpenCV中使用图像像素
    像素是计算机视觉中图像的重要属性。它们是表示图像中特定空间中光的颜色强度的数值,是图像中数据的最小单位。
    图像中的像素总数是高度、宽度和通道的乘积。
    由于OpenCV中的图像被读取为像素值的Numpy数组,因此可以使用数组切片操作获取并处理由该区域的像素表示的图像区域。
    切片操作用于检索序列子集,如列表、元组和数组,因此可用于获取图像区域的像素值,以便进行编辑、格式化或裁剪等处理。
    切片操作
    在OpenCV中使用图像像素
    在OpenCV中使用图像像素
    请注意,我使用索引值对字母列表进行切片。例如,传递起始索引1(列表中第二个字母的索引)和4将返回列表的一个片段,从第二个值到第四个值。
    由于索引值用于以这种方式检索子集,因此它们也用于定位和检索图像中感兴趣的区域。
    以图像中的区域为目标的切片由图像的两个轴(水平(X)和垂直(Y))的起始值和结束值定义,格式如下:
    image[startY: endY, startx:endX]
    它返回所需感兴趣区域的(图像像素的)Numpy数组。
    那么,我们如何确定感兴趣区域的X轴和Y轴的起始值和结束值?
    这些值(startX、endX、startY、endY)是映射出感兴趣区域的坐标值。
    使用OpenCV显示时,这些值不会显示在图像旁边,但我们可以使用其他应用程序(如Photoshop、Corel Draw、Paint e.t.c)或其他python可视化库(如Matplotlib)来显示具有X和Y坐标值的图像。
    一如既往,这在实践中得到了更好的理解。让我们使用matplotlib显示一个图像。pyplot,我们可以从中检索坐标,这些坐标映射出图像中的目标感兴趣区域。
    我用加纳共和国国旗的图像来证明这一点。在这里,我的目标是图像中围绕黑星的区域。
    获取感兴趣区域的坐标值
    1.使用Matplotlib加载并显示图像。
    在OpenCV中使用图像像素
    输出:加载的图像及其X和Y坐标。
    在OpenCV中使用图像像素
    正如你所看到的,plt.imshow函数返回读取的图像以及x和y轴的坐标值。
    然后,我们可以检索感兴趣区域(黑星)的起始和结束坐标值。
    追踪黑星区域的坐标值
    在OpenCV中使用图像像素
    这幅图像显示了如何追踪黑星周围区域的坐标。
    我们可以从图像中检索坐标(startY(y1)、endY(y2)、startX(x1)、endX(x2))。然后,我们可以定义两个轴的起点和终点坐标,并裁剪为:
    image[y1: y2, x1:x2]
    if we get y1, y2 = [145, 295] and x1, x2 = [245, 400]
    那么绘制出黑星的区域将是:
    black_star = image[145:295, 245:400]
    这将返回映射感兴趣区域(本例中为黑星)的像素值(在Numpy数组中)。
    现在,我们可以利用这种技术对图像区域进行定位和切片,以进行各种图像处理。
    使用切片操作裁剪图像
    1.加载并显示原始图像
    在OpenCV中使用图像像素
    输出:显示加载的图像。
    在OpenCV中使用图像像素
    2.获取图像的空间维度
    在OpenCV中使用图像像素
    输出:显示图像的空间尺寸。
    在OpenCV中使用图像像素
    3.裁剪图像
    裁剪出图像的左上角
    在OpenCV中使用图像像素
    输出:图像的左上角
    在OpenCV中使用图像像素
    裁剪出图像的右上角
    在OpenCV中使用图像像素
    输出:图像的右上角
    在OpenCV中使用图像像素
    裁剪出图像的左下角
    在OpenCV中使用图像像素
    输出:图像的左下角
    在OpenCV中使用图像像素
    裁剪出图像的右下角
    在OpenCV中使用图像像素
    输出:左下角。
    在OpenCV中使用图像像素
    4.使用尺寸将部分图像设置为特定颜色。
    在OpenCV中使用图像像素
    输出:将左上角设置为绿色
    在OpenCV中使用图像像素
    总结
    图像像素是表示图像中颜色强度的数值。使用OpenCV获取和设置不同图像处理的图像像素的过程基于Numpy阵列的切片操作。切片像素值在裁剪、重置、复制或增强图像时非常有用。
    感谢阅读!