OpenCV---像素运算
像素运算
分为算术运算和逻辑运算
算术运算:
加减乘除
调节亮度
调整对比度
逻辑运算:
与或非
遮罩层控制
一:算术运算
import cv2 as cv
import numpy as np def add_demo(m1,m2):
dst = cv.add(m1,m2)
cv.imshow("add_demo",dst) def subtract_demo(m1,m2):
dst = cv.subtract(m1,m2)
cv.imshow("subtract_demo",dst) def multiply_demo(m1,m2):
dst = cv.multiply(m1,m2)
cv.imshow("multiply_demo",dst) def divide_demo(m1,m2):
dst = cv.divide(m1,m2) #不多用
cv.imshow("divide_demo",dst) src1 = cv.imread("./a1.jpg") #读取图片
src2 = cv.imread("./a2.jpg") #读取图片
print(src1.shape)
print(src2.shape)
cv.imshow("image1",src1)
cv.imshow("image2",src2)
add_demo(src1,src2)
subtract_demo(src1,src2)
multiply_demo(src1,src2)
divide_demo(src1,src2)
cv.waitKey() #等待用户操作,里面等待参数是毫秒,我们填写0,代表是永远,等待用户操作
cv.destroyAllWindows() #销毁所有窗口
原图:

add:(黑色是0,白色为255,当大于255会为白色,小于0为黑色)

subtract:

multiply:

divide:

获得各个通道的均值:
def others(m1,m2):
M1 = cv.mean(m1)
M2 = cv.mean(m2)
print(M1)
print(M2)
(190.8543375, 190.8543375, 190.8543375, 0.0) #整体偏黑
(186.68600625000002, 228.5496625, 241.74333125, 0.0) #红绿较多,所以偏黄
获取各个图像的方差:
def others(m1,m2):
M1 = cv.mean(m1)
M2 = cv.mean(m2)
M1,dev1 = cv.meanStdDev(m1) #返回均值和方差,分别对应3个通道
M2,dev2 = cv.meanStdDev(m2)
print(M1)
print(dev1)
print(M2)
print(dev2)
[[190.8543375] #M1
[190.8543375]
[190.8543375]]
[[95.31664687] #dev1
[95.31664687]
[95.31664687]]
[[186.68600625] #M2
[228.5496625 ]
[241.74333125]]
[[72.40766216] #dev2
[39.39460523]
[30.92104465]]
可以知道dev2偏小,所以图二中色彩差异(对比性)是较小的,若是整张图片同色,则方差为0,均值为0,可以用来查看扫描仪中是否有信息(方差小于一个预值,则失效,丢弃)
img = np.zeros([,,],np.uint8)
m,dev = cv.meanStdDev(img)
print(m,dev)
二:逻辑运算
与and:(1和1为1)(类似遮罩,当我们使用白色遮罩)
def logic_and_demo(m1,m2):
dst = cv.bitwise_and(m1,m2)
cv.imshow("logic_and_demo",dst)

或or:(1和1,1和0都为1)
def logic_or_demo(m1,m2):
dst = cv.bitwise_or(m1,m2)
cv.imshow("logic_or_demo",dst)

异或xor:(1和0为1)
def logic_xor_demo(m1,m2): #异或:不同为1,相同为0
dst = cv.bitwise_xor(m1,m2)
cv.imshow("logic_or_demo",dst)

非(not):对一张图片取反
def logic_not_demo(m1): #非是对于一张图片
dst = cv.bitwise_not(m1)
cv.imshow("logic_not_demo",dst)

补充:针对视频中inrange
def extrace_object():
capture = cv.VideoCapture("./1.mp4")
while True:
ret,frame = capture.read() #frame是每一帧图像,ret是返回值,为0是表示图像读取完毕
if ret == False:
break
hsv = cv.cvtColor(frame,cv.COLOR_BGR2HSV)
lower_hsv = np.array([,,])
upper_hsv = np.array([,,])
mask = cv.inRange(hsv,lower_hsv,upper_hsv)
dst = cv.bitwise_and(frame,frame,mask=mask)
cv.imshow("video",frame)
cv.imshow("mask", mask)
cv.imshow("dst",dst)
c = cv.waitKey()
if c == :
break

mask:该函数输出的dst是一幅二值化之后的图像(是将满足我们的图像对象所有位都设为1白色,不满足设置为0黑色)

bitwise_and:白色全为1与原图相与,会将白色区域提取

调整亮度和对比度addWeighted
推文:Opencv 例程讲解 6 ---- 图片融合 addWeighted到底有多快?
def contrast_brightness_demo(image,c,b):
'''
:param image: 原图
:param c: 对比度 是将像素乘与c,原来2,---->, 差距由2--->4导致对比增强
:param b: 亮度 是将每个像素点加上相关亮度
:return:
'''
h,w,ch = image.shape
blank = np.zeros([h,w,ch],image.dtype)
dst = cv.addWeighted(image,c,blank,1-c,b)
cv.imshow("dst",dst)
src = cv.imread("./1.png")
cv.imshow("src",src)
contrast_brightness_demo(src,1.2,)

亮度:
src = cv.imread("./1.png")
cv.imshow("src",src)
contrast_brightness_demo(src,,)

、第1个参数,输入图片1,
、第2个参数,图片1的融合比例
、第3个参数,输入图片2
、第4个参数,图片2的融合比例
、第5个参数,偏差
、第6个参数,输出图片
OpenCV---像素运算的更多相关文章
- Python+OpenCV图像处理(五)—— 像素运算
最近在忙毕业设计,只能偶尔更新博客........ 一.像素的算术运算 像素的算术运算涉及加减乘除等基本运算(要进行算术运算,两张图片的形状(shape)必须一样) 代码如下: #像素的算术运算(加. ...
- opencv::卷积运算函数filter2D()
opencv::卷积运算函数filter2D() 使用掩模板矩阵(kernel)计算每个像素值 与原图相比,没有黑边 int main(int argc, char** argv) { Mat src ...
- python opencv:像素运算
以下运算两个图像的大小需要一样 算术运算: cv2.add(img1, img2):两个图像像素相加 cv2.subtract(img1, img2):两个图像像素相减 cv2.multiply(im ...
- 4、OpenCV Python 像素运算
__author__ = "WSX" import cv2 as cv import numpy as np #前提需要运算的图像大小和类型完全相同 #算术运算 加减乘除 #逻辑运 ...
- OpenCV像素操作和图形绘制
像素操作 #include<iostream> #include<opencv2/opencv.hpp> using namespace std; using namespac ...
- OpenCV——像素数据类型总结<摘>
1.Unsigned 8bits(一般的图像文件格式使用的大小)IplImage数据结构参数:IPL_DEPTH_8UCvMat数据结构参数:CV_8UC1,CV_8UC2,CV_8UC3,CV_8U ...
- Opencv Mat运算(转)
一.矩阵Mat I,img,I1,I2,dst,A,B; double k,alpha; Scalar s; //注意Mat的行列号是从0开始的 //定义矩阵a,b,c Mat a,b,c; //生成 ...
- opencv::像素重映射
像素重映射(cv::remap) 简单点说就是把输入图像中各个像素按照一定的规则映射到另外一张图像的对应位置上去,形成一张新的图像. Remap( InputArray src, // 输入图像 Ou ...
- js像素运算问题
通过DOM获取的某一距离属性(比如left)是带px单位的,直接对其算术运算不起效,要先把获取到的值处理一下去掉px单位. 方法一(用处理字符串的方式去除px): var x=document.get ...
- OpenCV——颜色运算(二)
#ifndef PS_ALGORITHM_H_INCLUDED #define PS_ALGORITHM_H_INCLUDED #include <iostream> #include & ...
随机推荐
- ES6的新特性(15)——Promise 对象
Promise 对象 Promise 的含义 Promise 是异步编程的一种解决方案,比传统的解决方案——回调函数和事件——更合理和更强大.它由社区最早提出和实现,ES6 将其写进了语言标准,统一了 ...
- Rsyslog的模板template详解
一. Template功能 根据用户需求指定任意格式 动态生成文件名 每个输出都使用了一些模板,包括针对文件的,针对用户消息等 备注: 旧版本:$template 新版本:template() V6之 ...
- scala程序运行的几种方式
HelloWorld简单实例 object HelloWorld{ def main(args:Array[String]){ println("HelloWorld") } } ...
- jQuery之过滤选择器
在原有选择器匹配的元素中进一步进行过滤的选择器 * 基本 * 内容 * 可见性 * 属性 需求 1. 选择第一个div 2. 选择最后一个class为box的元素 3. 选择所有class属性不为bo ...
- 【Python】python 反射机制在实际的应用场景讲解
剖析python语言中 "反射" 机制的本质和实际应用场景一. 前言 def s1(): print("s1是这个函数的名字!") s = "s1&q ...
- hdu 6434 Count (欧拉函数)
题目链接 Problem Description Multiple query, for each n, you need to get $$$$$$ \sum_{i=1}^{n} \sum_{j=1 ...
- HDFS集中式的缓存管理原理与代码剖析--转载
原文地址:http://yanbohappy.sinaapp.com/?p=468 Hadoop 2.3.0已经发布了,其中最大的亮点就是集中式的缓存管理(HDFS centralized cache ...
- BZOJ3591 最长上升子序列(状压dp)
之前听说过一种dp套dp的trick,大致是用另一个dp过程中用到的一些东西作为该dp的状态.这个题比较类似. 考虑求LIS时用到的单调队列.设f[S]为所选取集合为S的方案数,其中在单调队列内的标2 ...
- 题解 P1888 【三角函数】
堆排序万岁! 小金羊又来水题了 #include <iostream> #include <queue> using namespace std; priority_queue ...
- Unity3D手游开发日记(2) - 技能系统架构设计
我想把技能做的比较牛逼,所以项目一开始我就在思考,是否需要一个灵活自由的技能系统架构设计,传统的技能设计,做法都是填excel表,技能需要什么,都填表里,很死板,比如有的技能只需要1个特效,有的要10 ...