【ios开发 -- 图片处理 -- 抠图】

在大多图像处理中,我们会应用到高斯模糊处理图像,通常用它来减少图像噪声以及降低细节层次。在此文中介绍了高斯模糊的实现和可选区域的模糊【美图秀秀-背景虚化】

高斯模糊的原理中,它是根据高斯曲线调节像素色值,它是有选择地模糊图像。说得直白一点,就是高斯模糊能够把某一点周围的像素色值按高斯曲线统计起来,采用数学上加权平均的计算方法得到这条曲线的色值,最后能够留下人物的轮廓,即曲线.是指当 Adobe Photoshop 将加权平均应用于像素时生成的钟形曲线。在PS中间,你应该知道所有的颜色不过都是数字,各种模糊不过都是算法。把要模糊的像素色值统计,用数学上加权平均的计算方法(高斯函数)得到色值,对范围、半径等进行模糊,大致就是高斯模糊。

高斯模糊算法公式[使用正态分布]

二维图形表示形式

OpenGL ES 算法实现

1.0 / sqrt(2.0 * M_PI * pow(sigma, 2.0))) * exp(-pow(currentGaussianWeightIndex, 2.0) / (2.0 * pow(sigma, 2.0))

附:GLSL内置指数函数说明图

在GPUImage中我们可以使用GPUImageGaussianBlurFilter来实现高斯模糊。(GPUImageGaussianBlurFilter仅可以全图模糊,而不能部分模糊)

texelSpacingMultiplier是模糊的强度,数值越大,模糊效果越明显

blurRadiusInPixels是像素范围,用于计算平均值。

高斯模糊应用

1+ (UIImage *)applyGaussianBlur:(UIImage *)image 2{ 3GPUImageGaussianBlurFilter *filter = [[GPUImageGaussianBlurFilter alloc] init]; 4// filter.texelSpacingMultiplier = 5.0; 5filter.blurRadiusInPixels =1.0; 6 [filter forceProcessingAtSize:image.size]; 7GPUImagePicture *pic = [[GPUImagePicture alloc] initWithImage:image]; 8 [pic addTarget:filter]; 9 [pic processImage];10 [filter useNextFrameForImageCapture];11return [filter imageFromCurrentFramebuffer];12}

GPUImageGaussianSelectiveBlurFilter可以部分模糊,也就是选区外模糊

excludeCircleRadius用来调整模糊区域

  • (UIImage *)applyGaussianSelectiveBlur:(UIImage *)image

{

GPUImageGaussianSelectiveBlurFilter *filter = [[GPUImageGaussianSelectiveBlurFilter alloc] init];

//    filter.texelSpacingMultiplier = 5.0;

filter.excludeCircleRadius = 120 / 320.0;

[filter forceProcessingAtSize:image.size];

GPUImagePicture *pic = [[GPUImagePicture alloc] initWithImage:image];

[pic addTarget:filter];

[pic processImage];

[filter useNextFrameForImageCapture];

return [filter imageFromCurrentFramebuffer];

}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值