OpenCV-PS羽化操作

简介: OpenCV-PS羽化操作

功能函数

// 羽化
cv::Mat Eclosion(cv::Mat src, cv::Point center,float level)
{
  if (level>0.9)
    level = 0.9f;
  float diff = (1-level) * (src.rows / 2 * src.rows / 2 + src.cols / 2 * src.cols / 2);
  cv::Mat result = src.clone();
  for (int i = 0; i < result.rows; ++i)
  {
    for (int j = 0; j < result.cols; ++j)
    {
      float dx = float(center.x - j);
      float dy = float(center.y - i);
      float ra = dx * dx + dy * dy;
      float m = ((ra-diff) / diff * 255)>0? ((ra - diff) / diff * 255):0;
      int b = result.at<Vec3b>(i, j)[0];
      int g = result.at<Vec3b>(i, j)[1];
      int r = result.at<Vec3b>(i, j)[2];
      b = (int)(b+ m);
      g = (int)(g + m);
      r = (int)(r + m);
      result.at<Vec3b>(i, j)[0] = (b > 255 ? 255 : (b < 0 ? 0 : b));
      result.at<Vec3b>(i, j)[1] = (g > 255 ? 255 : (g < 0 ? 0 : g));
      result.at<Vec3b>(i, j)[2] = (r > 255 ? 255 : (r < 0 ? 0 : r));
    }
  }
  return result;
}

测试代码

#include <iostream>
#include <opencv2/opencv.hpp>
using namespace std;
using namespace cv;
cv::Mat Eclosion(cv::Mat src, cv::Point center, float level);
int main()
{
  cv::Mat src = imread("test.jpg");
  /***********       羽化   ***********************/
  cv::Mat eclosion1 = Eclosion(src, cv::Point(src.cols / 2, src.rows / 2), 0.5f);
  cv::Mat eclosion2 = Eclosion(src, cv::Point(src.cols / 2, src.rows / 2), 0.3f);
  imshow("原图", src);
    imshow("羽化1", eclosion1);
  imshow("羽化2", eclosion2);
  waitKey(0);
  return 0;
}
// 羽化
cv::Mat Eclosion(cv::Mat src, cv::Point center,float level)
{
  if (level>0.9)
    level = 0.9f;
  float diff = (1-level) * (src.rows / 2 * src.rows / 2 + src.cols / 2 * src.cols / 2);
  cv::Mat result = src.clone();
  for (int i = 0; i < result.rows; ++i)
  {
    for (int j = 0; j < result.cols; ++j)
    {
      float dx = float(center.x - j);
      float dy = float(center.y - i);
      float ra = dx * dx + dy * dy;
      float m = ((ra-diff) / diff * 255)>0? ((ra - diff) / diff * 255):0;
      int b = result.at<Vec3b>(i, j)[0];
      int g = result.at<Vec3b>(i, j)[1];
      int r = result.at<Vec3b>(i, j)[2];
      b = (int)(b+ m);
      g = (int)(g + m);
      r = (int)(r + m);
      result.at<Vec3b>(i, j)[0] = (b > 255 ? 255 : (b < 0 ? 0 : b));
      result.at<Vec3b>(i, j)[1] = (g > 255 ? 255 : (g < 0 ? 0 : g));
      result.at<Vec3b>(i, j)[2] = (r > 255 ? 255 : (r < 0 ? 0 : r));
    }
  }
  return result;
}

测试效果

      本文提供的PS羽化操作函数,可以实现类似PS中羽化的效果,即目标区域中心区不变,边缘区模糊化,center参数是羽化中心,level是羽化强度,该值越大则羽化程度越大,使整张图被羽化的区域变大~

相关文章
|
机器学习/深度学习 自然语言处理 开发工具
ModelScope--人像卡通化、人像美肤
利用ModelScope实现美拍人喜欢的人像处理卡通化、人像美肤
ModelScope--人像卡通化、人像美肤
|
并行计算 开发工具 git
NPU上运行onnxruntime
在Ascend环境下使用onnxruntime推理时,若安装了GPU版本的onnxruntime(`onnxruntime-gpu`),可能会因缺少CUDA组件报错。正确做法是卸载`onnxruntime-gpu`,并根据官方文档适配NPU,通过源码构建支持CANN的onnxruntime whl包。具体步骤为克隆onnxruntime源码,使用`--use_cann`参数构建,并安装生成的whl包。最后,配置CANNExecutionProvider进行推理。
2029 10
|
编解码 并行计算 物联网
4G显存部署Flux,2分钟Wan2.1-14B视频生成,DiffSynth-Engine引擎开源!
魔搭社区的开源项目 DiffSynth-Studio 自推出以来,凭借其前沿的技术探索和卓越的创新能力,持续受到开源社区的高度关注与广泛好评。截至目前,该项目已在 GitHub 上斩获超过 8,000 颗星,成为备受瞩目的开源项目之一。作为以技术探索为核心理念的实践平台,DiffSynth-Studio 基于扩散模型(Diffusion Model),在图像生成和视频生成领域孵化出了一系列富有创意且实用的技术成果,其中包括 ExVideo、ArtAug、EliGen 等代表性模块。
2033 3
|
自然语言处理 iOS开发
如何破解mac欧路词典,仅限个人使用,商用还请付费
这款软件非常好用,去官网看到才发现是个人开发项目, 在知乎、论坛、微信公众号、小红书等发表欧路词典的介绍文章或使用心得 就有机会获赠免费注册码一个,很容易获得,大家也可以去官网底部看下要求,商用的话还是建议购买付费版本
如何破解mac欧路词典,仅限个人使用,商用还请付费
|
存储 物联网 数据安全/隐私保护
如何让AppleWatch自动锁定Mac?
我们都知道AppleWatch支持了解锁Mac的功能,如果您的 Mac(2013 年中或后续机型)安装了macOS Sierra(Apple Watch Series 1 和 Apple Watch Series 2)、macOS High Sierra 或更高版本(Apple Watch Series 3 或后续机型),那么当其从睡眠模式唤醒时,Apple Watch 会立即解锁您的 Mac。
2029 1
如何让AppleWatch自动锁定Mac?
|
消息中间件 负载均衡 Kafka
Kafka - 3.x 分区分配策略及再平衡不完全指北
Kafka - 3.x 分区分配策略及再平衡不完全指北
902 0
|
XML 存储 Java
Android 开发音频录播中媒体录制器MediaRecorder和媒体播放器MediaPlayer的讲解及实战(超详细 附源码)
Android 开发音频录播中媒体录制器MediaRecorder和媒体播放器MediaPlayer的讲解及实战(超详细 附源码)
431 0
|
机器学习/深度学习 存储 人工智能
模型推理加速系列 | 03:Pytorch模型量化实践并以ResNet18模型量化为例(附代码)
本文主要简要介绍Pytorch模型量化相关,并以ResNet18模型为例进行量化实践。
|
Python
pip安装第三方库报错WARNING: Retrying (Retry(total=4,connect=None, read=Noneredirect=None,status=None))解决
pip安装第三方库报错WARNING: Retrying (Retry(total=4,connect=None, read=Noneredirect=None,status=None))解决
3887 0
pip安装第三方库报错WARNING: Retrying (Retry(total=4,connect=None, read=Noneredirect=None,status=None))解决
|
开发框架 SpringCloudAlibaba Java
Spring注解装配:@Autowired和@Resource使用及原理详解
`@Resource`和`@Autowired`都是实现bean的注入,在日常开发中使用非常频繁,但是使用体验不太一样,笔者喜欢用`@Resource`,因为在使用`@Autowired`时IDEA会出现一些警告爆红提示
739 0
Spring注解装配:@Autowired和@Resource使用及原理详解