还记得原来写过一个对图像进行波纹扭曲操作的博文

这次实现的是水波特效,其实就是通过正余弦函数表示波纹中心位置慢慢向外扩散,通过叠加衰减因子使振幅不断减小,进而产生水波的效果。

效果如下:

原图:

波纹特效:

matlab代码如下:

 
  1. clear all;
  2. close all;
  3. clc;
  4.  
  5. cenH=128; %波纹中心
  6. cenW=128;
  7. R=80; %扩散半径
  8. amplitude =3; %幅度
  9. wavelength=30; %波长
  10. phase =20; %相位
  11.  
  12. img = double(imread('lena.jpg'));
  13. imshow(img,[])
  14. [H, W] = size(img);
  15.  
  16. imgn=zeros(H,W);
  17. ii=1;
  18. jj=1;
  19. for i=1:H
  20. for j=1:W
  21. dy = i-cenH;
  22. dx = j-cenW;
  23. dis=dx*dx+dy*dy;
  24. if dis>R*R || dis==0
  25. pix=[i j];
  26. else
  27. dis=sqrt(dis);
  28. amount= amplitude * sin(dis/wavelength * 2*pi - phase);
  29. amount = amount*(R-dis)*wavelength/(R*dis);
  30. ii=(i+dy*amount);
  31. jj=(j+dx*amount);
  32.  
  33. if ii<=1
  34. ii=1;
  35. end
  36. if jj<=1
  37. jj=1;
  38. end
  39. if ii>=H
  40. ii=H ;
  41. end
  42. if jj>=W
  43. jj=W;
  44. end
  45. pix=[ii jj];
  46. end
  47.  
  48. float_Y=pix(1)-floor(pix(1));
  49. float_X=pix(2)-floor(pix(2));
  50.  
  51. pix_up_left=[floor(pix(1)) floor(pix(2))]; %四个相邻的点
  52. pix_up_right=[floor(pix(1)) ceil(pix(2))];
  53. pix_down_left=[ceil(pix(1)) floor(pix(2))];
  54. pix_down_right=[ceil(pix(1)) ceil(pix(2))];
  55.  
  56. value_up_left=(1-float_X)*(1-float_Y); %计算临近四个点的权重
  57. value_up_right=float_X*(1-float_Y);
  58. value_down_left=(1-float_X)*float_Y;
  59. value_down_right=float_X*float_Y;
  60.  
  61. imgn(i,j)=value_up_left*img(pix_up_left(1),pix_up_left(2))+ ...
  62. value_up_right*img(pix_up_right(1),pix_up_right(2))+ ...
  63. value_down_left*img(pix_down_left(1),pix_down_left(2))+ ...
  64. value_down_right*img(pix_down_right(1),pix_down_right(2));
  65. end
  66. end
  67.  
  68. figure;
  69. imshow(imgn,[])
  70. imwrite(mat2gray(imgn),'imgn.jpg')

关注公众号: MATLAB基于模型的设计 (ID:xaxymaker) ,每天推送MATLAB学习最常见的问题,每天进步一点点,业精于勤荒于嬉

打开微信扫一扫哦!

matlab练习程序(水波特效)的更多相关文章

  1. inno 实现水波特效

    安装Inno Setup时如果选择了水波效果插件(如下图),将在Inno Setup的安装目录下自带有水波特效的例子,如路径:C:\Program Files (x86)\Inno Setup 5\E ...

  2. matlab练习程序(SUSAN检测)

    matlab练习程序(SUSAN检测) SUSAN算子既可以检测角点也可以检测边缘,不过角点似乎比不过harris,边缘似乎比不过Canny.不过思想还是有点意思的. 主要思想就是:首先做一个和原图像 ...

  3. 一款基于jquery实现的鼠标单击出现水波特效

    今天要为大家绍一款由jquery实现的鼠标单击出现水波特效.用鼠标猛点击页面,你可以看到页面不断出面水波纹效果.然后水波纹渐渐消失.效果非常不错.我们一起看下效果图: 在线预览   源码下载 实现的代 ...

  4. (转)matlab练习程序(HOG方向梯度直方图)

    matlab练习程序(HOG方向梯度直方图)http://www.cnblogs.com/tiandsp/archive/2013/05/24/3097503.html HOG(Histogram o ...

  5. Python: PS 滤镜--水波特效

    本文用 Python 实现 PS 滤镜中的 水波特效 import numpy as np from skimage import img_as_float import matplotlib.pyp ...

  6. matlab练习程序(随机粒子切换特效)

    视频制作软件中一般都会有相邻帧切换的特效,我过去用过vagas好像就有很多切换特效. 我想这个也算是其中一种吧,虽然我不确定实际中到底有没有这种切换. 实际上我只是下班后太无聊了,写着玩的,没什么高深 ...

  7. matlab示例程序--Motion-Based Multiple Object Tracking--卡尔曼多目标跟踪程序--解读

    静止背景下的卡尔曼多目标跟踪 最近学习了一下多目标跟踪,看了看MathWorks的关于Motion-Based Multiple Object Tracking的Documention. 官网链接:h ...

  8. matlab练习程序(透视投影,把lena贴到billboard上)

    本练习程序是受到了这个老外博文的启发,感觉挺有意思,就尝试了一下.他用的是opencv,我这里用的是matlab. 过去写过透视投影,当时是用来做倾斜校正的,这次同样用到了透视投影,不过更有意思,是将 ...

  9. matlab练习程序(多圆交点)

    最近总是对计算几何方面的程序比较感兴趣. 多圆求交点,要先对圆两两求交点. 有交点的圆分为相切圆和相交圆. 相切圆求法: 1.根据两圆心求直线 2.求公共弦直线方程 3.求两直线交点即两圆切点. 相交 ...

随机推荐

  1. 值得收藏的Mybatis通用Mapper使用大全。

    引言 由于小编的记性不太好,每次在写代码的时候总是把通用mapper的方法记错,所以今天把通用mapper的常用方法做一下总结,方便以后直接查看.好了,不废话啦. 引包 <!-- 通用Mappe ...

  2. winform文件筛选器

    在.net 框架中,微软给我们封装了一个用于打开文件的对话框——OpenFileDialog.而该对话框包含一个可以筛选文件的属性——Filter,利用该属性,可选筛选出我们需要的文件.   因此,我 ...

  3. CentOS安装gcc clang git mysql等软件高版本福利

    最近同事需要在单位提供的开发机上临时安装gcc等软件,时间紧迫,因此向其推荐安装福利devtoolset. 感谢devtoolset,使得CentOS软件安装无比的快捷,卸载也是无与伦比的简单. gc ...

  4. tensorflow、cuda、cudnn之间的版本对应关系

    原文链接 tensorflow-gpu v1.9.0 | cuda9.0 |  cuDNN7.1.4可行  | 备注:7.0.4/ 7.0.5/ 7.1.2不明确 tensorflow-gpu v1. ...

  5. 解决SpringMVC中文乱码问题--这是前端传参数到服务器

    SpringMvc参数传递中乱码问题   问题描述: 当传递中文参数到controller类时,无乱是get方式还是post方式都出现乱码 解决: 1.保证所有的页面编码都是utf-8,包括jsp页面 ...

  6. BBS论坛(十九)

    19.1.cms轮播图管理页面布局 (1)cms/cms_base.html <li class="nav-group banner-manage"><a hre ...

  7. 网络协议 2 - IP 是怎么来,又是怎么没的?

    了解完网络协议,我们会发现,网络通信的五层模型里,有两个很重要的概念:IP 地址和 MAC 地址. 那么 IP 地址是怎么来的,又是怎么没的?MAC 地址与 IP 地址又有什么区别? 这回答上面问题前 ...

  8. MassTransit&Sagas分布式服务开发ppt分享

    saga,与分布式相关,最早被定义在Hector Garcia-Molina和Kenneth Salem的论文"Sagas"中.这篇论文提出了一个saga机制来作为分布式事务的替代 ...

  9. 【干货】Chrome插件(扩展)开发全攻略

    写在前面 我花了将近一个多月的时间断断续续写下这篇博文,并精心写下完整demo,写博客的辛苦大家懂的,所以转载务必保留出处.本文所有涉及到的大部分代码均在这个demo里面:https://github ...

  10. 初探Java设计模式4:JDK中的设计模式

    JDK中设计模式 本文主要是归纳了JDK中所包含的设计模式,包括作用和其设计类图.首先来个总结,具体的某个模式可以一个一个慢慢写,希望能对研究JDK和设计模式有所帮助.一.设计模式是什么(1)反复出现 ...