今天给大家讲解一下,如何实现美颜相机中的高级柔焦效果,首先先看下美颜相机中这个功能的效果图:

图1 原图(图片来自网络,如有侵权敬请告知)

图2 美颜相机高级柔焦模版

图3 马赛克效果

图4,动感模糊效果

以上图3和4是两种柔焦的效果,很不错,今天我将用C来实现这个算法。

这个算法的流程如下:

1,前景抠图(自动抠图或者手动抠图)

美颜相机使用的是先手动涂抹出前景目标区域,然后使用自动抠图将该区域准确抠图;

实际上,目前有很多基于深度学习的抠图算法,效果相当不错,比如最近比较火的实时视频抠图技术等等。这里,本人还是给出一些方法的汇总如下:

《Interactive graph cuts for optimal boundary and region segmentation of objects in N-D images》

《Shared Sampling for Real-Time Alpha Matting》

《A Closed Form Solution to Natural Image Matting》

《A Bayesian Approach to Digital Matting》

《Learning Based Alpha Matting using Support Vector Regression》

《Natural Image Matting using Deep Convolutional Neural Networks》

《Deep Image Matting》

本文主要介绍方法,这里给出白百合测试图前景抠图的效果:

图5 白百合前景MASK

2,背景特效

大家可以看到图3和图4的效果区别,主要是背景的区别,一个是马赛克,一个是放射模糊;

因此,我们需要对背景图片进行相应的马赛克和放射模糊处理,本人效果图如下:

图6 马赛克效果

图7 放射模糊效果

这里可以参考本人博客里的各种滤镜特效,实际上都可以用来做背景处理,进而得出各种不同的效果;

3,图像融合

有了前景背景之后,我们可以根据前景的MASK(区域的二值MASK),对前景和背景进行alpha融合,公式如下:

Output = F*Mask+(255-Mask)*B

其中F表示前景,B表示背景,其中MASK中白色表示前景,黑色表示背景;

最后本人的效果图如下:

图8 马赛克柔焦效果图

图9 放射模糊柔焦效果图

以上三点就是柔焦效果的具体算法实现过程,最后,给出代码逻辑(我这里实现了四个柔焦的效果):

int f_Focus(unsigned char* srcData, int width, int height, int stride, unsigned char* mask, int intensity, int mode)
{//background effectsint ret = 0;int i, j;unsigned char* gaussData = (unsigned char*)malloc(sizeof(unsigned char) * stride * height);int radius = intensity * 20 / 100;switch(mode){case  0://gauss blur effectret = f_TFastestGaussFilter(srcData, width, height, stride, gaussData, radius);break;case 1://moscia effectmemcpy(gaussData, srcData, sizeof(unsigned char) * stride * height);ret = f_TMosaic(gaussData, width, height, stride, intensity / 2);break;case 2://diffusion effectmemcpy(gaussData, srcData, sizeof(unsigned char) * stride * height);ret = f_TDiffusion(gaussData, width, height, stride, intensity / 2);break;case 3://zoom blur effectmemcpy(gaussData, srcData, sizeof(unsigned char) * stride * height);ret = f_TZoomBlur(gaussData, width, height, stride, width / 2, height / 2, 10, intensity);break;default:break;} //alpha blendunsigned char* pMask = mask;unsigned char* pSrc = srcData;unsigned char* pGauss = gaussData;int k, nk;for(j = 0; j < height; j++){for(i = 0; i < width; i++){k = pMask[0];nk = 255 - k;pSrc[0] = CLIP3((pSrc[0] * k + pGauss[0] * nk) >> 8, 0, 255);pSrc[1] = CLIP3((pSrc[1] * k + pGauss[1] * nk) >> 8, 0, 255);pSrc[2] = CLIP3((pSrc[2] * k + pGauss[2] * nk) >> 8, 0, 255);pSrc += 4;pGauss += 4;pMask += 4;}}free(gaussData);return ret;
};
int f_Test(unsigned char *srcData, int width, int height, int stride, unsigned char* mask, int intensity, int mode)
{int ret = 0;//Processret = f_Focus(srcData, width, height, stride, mask, intensity, mode);return ret;
};

这里本人给出自己的DEMO,这个DEMO中包含了四种效果(高斯模糊柔焦特效,马赛克柔焦特效,扩散模糊柔焦特效和放射模糊柔焦特效),下载地址:点击打开链接

本人QQ1358009172,欢迎交流学习!

图像滤镜艺术---美颜相机之高级柔焦效果实现相关推荐

  1. 图像滤镜艺术---微软自拍APP滤镜实现合集DEMO

    原文:图像滤镜艺术---微软自拍APP滤镜实现合集DEMO 微软最近推出了自家的美颜app,大家有兴趣可以在苹果商店中下载一下看一看,今天,我们要说的便是这款app中的所有滤镜实现问题. 这款app中 ...

  2. 图像滤镜艺术---(Lightleaks Filter)漏光滤镜

    原文:图像滤镜艺术---(Lightleaks Filter)漏光滤镜 (Lightleaks Filter)漏光滤镜 漏光拍摄其实就是一种摄影手法,最初是因为强烈光照导致相片交卷的过分曝光,最终在成 ...

  3. 图像滤镜艺术---(Nostalgla Filter)老照片滤镜

    原文:图像滤镜艺术---(Nostalgla Filter)老照片滤镜 (Nostalgla Filter)老照片滤镜 Nostalgla Filter主要是通过算法来模拟一种复古,陈旧的照片风格,以 ...

  4. 图像滤镜艺术---图像滤镜晕影调节算法研究

    原文:图像滤镜艺术---图像滤镜晕影调节算法研究 本文对滤镜中常见的晕影,晕角效果的实现做了研究,具体如下: 1 晕影调整算法 所谓晕影就是给图像四个角添加暗影效果,这暗影向图像中心逐渐淡化.我们使用 ...

  5. 图像滤镜艺术---PS图层混合模式之明度模式

    图像滤镜艺术---PS图层混合模式之明度模式 本文将介绍PS图层混合模式中比较复杂 的"明度"模式的算法原理及代码实现内容. 说到PS的图层混合模式,计算公式都有,具体代码实现也能 ...

  6. 图像滤镜艺术--编码基础(Photoshop基础变换的代码实现)

    原文:图像滤镜艺术--编码基础(Photoshop基础变换的代码实现) 自从上一篇博客写完之后,到现在已经有段时间了,这段时间不是不想接着写,只是想做的更好了在写出来给大家看呵呵. 今天,我将给大家介 ...

  7. 图像滤镜艺术---(Instagram)1977滤镜

    原文:图像滤镜艺术---(Instagram)1977滤镜 图像特效---(Instagram)1977滤镜 本文介绍1977这个滤镜的具体实现,这个滤镜最早是Instagram中使用的 ,由于Ins ...

  8. 图像滤镜艺术---Wave滤镜

    图像滤镜艺术---Wave滤镜 原文:图像滤镜艺术---Wave滤镜 Wave Filter水波滤镜 水波滤镜是通过坐标变换来模拟水波效果,使图像呈现出水波的特效.这个滤镜有一个可调参数:水波的扭曲程 ...

  9. 图像滤镜艺术---霓虹、浮雕、木刻滤镜

    图像滤镜艺术---霓虹.浮雕.木刻滤镜 原文:图像滤镜艺术---霓虹.浮雕.木刻滤镜 图像特效往往可以将普通的照片呈现出一种令人耳目一新的效果,特效的种类繁多,比如各种流行的 滤镜特效等等,今天,我们 ...

  10. 图像滤镜艺术---(Punch Filter)交叉冲印滤镜

    原文: 图像滤镜艺术---(Punch Filter)交叉冲印滤镜 (Punch Filter)交叉冲印滤镜 本文介绍一种交叉冲印效果的代码实现,至于原理,不在累赘,直接看代码: int f_TPun ...

最新文章

  1. Wireshark数据包分析之DHCP协议包解读
  2. TCP服务器和客户端的链接例子(侧重点在注意关闭套接子,减少套接子的描述子)
  3. pyx文件 生成pyd 文件用于 cython调用
  4. python打完代码怎么运行-Python的代码是如何去进行运行的?
  5. WPF 文本呈现(2)
  6. java 目录的遍历与删除
  7. python数据抓取课程_Python爬虫入门教程 21-100 网易云课堂课程数据抓取
  8. 解决VS'scanf':this function or variable may be unsafe.`(VS安全函数问题)
  9. BOM函数之history对象
  10. 灯泡亮度控制单片机_海淀区投影机灯泡
  11. 【设计模式】第五章 责任链模式
  12. mysql中时间处理函数_基于mysql时间处理函数的应用详解
  13. vue 组件创建与销毁
  14. 免费中文版Adobe Acrobat Reader DC PDF文件阅读软件
  15. 提高网站速度,分析工具page speed中文教程
  16. RobotStudio的基本布局方法,模型加载,工件坐标系的创建,手动操作机器人示教,以及模拟仿真机器人运动轨迹。
  17. 如何做好性能压测:压测环境的设计和搭建
  18. 都没滤网质量重要 细数净化器鸡肋功能
  19. C语言中用单引号括起多个字符的问题
  20. 调用marathon rest API

热门文章

  1. Python获取屏幕坐标,自动发送信息
  2. 20190408-相速度和群速度、傅里叶变换与波动方程的色散关系、介电常数与电导、介电函数与折射率、散度定理、电子迁移率、电磁波波动方程、自由电子气的介电函数
  3. 朗强科技讲解:HDMI分配器的作用与使用方法
  4. 联通屏蔽80端口后利用NAT端口映射穿透解决WEB网站应用发布
  5. 计算机切换用户屏幕闪,小编教您Win10切换用户后闪屏的具体办法
  6. Windows10系统 无法更换锁屏图片一直转圈圈(含替换系统默认锁屏壁纸教程)异常处理
  7. android10禁用华为桌面,华为禁用第三方桌面 简介办法
  8. wd移动硬盘不能识别_wd移动硬盘读不出来怎么办
  9. php保存pdf旋转90度,怎么把pdf旋转90度 多个pdf文件页面旋转的方法|支持选择要旋转的页面及旋转角度...
  10. iface eth0 inet dhcp