%%% Vortex
%%% 漩涡效果 clc;
clear all;
close all; addpath('E:\PhotoShop Algortihm\Image Processing\PS Algorithm'); I=imread('4.jpg');
Image=double(I); [row, col,channel]=size(Image);
R=floor(max(row, col)/2);
Image_new=Image;
Degree=45;
Center_X=(col+1)/2;
Center_Y=(row+1)/2; for i=1:row
for j=1:col
x0=j-Center_X;
y0=Center_Y-i;
if(x0~=0)
beta=atan(y0/x0);
if(x0<0)
beta=beta+pi;
end
else
beta=pi/2;
end
radius=sqrt(x0*x0+y0*y0);
beta=beta+radius/Degree;
x=radius*cos(beta);
y=radius*sin(beta);
x=x+col/2;
y=row/2-y;
if(x>1 && x<col && y<row && y>1)
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
end
figure, imshow(Image_new/255);

原图

效果图

最新文章

  1. ubuntu安装使用latex和texmaker--PC端
  2. Caused by: org.hibernate.loader.MultipleBagFetchException: cannot simultaneously fetch multiple bags
  3. 2016开发一个app需要多少钱?app开发需要哪些成本-app开发问题汇总-广州达到信息
  4. poj1160 dp
  5. struts2中constant参数设置
  6. 用MATLAB实现字符串分割
  7. pygame “音乐盒”---- 播放一首歌&amp; 点击对话框后背景以及对话框大小改变
  8. C++编译器默默编写并调用哪些函数
  9. Oracle EBS-SQL (SYS-20):职责使用菜单2.sql
  10. OCP-1Z0-051-题目解析-第9题
  11. ios 设置屏幕方向的两种方法
  12. bzoj4974 字符串大师
  13. js判断一个元素是否在数组中
  14. mybatis打印完整的sql
  15. macbook 下 spark开发环境搭建(基于idea 和maven)及spark单机写运行jar
  16. WPF--模板选择
  17. [Python_3] Python 函数 &amp; IO
  18. IP 别名和辅助 IP 地址
  19. 使用Hive UDF和GeoIP库为Hive加入IP识别功能
  20. Redis-cli命令总结

热门文章

  1. Spring Cloud 微服务四:熔断器Spring cloud hystrix
  2. Intellij idea subversion checkout error
  3. Selenium+C#自动化脚本开发学习
  4. iOS设备获取总结
  5. Data Decisions: DSP vs. DMP
  6. delete 和 truncate 的 区别
  7. 使VS自动生成代码注释
  8. python基础4 ----字符编码
  9. DHTMLTree、Dtree和Ztree的学习使用
  10. Java EE规范是如何制定的