python opencv图像处理(素描、怀旧、光照、流年、滤镜 原理及实现)


Posted in Python onDecember 10, 2020

图像素描特效

图像素描特效主要经过以下几个步骤:

调用cv.cvtColor()函数将彩色图像灰度化处理;
通过cv.GaussianBlur()函数实现高斯滤波降噪;
边缘检测采用Canny算子实现;
最后通过cv.threshold()反二进制阈值化处理实现素描特效。

#coding:utf-8
import cv2 as cv
import numpy as np

#读取原始图像
img = cv.imread('d:/paojie.png')

#图像灰度处理
gray = cv.cvtColor(img,cv.COLOR_BGR2GRAY)

#高斯滤波降噪
gaussian = cv.GaussianBlur(gray, (5,5), 0)
 
#Canny算子
canny = cv.Canny(gaussian, 50, 150)

#阈值化处理
ret, result = cv.threshold(canny, 0, 255, cv.THRESH_BINARY_INV+cv.THRESH_OTSU)

#显示图像
#cv.imshow('src', img)
#cv.imshow('result', result)
cv.imshow('result',np.vstack((gray,result)))
cv.waitKey()
cv.destroyAllWindows()

图像素描特效展示

python opencv图像处理(素描、怀旧、光照、流年、滤镜 原理及实现)

图像怀旧特效

怀旧特效是将图像的RGB三个分量分别按照一定比例进行处理的结果,其怀旧公式如下所示:

python opencv图像处理(素描、怀旧、光照、流年、滤镜 原理及实现)

#coding:utf-8
import cv2 as cv
import numpy as np

#读取原始图像
img = cv.imread('d:/paojie.png')

#获取图像行和列
rows, cols = img.shape[:2]

#新建目标图像
dst = np.zeros((rows, cols, 3), dtype="uint8")

#图像怀旧特效
for i in range(rows):
  for j in range(cols):
    B = 0.272*img[i,j][2] + 0.534*img[i,j][1] + 0.131*img[i,j][0]
    G = 0.349*img[i,j][2] + 0.686*img[i,j][1] + 0.168*img[i,j][0]
    R = 0.393*img[i,j][2] + 0.769*img[i,j][1] + 0.189*img[i,j][0]
    if B>255:
      B = 255
    if G>255:
      G = 255
    if R>255:
      R = 255
    dst[i,j] = np.uint8((B, G, R))
    
#显示图像
cv.imshow('result',np.vstack((img,dst)))
cv.waitKey()
cv.destroyAllWindows()

图像怀旧特效展示

python opencv图像处理(素描、怀旧、光照、流年、滤镜 原理及实现)

图像光照特效

图像光照特效是指图像存在一个类似于灯光的光晕特效,图像像素值围绕光照中心点呈圆形范围内的增强。
python实现代码主要是通过双层循环遍历图像的各像素点,寻找图像的中心点,再通过计算当前点到光照中心的距离(平面坐标系中两点之间的距离),判断该距离与图像中心圆半径的大小关系,中心圆范围内的图像灰度值增强,范围外的图像灰度值保留,并结合边界范围判断生成最终的光照效果。

#coding:utf-8
import cv2 as cv
import math
import numpy as np

#读取原始图像
img = cv.imread('d:/paojie.png')

#获取图像行和列
rows, cols = img.shape[:2]

#设置中心点和光照半径
centerX = rows / 2 - 20
centerY = cols / 2 + 20
radius = min(centerX, centerY)

#设置光照强度
strength = 100

#新建目标图像
dst = np.zeros((rows, cols, 3), dtype="uint8")

#图像光照特效
for i in range(rows):
  for j in range(cols):
    #计算当前点到光照中心距离(平面坐标系中两点之间的距离)
    distance = math.pow((centerY-j), 2) + math.pow((centerX-i), 2)
    #获取原始图像
    B = img[i,j][0]
    G = img[i,j][1]
    R = img[i,j][2]
    if (distance < radius * radius):
      #按照距离大小计算增强的光照值
      result = (int)(strength*( 1.0 - math.sqrt(distance) / radius ))
      B = img[i,j][0] + result
      G = img[i,j][1] + result
      R = img[i,j][2] + result
      #判断边界 防止越界
      B = min(255, max(0, B))
      G = min(255, max(0, G))
      R = min(255, max(0, R))
      dst[i,j] = np.uint8((B, G, R))
    else:
      dst[i,j] = np.uint8((B, G, R))
    
#显示图像
cv.imshow('result',np.vstack((img,dst)))
cv.waitKey()
cv.destroyAllWindows()

图像光照特效展示

python opencv图像处理(素描、怀旧、光照、流年、滤镜 原理及实现)

图像流年特效

流年是用来形容如水般流逝的光阴或年华,图像处理中特指将原图像转换为具有时代感或岁月沉淀的特效。python实现代码如下,它将原始图像的蓝色(B)通道的像素值开根号,再乘以一个权重参数,产生最终的流年效果。

#coding:utf-8
import cv2 as cv
import math
import numpy as np

#读取原始图像
img = cv.imread('d:/paojie.png')

#获取图像行和列
rows, cols = img.shape[:2]

#新建目标图像
dst = np.zeros((rows, cols, 3), dtype="uint8")

#图像流年特效
for i in range(rows):
  for j in range(cols):
    #B通道的数值开平方乘以参数12
    B = math.sqrt(img[i,j][0]) * 12
    G = img[i,j][1]
    R = img[i,j][2]
    if B>255:
      B = 255
    dst[i,j] = np.uint8((B, G, R))
    
#显示图像
cv.imshow('result',np.vstack((img,dst)))
cv.waitKey()
cv.destroyAllWindows()

图像流年特效展示

python opencv图像处理(素描、怀旧、光照、流年、滤镜 原理及实现)

图像滤镜特效

滤镜主要是用来实现图像的各种特殊效果,它在Photoshop中具有非常神奇的作用。滤镜通常需要同通道、图层等联合使用,才能取得最佳艺术效果。本小节将讲述一种基于颜色查找表(Look up Table)的滤镜处理方法,它通过将每一个原始颜色进行转换之后得到新的颜色。比如,原始图像的某像素点为红色(R-255, G-0, B-0),进行转换之后变为绿色(R-0, G-255, B-0),之后所有是红色的地方都会被自动转换为绿色,而颜色查找表就是将所有的颜色进行一次(矩阵)转换,很多的滤镜功能就是提供了这么一个转换的矩阵,在原始色彩的基础上进行颜色的转换。
假设现在存在一张新的滤镜颜色查找表,如图所示,它是一张512×512大小,包含各像素颜色分布的图像。下面这张图片另存为本地,即可直接用于图像滤镜处理。

python opencv图像处理(素描、怀旧、光照、流年、滤镜 原理及实现)

#coding:utf-8
import cv2 as cv 
import numpy as np

#获取滤镜颜色
def getBGR(img, table, i, j):
  #获取图像颜色
  b, g, r = img[i][j]
  #计算标准颜色表中颜色的位置坐标
  x = int(g/4 + int(b/32) * 63)
  y = int(r/4 + int((b%32) / 4) * 63)
  #返回滤镜颜色表中对应的颜色
  return lj_map[x][y]

#读取原始图像
img = cv.imread('d:/paojie.png')
lj_map = cv.imread('lvjing.png')

#获取图像行和列
rows, cols = img.shape[:2]

#新建目标图像
dst = np.zeros((rows, cols, 3), dtype="uint8")

#循环设置滤镜颜色
for i in range(rows):
  for j in range(cols):
    dst[i][j] = getBGR(img, lj_map, i, j)
    
#显示图像
cv.imshow('result',np.vstack((img,dst)))

cv.waitKey()
cv.destroyAllWindows()

图像滤镜特效展示

python opencv图像处理(素描、怀旧、光照、流年、滤镜 原理及实现)

以上就是python opencv图像处理(素描、怀旧、光照、流年、滤镜 原理及实现)的详细内容,更多关于python opencv图像处理的资料请关注三水点靠木其它相关文章!

Python 相关文章推荐
Python中的闭包实例详解
Aug 29 Python
python使用fileinput模块实现逐行读取文件的方法
Apr 29 Python
pycharm安装图文教程
May 02 Python
Python使用matplotlib和pandas实现的画图操作【经典示例】
Jun 13 Python
Python自动化运维之Ansible定义主机与组规则操作详解
Jun 13 Python
tensorflow 实现打印pb模型的所有节点
Jan 23 Python
使用Bazel编译TensorBoard教程
Feb 15 Python
在python3中实现更新界面
Feb 21 Python
新版Pycharm中Matplotlib不会弹出独立的显示窗口的问题
Jun 02 Python
python如何实现读取并显示图片(不需要图形界面)
Jul 08 Python
Python基础教程(一)——Windows搭建开发Python开发环境
Jul 20 Python
爬虫代理的cookie如何生成运行
Sep 22 Python
python 实现的IP 存活扫描脚本
Dec 10 #Python
class类在python中获取金融数据的实例方法
Dec 10 #Python
Python制作简单的剪刀石头布游戏
Dec 10 #Python
python给list排序的简单方法
Dec 10 #Python
详解java调用python的几种用法(看这篇就够了)
Dec 10 #Python
Python利用imshow制作自定义渐变填充柱状图(colorbar)
Dec 10 #Python
详解Python GUI编程之PyQt5入门到实战
Dec 10 #Python
You might like
PHP flush()与ob_flush()的区别详解
2013/06/03 PHP
PHP接收App端发送文件流的方法
2016/09/23 PHP
Laravel 5.1 on SAE环境开发教程【附项目demo源码】
2016/10/09 PHP
PHP编程实现csv文件导入mysql数据库的方法
2017/04/29 PHP
visual studio code 调试php方法(图文详解)
2017/09/15 PHP
Yii 框架使用Forms操作详解
2020/05/18 PHP
JS处理VBArray的函数使用说明
2008/05/11 Javascript
JavaScript 设计模式学习 Factory
2009/07/29 Javascript
JavaScript实现拼音排序的方法
2012/11/20 Javascript
js获取当月最后一天实例代码
2013/11/19 Javascript
jquery实现tr元素的上下移动示例代码
2013/12/20 Javascript
自写的jQuery异步加载数据添加事件
2014/05/15 Javascript
js中 计算两个日期间的工作日的简单实例
2016/08/08 Javascript
详解JavaScript中return的用法
2017/05/08 Javascript
vue开发调试神器vue-devtools使用详解
2017/07/13 Javascript
JavaScript实现三级级联特效
2017/11/05 Javascript
利用vue + koa2 + mockjs模拟数据的方法教程
2017/11/22 Javascript
在 React、Vue项目中使用SVG的方法
2018/02/09 Javascript
手写简单的jQuery雪花飘落效果实例
2018/04/22 jQuery
Echarts之悬浮框中的数据排序问题
2018/11/08 Javascript
15分钟深入了解JS继承分类、原理与用法
2019/01/19 Javascript
微信小程序实现基于三元运算验证手机号/姓名功能示例
2019/01/19 Javascript
[01:13:17]Secret vs NB 2018国际邀请赛小组赛BO2 第二场 8.19
2018/08/21 DOTA
[01:30]我们共输赢 完美世界城市挑战赛开启全新赛季
2019/04/19 DOTA
python通过wxPython打开一个音频文件并播放的方法
2015/03/25 Python
深入解析Python中的上下文管理器
2016/06/28 Python
python 二维数组90度旋转的方法
2019/01/28 Python
利用 Flask 动态展示 Pyecharts 图表数据方法小结
2019/09/04 Python
Python集合基本概念与相关操作实例分析
2019/10/30 Python
python如何控制进程或者线程的个数
2020/10/16 Python
英国儿童设计师服装的领先零售商:Base
2019/03/17 全球购物
办公室文秘岗位职责
2013/11/15 职场文书
道德之星事迹材料
2014/05/03 职场文书
地下停车场租赁协议范本
2014/10/07 职场文书
科技活动周标语
2014/10/08 职场文书
单位婚育证明范本
2014/11/21 职场文书