图像处理之边缘褪化效果

简介: 图像处理之边缘褪化效果

图像处理之边缘褪化效果



很多图像处理软件都提供边缘褪化效果滤镜,其实原理非常的简单,网上搜索了一把,


实现了基于Java的图像边缘褪化效果。边缘褪化效果取决于以下三个参数:


1.      设定的图像边缘宽度


2.      褪化比率– 其实质是图像融合的百分比数


3.      选择的边框颜色



主要原理是计算图像中的像素点到中心点的距离,对边缘像素根据褪化比率与选择的


边框颜色融合从而产生褪化效果。程序效果如下:


原图:

1333458966_1480.jpg


处理以后图像:

1333459016_4173.png


滤镜的完全源代码如下:

package com.process.blur.study;
 
import java.awt.Color;
import java.awt.image.BufferedImage;
 
/**
 * @author gloomy fish
 * Vignette - a photograph whose edges shade off gradually
 * 
 */
public class VignetteFilter extends AbstractBufferedImageOp {
    
  private int vignetteWidth;
  private int fade;
  private Color vignetteColor;
  
  public VignetteFilter() {
    vignetteWidth = 50;
    fade = 35;
    vignetteColor = Color.BLACK;
  }
  
  @Override
  public BufferedImage filter(BufferedImage src, BufferedImage dest) {
    int width = src.getWidth();
        int height = src.getHeight();
 
        if ( dest == null )
          dest = createCompatibleDestImage( src, null );
 
        int[] inPixels = new int[width*height];
        int[] outPixels = new int[width*height];
        getRGB( src, 0, 0, width, height, inPixels );
        int index = 0;
        for(int row=0; row<height; row++) {
          int ta = 0, tr = 0, tg = 0, tb = 0;
          for(int col=0; col<width; col++) {
              
                int dX = Math.min(col, width - col);
                int dY = Math.min(row, height - row);
                index = row * width + col;
            ta = (inPixels[index] >> 24) & 0xff;
                tr = (inPixels[index] >> 16) & 0xff;
                tg = (inPixels[index] >> 8) & 0xff;
                tb = inPixels[index] & 0xff;
                if ((dY <= vignetteWidth) & (dX <= vignetteWidth))
                {
                    double k = 1 - (double)(Math.min(dY, dX) - vignetteWidth + fade) / (double)fade;
                    outPixels[index] = superpositionColor(ta, tr, tg, tb, k);
                    continue;
                }
 
                if ((dX < (vignetteWidth - fade)) | (dY < (vignetteWidth - fade)))
                {
                  outPixels[index] = (ta << 24) | (vignetteColor.getRed() << 16) | (vignetteColor.getGreen() << 8) | vignetteColor.getBlue();
                }
                else
                {
                    if ((dX < vignetteWidth)&(dY>vignetteWidth))
                    {
                        double k = 1 - (double)(dX - vignetteWidth + fade) / (double)fade;
                        outPixels[index] = superpositionColor(ta, tr, tg, tb, k);
                    }
                    else
                    {
                        if ((dY < vignetteWidth)&(dX > vignetteWidth))
                        {
                            double k = 1 - (double)(dY - vignetteWidth + fade) / (double)fade;
                            outPixels[index] = superpositionColor(ta, tr, tg, tb, k);
                        }
                        else
                        {
                          outPixels[index] = (ta << 24) | (tr << 16) | (tg << 8) | tb;
                        }
                    }
                }
            }
        }
        
        setRGB( dest, 0, 0, width, height, outPixels );
        return dest;
  }
  
  public int superpositionColor(int ta, int red, int green, int blue, double k) {
    red = (int)(vignetteColor.getRed() * k + red *(1.0-k));
    green = (int)(vignetteColor.getGreen() * k + green *(1.0-k));
    blue = (int)(vignetteColor.getBlue() * k + blue *(1.0-k));
    int color = (ta << 24) | (clamp(red) << 16) | (clamp(green) << 8) | clamp(blue);
    return color;
  }
  
  public int clamp(int value) {
    return value > 255 ? 255 :((value < 0) ? 0 : value);
  }
  
  public int getVignetteWidth() {
    return vignetteWidth;
  }
 
  public void setVignetteWidth(int vignetteWidth) {
    this.vignetteWidth = vignetteWidth;
  }
 
  public int getFade() {
    return fade;
  }
 
  public void setFade(int fade) {
    this.fade = fade;
  }
  
  public Color getVignetteColor() {
    return vignetteColor;
  }
 
  public void setVignetteColor(Color vignetteColor) {
    this.vignetteColor = vignetteColor;
  }
  
}


转载请务必注明出自本博客

相关文章
|
7天前
|
存储 弹性计算 人工智能
【2025云栖精华内容】 打造持续领先,全球覆盖的澎湃算力底座——通用计算产品发布与行业实践专场回顾
2025年9月24日,阿里云弹性计算团队多位产品、技术专家及服务器团队技术专家共同在【2025云栖大会】现场带来了《通用计算产品发布与行业实践》的专场论坛,本论坛聚焦弹性计算多款通用算力产品发布。同时,ECS云服务器安全能力、资源售卖模式、计算AI助手等用户体验关键环节也宣布升级,让用云更简单、更智能。海尔三翼鸟云服务负责人刘建锋先生作为特邀嘉宾,莅临现场分享了关于阿里云ECS g9i推动AIoT平台的场景落地实践。
【2025云栖精华内容】 打造持续领先,全球覆盖的澎湃算力底座——通用计算产品发布与行业实践专场回顾
|
1天前
|
弹性计算 人工智能 安全
云上十五年——「弹性计算十五周年」系列客户故事(第二期)
阿里云弹性计算十五年深耕,以第九代ECS g9i实例引领算力革新。携手海尔三翼鸟、小鹏汽车、微帧科技等企业,实现性能跃升与成本优化,赋能AI、物联网、智能驾驶等前沿场景,共绘云端增长新图景。
|
6天前
|
人工智能 自然语言处理 自动驾驶
关于举办首届全国大学生“启真问智”人工智能模型&智能体大赛决赛的通知
关于举办首届全国大学生“启真问智”人工智能模型&智能体大赛决赛的通知
|
5天前
|
云安全 人工智能 自然语言处理
阿里云x硅基流动:AI安全护栏助力构建可信模型生态
阿里云AI安全护栏:大模型的“智能过滤系统”。
|
Linux 虚拟化 iOS开发
VMware Workstation Pro 25H2 for Windows & Linux - 领先的免费桌面虚拟化软件
VMware Workstation Pro 25H2 for Windows & Linux - 领先的免费桌面虚拟化软件
1096 4
|
9天前
|
存储 机器学习/深度学习 人工智能
大模型微调技术:LoRA原理与实践
本文深入解析大语言模型微调中的关键技术——低秩自适应(LoRA)。通过分析全参数微调的计算瓶颈,详细阐述LoRA的数学原理、实现机制和优势特点。文章包含完整的PyTorch实现代码、性能对比实验以及实际应用场景,为开发者提供高效微调大模型的实践指南。
697 2
|
6天前
|
编解码 自然语言处理 文字识别
Qwen3-VL再添丁!4B/8B Dense模型开源,更轻量,仍强大
凌晨,Qwen3-VL系列再添新成员——Dense架构的Qwen3-VL-8B、Qwen3-VL-4B 模型,本地部署友好,并完整保留了Qwen3-VL的全部表现,评测指标表现优秀。
535 7
Qwen3-VL再添丁!4B/8B Dense模型开源,更轻量,仍强大
|
5天前
|
人工智能 缓存 算法
阿里云AI基础设施成果入选顶级学术会议,显著提升GPU利用率
阿里云提出的GPU池化服务多模型研究成果入选SOSP2025,其创新系统Aegaeon实现token级调度,大幅提升GPU利用率,核心技术已落地百炼平台,显著降低资源消耗。
513 2