python+openCV图像处理(二十六)开运算与闭运算

54 篇文章 13 订阅
import cv2 as cv
import numpy as np

def open_demo(image):#开操作=腐蚀+膨胀  去外边白点
    print(image.shape)
    gray = cv.cvtColor(image, cv.COLOR_BGR2GRAY)
    ret, binary = cv.threshold(gray, 0, 255, cv.THRESH_BINARY | cv.THRESH_OTSU)
    cv.imshow("binary", binary)
    kernel = cv.getStructuringElement(cv.MORPH_ELLIPSE, (15, 15))
    binary = cv.morphologyEx(binary, cv.MORPH_OPEN, kernel)
    cv.imshow("open-result", binary)

def close_demo(image):#闭操作=膨胀+腐蚀 填充里边黑点
    print(image.shape)
    gray = cv.cvtColor(image, cv.COLOR_BGR2GRAY)
    ret, binary = cv.threshold(gray, 0, 255, cv.THRESH_BINARY | cv.THRESH_OTSU)
    cv.imshow("binary", binary)
    kernel = cv.getStructuringElement(cv.MORPH_RECT, (15, 15))
    binary = cv.morphologyEx(binary, cv.MORPH_CLOSE, kernel)
    cv.imshow("close_demo", binary)

src = cv.imread("1.png")
cv.namedWindow("input image", cv.WINDOW_AUTOSIZE)
cv.imshow("input image", src)
open_demo(src)
close_demo(src)

cv.waitKey(0)

cv.destroyAllWindows()
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个简单的使用PythonOpenCV实现图像和视频加密的示例代码: ```python import cv2 import numpy as np def encrypt(img_path, key): # 读取图像 img = cv2.imread(img_path) # 将图像转换为灰度图 gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY) # 获取图像的宽度和高度 height, width = gray.shape # 生成随机数种子 np.random.seed(key) # 生成与图像大小相同的随机数矩阵 rand_matrix = np.random.randint(0, 256, (height, width)) # 对图像进行异或运算 encrypted_img = cv2.bitwise_xor(gray, rand_matrix) # 返回加密后的图像 return encrypted_img def decrypt(encrypted_img, key): # 获取图像的宽度和高度 height, width = encrypted_img.shape # 生成随机数种子 np.random.seed(key) # 生成与图像大小相同的随机数矩阵 rand_matrix = np.random.randint(0, 256, (height, width)) # 对加密图像进行异或运算 decrypted_img = cv2.bitwise_xor(encrypted_img, rand_matrix) # 返回解密后的图像 return decrypted_img def encrypt_video(video_path, key): # 读取视频 cap = cv2.VideoCapture(video_path) # 获取视频的帧率、宽度和高度 fps = int(cap.get(cv2.CAP_PROP_FPS)) width = int(cap.get(cv2.CAP_PROP_FRAME_WIDTH)) height = int(cap.get(cv2.CAP_PROP_FRAME_HEIGHT)) # 创建VideoWriter对象,用于写入加密后的视频 fourcc = cv2.VideoWriter_fourcc(*'mp4v') encrypted_video = cv2.VideoWriter('encrypted_video.mp4', fourcc, fps, (width, height), isColor=False) # 读取视频帧并加密 while True: ret, frame = cap.read() if not ret: break # 将图像转换为灰度图 gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY) # 加密图像 encrypted_frame = encrypt(gray, key) # 将加密后的帧写入加密视频 encrypted_video.write(encrypted_frame) # 释放资源 cap.release() encrypted_video.release() def decrypt_video(encrypted_video_path, key): # 读取加密视频 cap = cv2.VideoCapture(encrypted_video_path) # 获取加密视频的帧率、宽度和高度 fps = int(cap.get(cv2.CAP_PROP_FPS)) width = int(cap.get(cv2.CAP_PROP_FRAME_WIDTH)) height = int(cap.get(cv2.CAP_PROP_FRAME_HEIGHT)) # 创建VideoWriter对象,用于写入解密后的视频 fourcc = cv2.VideoWriter_fourcc(*'mp4v') decrypted_video = cv2.VideoWriter('decrypted_video.mp4', fourcc, fps, (width, height), isColor=False) # 读取加密视频帧并解密 while True: ret, frame = cap.read() if not ret: break # 解密帧 decrypted_frame = decrypt(frame, key) # 将解密后的帧写入解密视频 decrypted_video.write(decrypted_frame) # 释放资源 cap.release() decrypted_video.release() # 测试加密解密图像 encrypted_img = encrypt('test_img.jpg', 123) cv2.imwrite('encrypted_img.jpg', encrypted_img) decrypted_img = decrypt(encrypted_img, 123) cv2.imwrite('decrypted_img.jpg', decrypted_img) # 测试加密解密视频 encrypt_video('test_video.mp4', 123) decrypt_video('encrypted_video.mp4', 123) ``` 该代码中的 `encrypt` 函数和 `decrypt` 函数分别实现了图像的加密和解密操作,使用的加密算法是将图像的每个像素值与一个随机数进行异或运算,随机数矩阵的生成使用了Numpy库中的随机数函数。 `encrypt_video` 函数和 `decrypt_video` 函数分别实现了视频的加密和解密操作,使用的方法是对视频中的每一帧进行加密或解密操作,然后将加密或解密后的帧写入加密或解密视频中。 请注意:该示例代码仅为了演示加密和解密的基本原理,实际应用中需要使用更加复杂的加密算法和密钥管理方法,以确保加密的安全性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值