Python实现PS滤镜的旋转模糊功能示例


Posted in Python onJanuary 20, 2018

本文实例讲述了Python实现PS滤镜的旋转模糊功能。分享给大家供大家参考,具体如下:

这里用 Python 实现 PS 滤镜中的旋转模糊,具体的算法原理和效果可以参考附录相关介绍。Python代码如下:

from skimage import img_as_float
import matplotlib.pyplot as plt
from skimage import io
import numpy as np
import numpy.matlib
file_name='D:/Visual Effects/PS Algorithm/4.jpg'
img=io.imread(file_name)
img = img_as_float(img)
img_out = img.copy()
row, col, channel = img.shape
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)
center_y = (row -1) / 2.0
center_x = (col -1) / 2.0
R = np.sqrt((x_mask - center_x) **2 + (y_mask - center_y) ** 2)
angle = np.arctan2(y_mask - center_y , x_mask - center_x)
Num = 20
arr = ( np.arange(Num) + 1 ) / 100.0
for i in range (row):
  for j in range (col):
    T_angle = angle[i, j] + arr
    new_x = R[i, j] * np.cos(T_angle) + center_x
    new_y = R[i, j] * np.sin(T_angle) + center_y
    int_x = new_x.astype(int)
    int_y = new_y.astype(int)
    int_x[int_x > col-1] = col - 1
    int_x[int_x < 0] = 0
    int_y[int_y < 0] = 0
    int_y[int_y > row -1] = row -1
    img_out[i,j,0] = img[int_y, int_x, 0].sum()/Num
    img_out[i,j,1] = img[int_y, int_x, 1].sum()/Num
    img_out[i,j,2] = img[int_y, int_x, 2].sum()/Num
plt.figure(1)
plt.imshow(img)
plt.axis('off')
plt.figure(2)
plt.imshow(img_out)
plt.axis('off')
plt.show()

附:PS 滤镜——旋转模糊

这里给出灰度图像的模糊算法,彩色图像只要分别对三个通道做模糊即可。

%% spin blur
% 旋转模糊
clc;
clear all;
close all;
I=imread('4.jpg');
I=double(I);
% % % I_new=I;
% % % for kk=1:3
% % %   I_new(:,:,kk)=Spin_blur_Fun(I(:,:,kk), 30, 30);
% % % end
% % % imshow(I_new/255)
Image=I;
Image=0.2989 * I(:,:,1) + 0.5870 * I(:,:,2) + 0.1140 * I(:,:,3);
[row, col]=size(Image);
Image_new=Image;
Center_X=(col+1)/2;
Center_Y=(row+1)/2;
validPoint=1;
angle=5;
radian=angle*pi/180;
radian2=radian*radian;
Num=30;
Num2=Num*Num;
for i=1:row
  for j=1:col
    validPoint=1;
    x0=j-Center_X;
    y0=Center_Y-i;
    x1=x0;
    y1=y0;
    Sum_Pixel=Image(i,j);
    for k=1:Num
      x0=x1;
      y0=y1;
      %%% 逆时针
      % x1=x0-radian*y0/Num-radian2*x0/Num2;
      % y1=y0+radian*x0/Num-radian2*y0/Num2;
      %%% 顺时针
      x1=x0+radian*y0/Num-radian2*x0/Num2;
      y1=y0-radian*x0/Num-radian2*y0/Num2;
      x=floor(x1+Center_X);
      y=floor(Center_Y-y1);
      if(x>1 && x<col && y>1 && y<row)
        validPoint=validPoint+1;
        Sum_Pixel=Sum_Pixel+Image(y,x);
      end
    end
    Image_new(i,j)=Sum_Pixel/validPoint;
  end
end
 imshow(Image_new/255);

原图

Python实现PS滤镜的旋转模糊功能示例

效果图

Python实现PS滤镜的旋转模糊功能示例

效果图

Python实现PS滤镜的旋转模糊功能示例

希望本文所述对大家Python程序设计有所帮助。

Python 相关文章推荐
python二叉树的实现实例
Nov 21 Python
Python用zip函数同时遍历多个迭代器示例详解
Nov 14 Python
在 Python 应用中使用 MongoDB的方法
Jan 05 Python
python实现给微信公众号发送消息的方法
Jun 30 Python
Python简单获取网卡名称及其IP地址的方法【基于psutil模块】
May 24 Python
python实现windows下文件备份脚本
May 27 Python
python基础梳理(一)(推荐)
Apr 06 Python
Tensorflow设置显存自适应,显存比例的操作
Feb 03 Python
从0到1使用python开发一个半自动答题小程序的实现
May 12 Python
使用pytorch实现论文中的unet网络
Jun 24 Python
python如何代码集体右移
Jul 20 Python
Python趣味挑战之用pygame实现简单的金币旋转效果
May 31 Python
浅谈flask中的before_request与after_request
Jan 20 #Python
Python使用SQLite和Excel操作进行数据分析
Jan 20 #Python
python与sqlite3实现解密chrome cookie实例代码
Jan 20 #Python
Python实现PS滤镜中马赛克效果示例
Jan 20 #Python
浅析python协程相关概念
Jan 20 #Python
Python实现可自定义大小的截屏功能
Jan 20 #Python
python+matplotlib绘制饼图散点图实例代码
Jan 20 #Python
You might like
php实现的美国50个州选择列表实例
2015/04/20 PHP
PHP面向对象程序设计实例分析
2016/01/26 PHP
php倒计时出现-0情况的解决方法
2016/07/28 PHP
PHP入门教程之面向对象基本概念实例分析
2016/09/11 PHP
PHP实现登陆表单提交CSRF及验证码
2017/01/24 PHP
jQuery中的常用事件总结
2009/12/27 Javascript
理解Javascript_09_Function与Object
2010/10/16 Javascript
jquery 单击li防止重复加载的实现代码
2010/12/24 Javascript
JavaScript包装对象使用介绍
2013/08/29 Javascript
举例详解JavaScript中Promise的使用
2015/06/24 Javascript
JavaScript encodeURI 和encodeURIComponent
2015/12/04 Javascript
jquery实现定时自动轮播特效
2015/12/10 Javascript
详解vue组件开发脚手架
2018/06/15 Javascript
JavaScript中this的全面解析及常见实例
2019/05/14 Javascript
ES6 Array常用扩展的应用实例分析
2019/06/26 Javascript
基于vue-cli3创建libs库的实现方法
2019/12/04 Javascript
Vue v-bind动态绑定class实例方法
2020/01/15 Javascript
vue 公共列表选择组件,引用Vant-UI的样式方式
2020/11/02 Javascript
vue-router路由懒加载及实现的3种方式
2021/02/28 Vue.js
python备份文件的脚本
2008/08/11 Python
Python中的高级函数map/reduce使用实例
2015/04/13 Python
python实现图片变亮或者变暗的方法
2015/06/01 Python
Python根据文件名批量转移图片的方法
2018/10/21 Python
Python函数基础实例详解【函数嵌套,命名空间,函数对象,闭包函数等】
2019/03/30 Python
python实现飞机大战小游戏
2019/11/08 Python
python代码中怎么换行
2020/06/17 Python
css3强大的动画效果animate使用说明及浏览器兼容介绍
2013/01/09 HTML / CSS
英国日常交易网站:Wowcher
2018/09/04 全球购物
临床护士自荐信
2014/01/31 职场文书
广告语设计及教案
2014/03/21 职场文书
实习工作表现评语
2014/12/31 职场文书
万能检讨书开头与结尾怎么写
2015/02/17 职场文书
《角的度量》教学反思
2016/02/18 职场文书
聘任书的格式及模板
2019/10/28 职场文书
MySQL InnoDB ReplicaSet(副本集)简单介绍
2021/04/24 MySQL
Go 语言结构实例分析
2021/07/04 Golang