Python+OpenCV图片局部区域像素值处理改进版详解
2019-01-23 12:21
3947 查看
上个版本的Python OpenCV图片局部区域像素值处理,虽然实现了我需要的功能,但还是走了很多弯路,我意识到图片本就是数组形式,对于8位灰度图,通道数为1,它就是个二位数组,这样就没有必要再设置ROI区域,复制出来这块区域再循环提取像素存入数组进行处理了,可以直接将图片存入数组,再利用numpy进行切分相应的数组操作就可以了,这样一想就简单很多了,这篇我会贴出修改后的代码,直接省去了大段的代码啊。
ps:这次我重新装的opencv3.2.0版本,代码里面直接用cv2了
# 查看opencv版本,终端输入: $ pkg-config --modversion opencv
cv_img_cv2.py
# -*- coding:utf-8 -*- __author__ = 'lwp' import cv2 import numpy as np import 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) & 0xFF if key == ord('q'): # 按q关闭窗口 cv2.destroyAllWindows()
效果:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
您可能感兴趣的文章:
相关文章推荐
- Python+OpenCV图片局部区域像素值处理详解
- 【Python+OpenCV】图片局部区域像素值处理(改进版)-一种特征提取方法
- 【Python+OpenCV】图片局部区域像素值处理
- 【Python+OpenCV】视频流局部区域像素值处理-一种特征提取方法
- python3.6-opencv3.4鼠标交互查看图片像素
- opencv for python (6) 改变一幅图的特定区域 (往一幅图片上加标志)
- python3-opencv库(4)--图片像素运算,利用加权叠加调节图像对比度和亮度
- 【Python_OpenCv】笔记4:python,OpenCv中对图片像素的操作以及图片基本属性的获取方法
- 通过OpenCV修改图片某一像素的数值 Python实现
- vim+python+OpenCV学习三 : 对图像的像素处理
- python 读取、保存、二值化、灰度化图片+opencv处理图片的方法
- CAShapeLayer 局部区域暗色处理 iOS图片裁剪处理
- Opencv3 python学习1——图片基础处理
- Python中Scrapy爬虫图片处理详解
- 用python简单处理图片(4):图像中的像素访问
- 图像识别与处理之Opencv——选取图像局部区域
- 图片处理工具-局部像素替换
- Python 处理图片像素点的实例
- opencv-python 学习笔记1:简单的图片处理
- 用python简单处理图片(4):图像中的像素访问