Python实现PS滤镜的万花筒效果示例


Posted in Python onJanuary 23, 2018

本文实例讲述了Python实现PS滤镜的万花筒效果。分享给大家供大家参考,具体如下:

这里用 Python 实现 PS 的一种滤镜效果,称为万花筒。也是对图像做各种扭曲变换,最后图像呈现的效果就像从万花筒中看到的一样:

图像的效果可以参考附录说明。具体Python代码如下:

import matplotlib.pyplot as plt
from skimage import io
from skimage import img_as_float
import numpy as np
import numpy.matlib
import math
file_name='D:/Visual Effects/PS Algorithm/4.jpg';
img=io.imread(file_name)
img = img_as_float(img)
row, col, channel = img.shape
# set the parameters
radius = 100.0
angle = math.pi/3
angle2 = math.pi/4
sides = 10.0
# set the center of the circle, proportion of the image size
centerX = 0.5
centerY = 0.5
iWidth=col
iHeight=row
center_x=iWidth*centerX
center_y=iHeight*centerY
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 = y_mask - center_y
r = np.sqrt(xx_dif * xx_dif + yy_dif * yy_dif)
theta = np.arctan2(yy_dif, xx_dif+0.0001) - angle - angle2
temp_theta=theta/math.pi*sides*0.5
temp_r = np.mod(temp_theta, 1.0)
mask_1 = temp_r < 0.5
theta = temp_r * 2 * mask_1 + (1-temp_r) * 2 * (1 - mask_1)
radius_c=radius/np.cos(theta)
temp_r = np.mod (r/radius_c, 1.0)
mask_1 = temp_r < 0.5
r = radius_c * (temp_r * 2 * mask_1 + (1-temp_r) * 2 * (1 - mask_1))
theta = theta + angle
x1_mask = r * np.cos(theta) + center_x
y1_mask = r * np.sin(theta) + center_y
mask = x1_mask < 0
x1_mask = x1_mask * (1 - mask)
mask = x1_mask > (col - 1)
x1_mask = x1_mask * (1 - mask) + (x1_mask * 0 + col -2) * mask
mask = y1_mask < 0
y1_mask = y1_mask * (1 - mask)
mask = y1_mask > (row -1)
y1_mask = y1_mask * (1 - mask) + (y1_mask * 0 + row -2) * mask
img_out = img * 1.0
int_x = np.floor (x1_mask)
int_x = int_x.astype(int)
int_y = np.floor (y1_mask)
int_y = int_y.astype(int)
p_mask = x1_mask - int_x
q_mask = y1_mask - int_y
img_out = img * 1.0
for ii in range(row):
  for jj in range (col):
    new_xx = int_x [ii, jj]
    new_yy = int_y [ii, jj]
#    p = p_mask[ii, jj]
#    q = q_mask[ii, jj]
    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()

附:PS 滤镜万花筒效果原理

clc;
  clear all;
  close all;
  addpath('E:\PhotoShop Algortihm\Image Processing\PS Algorithm');
  I=imread('4.jpg');
  I=double(I);
  Image=I/255;
  sz=size(Image);
  % set the parameters
  radius = 150;
  angle = pi/4;
  angle2=pi/4;
  sides=10;
  centerX = 0.5;  % set the center of the circle, proportion of the image size
  centerY = 0.5;
  iWidth=sz(2);
  iHeight=sz(1);
  icenterX=iWidth*centerX;
  icenterY=iHeight*centerY;
  Image_new=Image;
  for i=1:sz(1)
    for j=1:sz(2)
      dx=j-icenterX;
      dy=i-icenterY;
      r=sqrt(dy*dy+dx*dx);
      theta=atan2(dy, dx)-angle-angle2;
      temp_theta=theta/pi*sides*0.5 ;
      theta=triangle(temp_theta);
      if (radius)
        c=cos(theta);
        radius_c=radius/c;
        r=radius_c * triangle(r/radius_c);
      end
      theta=theta+angle;
      x=r * cos(theta)+icenterX;
      y=r * sin(theta)+icenterY;
      if (x<=1)   x=1; end
      if (x>=sz(2)) x=sz(2)-1; end;
      if (y>=sz(1)) y=sz(1)-1; end;
      if (y<1) y=1;   end;
  % % %     if (x<=1)   continue; end
  % % %     if (x>=sz(2))  continue; end;
  % % %     if (y>=sz(1)) continue; end;
  % % %     if (y<1) continue;   end;
      x1=floor(x);
      y1=floor(y);
      p=x-x1;
      q=y-y1;
      Image_new(i,j,:)=(1-p)*(1-q)*Image(y1,x1,:)+p*(1-q)*Image(y1,x1+1,:)...
        +q*(1-p)*Image(y1+1,x1,:)+p*q*Image(y1+1,x1+1,:);
    end
  end
  imshow(Image_new)
  imwrite(Image_new, 'out.jpg');

参考来源:http://www.jhlabs.com/index.html

原图:

Python实现PS滤镜的万花筒效果示例

效果图:

Python实现PS滤镜的万花筒效果示例

Python实现PS滤镜的万花筒效果示例

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

Python 相关文章推荐
python进程管理工具supervisor使用实例
Sep 17 Python
python和shell实现的校验IP地址合法性脚本分享
Oct 23 Python
分析Python编程时利用wxPython来支持多线程的方法
Apr 07 Python
Python logging管理不同级别log打印和存储实例
Jan 19 Python
查找python项目依赖并生成requirements.txt的方法
Jul 10 Python
python批量修改图片后缀的方法(png到jpg)
Oct 25 Python
python开发游戏的前期准备
May 05 Python
在django view中给form传入参数的例子
Jul 19 Python
在python中计算ssim的方法(与Matlab结果一致)
Dec 19 Python
Python爬虫爬取糗事百科段子实例分享
Jul 31 Python
详解Pytorch显存动态分配规律探索
Nov 17 Python
python脚本使用阿里云slb对恶意攻击进行封堵的实现
Feb 04 Python
python处理csv数据动态显示曲线实例代码
Jan 23 #Python
Python+matplotlib实现华丽的文本框演示代码
Jan 22 #Python
CentOS7.3编译安装Python3.6.2的方法
Jan 22 #Python
Python OpenCV实现图片上输出中文
Jan 22 #Python
python批量替换页眉页脚实例代码
Jan 22 #Python
python解析html提取数据,并生成word文档实例解析
Jan 22 #Python
Python复制Word内容并使用格式设字体与大小实例代码
Jan 22 #Python
You might like
php mysql Errcode: 28 终极解决方法
2009/07/01 PHP
ueditor 1.2.6 使用方法说明
2013/07/24 PHP
php获取远程文件的内容和大小
2015/11/03 PHP
nginx下安装php7+php5
2016/07/31 PHP
PHP Header失效的原因分析及解决方法
2016/11/16 PHP
PHP字符串中抽取子串操作实例分析
2019/06/22 PHP
php中数组最简单的使用方法
2020/12/27 PHP
利用jQuery操作对象数组的实现代码
2011/04/27 Javascript
浅析JavaScript中的事件机制
2015/06/04 Javascript
JavaScript中Date对象的常用方法示例
2015/10/24 Javascript
jquery制作属于自己的select自定义样式
2015/11/23 Javascript
移动端使用localStorage缓存Js和css文的方法(web开发)
2016/09/20 Javascript
将json转换成struts参数的方法
2016/11/08 Javascript
利用canvas实现的加载动画效果实例代码
2017/07/05 Javascript
ES6 Array常用扩展的应用实例分析
2019/06/26 Javascript
基于VUE的v-charts的曲线显示功能
2019/10/01 Javascript
Vuejs中的watch实例详解(监听者)
2020/01/05 Javascript
JS通过识别id、value值对checkbox设置选中状态
2020/02/19 Javascript
Vue中keep-alive 实现后退不刷新并保持滚动位置
2020/03/17 Javascript
Python实现可自定义大小的截屏功能
2018/01/20 Python
分析Python读取文件时的路径问题
2018/02/11 Python
python3中zip()函数使用详解
2018/06/29 Python
详解python算法之冒泡排序
2019/03/05 Python
Python中BeautifuSoup库的用法使用详解
2019/11/15 Python
python 实现一个反向单位矩阵示例
2019/11/29 Python
Python实现不规则图形填充的思路
2020/02/02 Python
tensorflow/core/platform/cpu_feature_guard.cc:140] Your CPU supports instructions that this T
2020/06/22 Python
美国美食礼品篮网站:Gourmet Gift Baskets
2019/12/15 全球购物
创业计划书如何编写
2014/02/06 职场文书
党校培训自我鉴定范文
2014/03/20 职场文书
第二课堂活动总结
2014/05/07 职场文书
会计学专业自荐信
2014/06/25 职场文书
教师党的群众路线教育实践活动学习心得体会
2014/10/30 职场文书
布达拉宫的导游词
2015/02/02 职场文书
违反纪律检讨书范文
2015/05/07 职场文书
Python自动化实战之接口请求的实现
2022/05/30 Python