图像滤镜艺术---旋转模糊滤镜
来源:互联网 发布:淘宝介入买家怎么赢 编辑:程序博客网 时间:2024/05/18 02:09
本文介绍一种旋转模糊滤镜的实现算法。
旋转模糊主要特点是:整张图像围绕一个中心点做旋转变换,同时有个控制旋转程度的变量和一个控制模糊程度的变量,来完成这个效果。图像中距离中心点越近,旋转和模糊的程度都越小,反之,越大。
假设中心点O坐标为(cenX,cenY),当前点位置为P(x,y):
1,PO距离Dis=Math.Sqrt((y - cenY) * (y - cenY) + (x - cenX) * (x - cenX));
2,PO和水平方向夹角angle=Math.Atan2((double)(y - cenY), (double)(x - cenX));
3,当前点P对应的旋转后新的坐标newX,newY计算:
newX = Dis * Math.Cos(angle) + cenX;
newY = Dis * Math.Sin(angle) + cenY;
下面给出完整的C#代码:
/// <summary>
/// Rotate Blur
/// </summary>
/// <param name="src">Source image.</param>
/// <param name="cenX">The X position of Blur.</param>
/// <param name="cenY">The Y position of Blur.</param>
/// <param name="intensity">The intensity of blur,0-100.</param>
/// <returns>The result image.</returns>
private Bitmap RotateBlurProcess(Bitmap srcBitmap, int cenX, int cenY, int intensity)
{
Bitmap a = new Bitmap(srcBitmap);
int w = a.Width;
int h = a.Height;
cenX = Math.Min(w - 1, Math.Max(0, cenX));
cenY = Math.Min(h - 1, Math.Max(0, cenY));
Bitmap dst = new Bitmap(w, h);
System.Drawing.Imaging.BitmapData srcData = a.LockBits(new Rectangle(0, 0, w, h), System.Drawing.Imaging.ImageLockMode.ReadWrite, System.Drawing.Imaging.PixelFormat.Format32bppArgb);
System.Drawing.Imaging.BitmapData dstData = dst.LockBits(new Rectangle(0, 0, w, h), System.Drawing.Imaging.ImageLockMode.ReadWrite, System.Drawing.Imaging.PixelFormat.Format32bppArgb);
unsafe
{
byte* pIn = (byte*)srcData.Scan0.ToPointer();
byte* pOut = (byte*)dstData.Scan0.ToPointer();
byte* p = null;
int stride = srcData.Stride - w * 4;
int newX = 0, newY = 0;
double angle = 0;
double temp = 0, r = 0, g = 0, b = 0;
for (int y = 0; y < h; y++)
{
for (int x = 0; x < w; x++)
{
r = 0;
g = 0;
b = 0;
temp = Math.Sqrt((y - cenY) * (y - cenY) + (x - cenX) * (x - cenX));
angle = Math.Atan2((double)(y - cenY), (double)(x - cenX));
for (int n = 0; n < intensity; n++)
{
angle = angle + 0.005;
newX = (int)(temp * Math.Cos(angle) + (double)cenX);
newY = (int)(temp * Math.Sin(angle) + (double)cenY);
newX = Math.Min(w - 1, Math.Max(0, newX));
newY = Math.Min(h - 1, Math.Max(0, newY));
p = pIn + newY * srcData.Stride + newX * 4;
b = b + p[0];
g = g + p[1];
r = r + p[2];
}
b = Math.Min(255, Math.Max(0, b / intensity));
g = Math.Min(255, Math.Max(0, g / intensity));
r = Math.Min(255, Math.Max(0, r / intensity));
pOut[0] = (byte)b;
pOut[1] = (byte)g;
pOut[2] = (byte)r;
pOut[3] = (byte)255;
pOut += 4;
}
pOut += stride;
}
a.UnlockBits(srcData);
dst.UnlockBits(dstData);
}
return dst;
}
最后,看下效果图:
原图
效果图
给出一个完整DEMO程序的下载地址:http://www.zealpixel.com/forum.php?mod=viewthread&tid=148&extra=page%3D1 跟大家分享一下!
0 0
- 图像滤镜艺术---旋转模糊滤镜
- 图像特效---旋转模糊滤镜
- 图像滤镜艺术--PS平均(滤镜-模糊-平均)效果
- 图像滤镜艺术----Brannan滤镜
- 图像滤镜艺术--Toaster滤镜
- 图像滤镜艺术--暴雨滤镜
- 图像滤镜艺术--大雪滤镜
- 图像滤镜艺术---连环画滤镜
- 图像滤镜艺术---漫画滤镜
- 图像滤镜艺术---水彩画滤镜
- 图像滤镜艺术---Swirl滤镜
- 图像滤镜艺术---Wave滤镜
- 图像滤镜艺术----Brannan滤镜
- 图像滤镜艺术--序言
- 图像滤镜艺术---图像光照效果滤镜
- 图像滤镜艺术---Hudson滤镜(Instagram)
- 图像滤镜艺术--大雾效果滤镜
- 图像滤镜艺术---暗调滤镜
- Android源码编译整理总结
- 四层和七层负载均衡的区别
- 分布式服务框架 Zookeeper -- 管理分布式环境中的数据
- java判断操作系统
- postgreSQL数据库limit分页、排序
- 图像滤镜艺术---旋转模糊滤镜
- svn导出历史版本
- [LeetCode-190] Reverse Bits(反转位)
- Mantis运行环境的安装以及邮件相关配置
- 【springmvc+mybatis项目实战】杰信商贸-14.购销合同添加+修改+删除+查看
- 麻将432牌型听牌判断流程图
- Druid数据库连接池使用
- 解决spark运行时Java heap space问题
- 增量实现