图像处理之边缘褪化效果
很多图像处理软件都提供边缘褪化效果滤镜,其实原理非常的简单,网上搜索了一把,
实现了基于Java的图像边缘褪化效果。边缘褪化效果取决于以下三个参数:
1.设定的图像边缘宽度
2.褪化比率– 其实质是图像融合的百分比数
3.选择的边框颜色
主要原理是计算图像中的像素点到中心点的距离,对边缘像素根据褪化比率与选择的
边框颜色融合从而产生褪化效果。程序效果如下:
原图:
处理以后图像:
滤镜的完全源代码如下:
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;
}
}
转载请务必注明出自本博客
分享到:
相关推荐
数字图像处理边缘检测 数字图像处理边缘检测 数字图像处理边缘检测
图像处理边缘检测
图像处理——边缘检测算法 ,含有Matlab程序和边缘检测的文档
边缘检测是图像处理的一个重要环节,边缘检测效果的好坏直接决定图像处理结果的好坏,但对于边缘检测结果缺乏一个标准的数值化的评价方式,因此提出了一种对边缘检测结果的边缘连续性量化评价方法。以边缘的连续性...
该源码为MATLAB图像处理GUI的源代码,包含图像灰度转化,二值化、边缘检测、以及图像增强、直方图均衡化等功能。
数字图像处理matlab实验中的一个,形态学方法实现边缘检测
2.1边缘检测的方法 2.1.1检测梯度的最大值 2.1.2检测二阶导数的零交叉点 2.1.3统计型方法 2.1.4小波多尺度边缘检测 2.2边缘检测算子 2.2.1 Roberts算子 2.2.2 Prewitt算子和Sobel算子 2.2.3 Kirsch算子 ...
基于vc的图像处理的代码,可以进行图像的灰度化,二值化,边缘检测、提取等功能
数字图像处理 锐化及边缘检测 VC++6.0环境
1.C#写的边缘检测算法 2.VS2011版本 3.纯粹的图像算法边缘检测 4.经典案例C#图像处理边缘检测
canny 边缘检测很好用的,MFC程序完整,清晰。还有一些基本的图像处理的预处理功能。
数字图像处理实验matlab图像增强边缘检测图像操作.pdf
opencv图像处理 opencv图像处理_opencv图像处理算法之边缘检测
CC#图像处理边缘检测代码 C#图像处理边缘检测代码 C#图像处理边缘检测代码 C#图像处理边缘检测代码 #图像处理边缘检测代码
根据图像的边缘可以检测出来,可以调整边缘像素的宽度,达到线性化
"边缘检测和角点标记的图像处理与可视化" 是一项基于Python语言的图像处理工作,旨在通过应用边缘检测算法和角点检测算法来提取图像中的边缘特征和角点特征,并通过可视化技术将这些特征呈现出来。通过使用Python的...
数字图像处理作业canny边缘检测坎尼边缘检测MATLAB源码及实验报告
图像处理-边缘滤波,用matlab实现的简单图像处理代码,可随意用灰度图像进行试验,放于同一文件夹内