import cv2 as cv
import numpy as np
def add_photo(m1, m2):
dst = cv.add(m1, m2)
cv.imshow("add_photo", dst)
def subtract_photo(m1, m2):
dst = cv.subtract(m1, m2)
cv.imshow("subtract_photo", dst)
def divide_photo(m1, m2):
dst = cv.divide(m1, m2)
cv.imshow("divide_photo", dst)
def multiply_photo(m1, m2):
dst = cv.multiply(m1, m2)
cv.imshow("multiply_photo", dst)
def others(m1, m2):
M1, dev1 = cv.meanStdDev(m1)
M2, dev2 = cv.meanStdDev(m2)
print("M1:", M1, "\n", M2)
print("dev:", dev1, "\n", dev2)
h, w = m1.shape[:2]
img = np.zeros([h, w], np.uint8)
m, dev = cv.meanStdDev(img)
print(m, dev)
def logic_demo_and(m1, m2):
dst = cv.bitwise_and(m1, m2)
cv.imshow("and", dst)
def logic_demo_or(m1, m2):
dst = cv.bitwise_or(m1, m2)
cv.imshow("or", dst)
def logic_demo_not(m1):
dst = cv.bitwise_not(m1)
cv.imshow("not", dst)
def logic_demo_xor(m1, m2):
dst = cv.bitwise_xor(m1, m2)
cv.imshow("xor", dst)
def contrast_lightness_demo(image, c, b):
h, w, ch = image.shape
blank = np.zeros([h, w, ch], image.dtype)
dst = cv.addWeighted(image, c, blank, 1 - c, b)
cv.imshow("lightness", dst)
src1 = cv.imread("D:\ophotos\linux.jpg")
src2 = cv.imread("D:\ophotos\win.jpg")
cv.namedWindow("image1", cv.WINDOW_AUTOSIZE)
cv.namedWindow("image2", cv.WINDOW_AUTOSIZE)
print(src1.shape)
print(src2.shape)
cv.imshow("image1", src1)
cv.imshow("image2", src2)
add_photo(src1, src2)
subtract_photo(src1, src2)
divide_photo(src1, src2)
multiply_photo(src1, src2)
others(src1, src2)
logic_demo_and(src1, src2)
logic_demo_not(src1)
logic_demo_or(src1, src2)
logic_demo_xor(src1, src2)
contrast_lightness_demo(src, 1.2, 100)
cv.waitKey(0)
cv.destroyAllWindows()
像素数值运算