时间:2021-05-22
上个版本的Python OpenCV图片局部区域像素值处理,虽然实现了我需要的功能,但还是走了很多弯路,我意识到图片本就是数组形式,对于8位灰度图,通道数为1,它就是个二位数组,这样就没有必要再设置ROI区域,复制出来这块区域再循环提取像素存入数组进行处理了,可以直接将图片存入数组,再利用numpy进行切分相应的数组操作就可以了,这样一想就简单很多了,这篇我会贴出修改后的代码,直接省去了大段的代码啊。
ps:这次我重新装的opencv3.2.0版本,代码里面直接用cv2了
# 查看opencv版本,终端输入:$ pkg-config --modversion opencvcv_img_cv2.py
# -*- coding:utf-8 -*-__author__ = 'lwp'import cv2import numpy as npimport matplotlib.pyplot as plt path ='/media/lwp/A/111111.jpg' # 图片路径lwpImg = cv2.imread(path) # 加载图片gray_lwpImg = cv2.cvtColor(lwpImg, cv2.COLOR_BGR2GRAY) # 转为灰度图# 画目标区域,参数分别为图片、左上坐标、右下坐标、框的颜色、框线条的粗细lwpImg = cv2.rectangle(lwpImg, (290, 0), (310, 327), (0, 255, 0), 2) # 显示标记后的图片cv2.imshow('local_pixel', lwpImg) # 提取图片像素值到矩阵pixel_data = np.array(gray_lwpImg)# 提取目标区域box_data = pixel_data[:, 290:310]# 矩阵行求和pixel_sum = np.sum(box_data, axis=1)# 画图x = range(576)fig = plt.figure(figsize=(4, 2))ax1 = fig.add_subplot(1, 1, 1)ax1.bar(x, pixel_sum, width=1) # x为每个条形到x轴0点的距离,width为每个条的宽度plt.xlabel('X')plt.ylabel('Y')plt.title('edge_filter')plt.grid(True)plt.show()key = cv2.waitKey(0) & 0xFFif key == ord('q'): # 按q关闭窗口 cv2.destroyAllWindows()效果:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
python+opencv车道线检测(简易实现),供大家参考,具体内容如下技术栈:python+opencv实现思路:1、canny边缘检测获取图中的边缘信息;
本文实例为大家分享了python+opencv实现霍夫变换检测直线的具体代码,供大家参考,具体内容如下python+opencv实现高斯平滑滤波python+o
Python+OpenCV直接上代码importcv2importnumpyasnpfrommatplotlibimportpyplotaspltfromPIL
上一篇文章中,我们介绍了python实现图片处理和特征提取详解,这里我们再来看看Python通过OpenCV实现批量剪切图片,具体如下。做图像处理需要大批量的修
利用Python+opencv实现从摄像头捕获图像,识别其中的人眼/人脸,并打上马赛克。系统环境:Windows7+Python3.6.3+opencv3.4.