【Python+OpenCV】图片局部区域像素值处理(改进版)-一种特征提取方法
来源:互联网 发布:人工智能机器人ai 编辑:程序博客网 时间:2024/05/17 03:53
上一个版本看这里:《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 cv2import numpy as npimport matplotlib.pyplot as pltpath ='/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()
0 0
- 【Python+OpenCV】图片局部区域像素值处理(改进版)-一种特征提取方法
- 【Python+OpenCV】视频流局部区域像素值处理-一种特征提取方法
- 【Python+OpenCV】图片局部区域像素值处理
- opencv 提取感兴趣区域 (新版方法)
- opencv-图片特征点提取
- 【OpenCV】图片几何特征提取
- Caffe图片特征提取(Python/C++)
- 用python进行图片处理和特征提取
- 用python进行图片处理和特征提取
- 简单的图像显著性区域特征提取方法-----opencv实现LC,AC,FT
- 【图像特征提取4】改进的圆形局部二值模式LBP特征描述符C++代码的实现
- 图片处理工具-局部像素替换
- 特征提取--基于局部二值模型(LBP)的特征提取
- OpenCV处理像素值
- 条形码区域的提取--python(opencv)
- Python+OpenCV感兴趣区域ROI提取
- LBP(局部二值模式)特征提取原理
- 一种改进的OPenCV局部 自适应快速二值化
- oracle 返回table类型的结果集:
- Activiti流程设计工具
- Spring学习笔记之Spring MVC体系学习(一)
- Ubuntu下 嵌入式Qt开发环境的搭建
- 数据结构学习之二叉树
- 【Python+OpenCV】图片局部区域像素值处理(改进版)-一种特征提取方法
- .net C# POST请求数据,…
- 全球最杰出的14位程序员
- 多线程简介
- 100. Same Tree
- PHP生成二维码的方法
- 第一次使用Gradle构建Java程序
- 成员指针操作符
- 全面了解 Nginx 主要应用场景