python 实现波浪滤镜特效


Posted in Python onDecember 02, 2020

本文用 Python 实现 PS 滤镜的波浪特效

import numpy as np
from skimage import img_as_float
import matplotlib.pyplot as plt
from skimage import io
import numpy.matlib
import math
# 图片位置
file_name2='D:/Visual Effects/PS Algorithm/4.jpg'
img=io.imread(file_name2)

img = img_as_float(img)

row, col, channel = img.shape
img_out = img * 1.0
alpha = 70.0
beta = 30.0
degree = 20.0

center_x = (col-1)/2.0
center_y = (row-1)/2.0

xx = np.arange(col)
yy = np.arange(row)

x_mask = numpy.matlib.repmat (xx, row, 1)
y_mask = numpy.matlib.repmat (yy, col, 1)
y_mask = np.transpose(y_mask)

xx_dif = x_mask - center_x
yy_dif = center_y - y_mask

x = degree * np.sin(2 * math.pi * yy_dif / alpha) + xx_dif
y = degree * np.cos(2 * math.pi * xx_dif / beta) + yy_dif

x_new = x + center_x
y_new = center_y - y 

int_x = np.floor (x_new)
int_x = int_x.astype(int)
int_y = np.floor (y_new)
int_y = int_y.astype(int)

for ii in range(row):
  for jj in range (col):
    new_xx = int_x [ii, jj]
    new_yy = int_y [ii, jj]

    if x_new [ii, jj] < 0 or x_new [ii, jj] > col -1 :
      continue
    if y_new [ii, jj] < 0 or y_new [ii, jj] > row -1 :
      continue

    img_out[ii, jj, :] = img[new_yy, new_xx, :]


plt.figure (1)
plt.imshow (img)
plt.axis('off')

plt.figure (2)
plt.imshow (img_out)
plt.axis('off')

plt.show()

实现效果

python 实现波浪滤镜特效

以上就是python 实现波浪滤镜特效的详细内容,更多关于python 波浪滤镜的资料请关注三水点靠木其它相关文章!

Python 相关文章推荐
Python的subprocess模块总结
Nov 07 Python
python实现的系统实用log类实例
Jun 30 Python
python 随机数使用方法,推导以及字符串,双色球小程序实例
Sep 12 Python
使用python中的in ,not in来检查元素是不是在列表中的方法
Jul 06 Python
对python 判断数字是否小于0的方法详解
Jan 26 Python
Django打印出在数据库中执行的语句问题
Jul 25 Python
Python tkinter实现图片标注功能(完整代码)
Dec 08 Python
Anaconda+VSCode配置tensorflow开发环境的教程详解
Mar 30 Python
Python 如何创建一个线程池
Jul 28 Python
Python如何执行系统命令
Sep 23 Python
详解python os.path.exists判断文件或文件夹是否存在
Nov 16 Python
详解Python小数据池和代码块缓存机制
Apr 07 Python
python 如何对logging日志封装
Dec 02 #Python
python3中确保枚举值代码分析
Dec 02 #Python
python使用yaml 管理selenium元素的示例
Dec 01 #Python
python3处理word文档实例分析
Dec 01 #Python
python3中布局背景颜色代码分析
Dec 01 #Python
python 读取yaml文件的两种方法(在unittest中使用)
Dec 01 #Python
Python用摘要算法生成token及检验token的示例代码
Dec 01 #Python
You might like
Apache, PHP在Windows 9x/NT下的安装与配置 (一)
2006/10/09 PHP
php添加文章时生成静态HTML文章的实现代码
2013/02/17 PHP
必须收藏的php实用代码片段
2016/02/02 PHP
深入解析Laravel5.5中的包自动发现Package Auto Discovery
2017/09/13 PHP
PHP数据源架构模式之表入口模式实例分析
2020/01/23 PHP
优化 JavaScript 代码的方法小结
2009/07/16 Javascript
Javascript this指针
2009/07/30 Javascript
javascript 匿名函数的理解(透彻版)
2010/01/28 Javascript
from 表单提交返回值用post或者是get方法实现
2013/08/21 Javascript
JavaScript中实现单体模式分享
2015/01/29 Javascript
JavaScript整除运算函数ceil和floor的区别分析
2015/04/14 Javascript
jQuery.Uploadify插件实现带进度条的批量上传功能
2016/06/08 Javascript
浅谈jquery的map()和each()方法
2016/06/12 Javascript
jQuery常用样式操作实例分析(获取、设置、追加、删除、判断等)
2016/09/08 Javascript
详解Javascript数据类型的转换规则
2016/12/12 Javascript
JS 实现随机验证码功能
2017/02/15 Javascript
浅谈regExp的test方法取得的值变化的原因及处理方法
2017/03/01 Javascript
Vue.js实战之利用vue-router实现跳转页面
2017/04/01 Javascript
webpack构建react多页面应用详解
2017/09/15 Javascript
vue.js 实现点击展开收起动画效果
2018/07/07 Javascript
Vue常用的几个指令附完整案例
2018/11/06 Javascript
微信小程序实现打开并下载服务器上面的pdf文件到手机
2019/09/20 Javascript
解决vue bus.$emit触发第一次$on监听不到问题
2020/07/28 Javascript
[01:12:53]完美世界DOTA2联赛PWL S2 Forest vs SZ 第一场 11.25
2020/11/26 DOTA
Python使用matplotlib的pie函数绘制饼状图功能示例
2018/01/08 Python
使用python绘制二维图形示例
2019/11/22 Python
python3实现从kafka获取数据,并解析为json格式,写入到mysql中
2019/12/23 Python
舒适的豪华鞋:Taryn Rose
2018/05/03 全球购物
英超联赛的首选足球:Mitre足球
2019/05/06 全球购物
荷兰最大的多品牌男装连锁店:Adam Brandstore
2019/12/31 全球购物
2014年社区植树节活动方案
2014/02/28 职场文书
室内设计专业毕业生求职信
2014/05/02 职场文书
优秀小学生事迹材料
2014/12/26 职场文书
2015初中教导处工作总结
2015/07/21 职场文书
原生JavaScript实现简单五子棋游戏
2021/06/28 Javascript
Python爬虫中urllib3与urllib的区别是什么
2021/07/21 Python