Atitit Atitit 图像处理之  Oilpaint油画滤镜 水彩画 源码实现

Posted attilaxAti

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Atitit Atitit 图像处理之  Oilpaint油画滤镜 水彩画 源码实现相关的知识,希望对你有一定的参考价值。

 

 

 

Atitit Atitit 图像处理之  Oilpaint油画滤镜 水彩画 源码实现

 

1.1. 具体原理参考1

2. 水彩画滤镜算法如下:1

2.1. 这个其实就是灰度层次降低维度的过程。2

2.2. 模板半径Radius用来调节水彩画的水彩程度。即是颜色的降低维度的过程2

 

 

1.1. 具体原理参考

Atitit 图像处理之仿油画效果 Oilpaint油画滤镜 水彩画 漫画滤镜 v2

 

2. 水彩画滤镜算法如下:

灰度,离散化(聚类)。。

灰度层次N就是水彩画最多使用的颜色明暗层次,一般7种一下为好

1,假设原始图像为F(x,y),灰度化得到G(x,y);

2,构建一个半径为Radius的正方形模板M,边长为2*Radius+1;

3,将M在F上依次遍历每个像素,对于当前像素P(x,y):

设置灰度层次N,由于图像灰度值范围为0-255, 主要用来对像素的灰度层次聚类

3.1首先按照N将0-255的范围划分为等距的N个灰度层次,对于模板中对应的像素,我们按照其灰度值,依次将其放入相应的灰度层次

3.2统计N个灰度层次像素数目,计算像素数最多的那个层次内,像素的各个颜色分量均值Mean,这个均值RGB就是模板中心像素P(x,y)的值。

 

 

2.1. 这个其实就是灰度层次降低维度的过程。

注意:油漆桶数N可以调节图像平滑度,灰度层次

2.2. 模板半径Radius用来调节水彩画的水彩程度。即是颜色的降低维度的过程

 

 

3. 源码算法/AtiPlatf_cms/src/com/attilax/img/OilPaintV2.java

private void process(BufferedImage src, int grayLevDeep, int radis) throws FileExistEx {

 

//初始化矩阵扫描模板

mtrx = new Matrix().setRadis(radis).setImg(src);

//初始化灰度层次分类器

GrayLayerCater GrayLayerCater1 = new GrayLayerCater(); // ini

GrayLayerCater_rgbmod_dbg = GrayLayerCater1;

//初始化灰度层次,为n

List<Layer> li = GrayLayerCater1.iniLayers_groupByGray(grayLevDeep, 255);

//初始化选框矩阵扫描器

ImgTraver_byMatrix trvr = new ImgTraver_byMatrix(mtrx);

//设置扫描到每个像素的事件处理

trvr.cur_Pix_Point_Evt_Handler = (cur_point) -> {

 

//对模板选框内内的像素对灰度聚合分类,分别放在不同的灰度层次里面

GrayLayerCater1.assignMatrixColorsToBukesByPerColorGray(mtrx);

//得到最多像素点的那个灰度层次,丢弃其他层次像素信息

Layer MaxPixsLayer1 = GrayLayerCater1.MaxPixsLayer();

//计算颜色均值,分别对各个rgb分量计算,与合成

Color avgColor = MaxPixsLayer1.avgColor_retClr();

Point mtrxCenter_Point = mtrx.getCenterPoint();

 

try {

src.setRGB(cur_point.x, cur_point.y, avgColor.getRGB());

   //因为扫描的时候,模板可能超出图像边界,最后一行像素简化处理,忽略错误即可

} catch (ArrayIndexOutOfBoundsException e) {

System.out.println(e.getMessage() + "  point:" + cur_point);

}

 

};

trvr.trave(src); //开始扫描

}

 

作者:: 绰号:老哇的爪子 ( 全名::Attilax Akbar Al Rapanui 阿提拉克斯 阿克巴 阿尔 拉帕努伊 ) 

汉字名:艾提拉(艾龙)   EMAIL:1466519819@qq.com

转载请注明来源: http://www.cnblogs.com/attilax/

Atiend

 

 

以上是关于Atitit Atitit 图像处理之  Oilpaint油画滤镜 水彩画 源码实现的主要内容,如果未能解决你的问题,请参考以下文章

Atitit 图像处理之编程之类库调用的接口api cli gui ws rest  attilax大总结.docx

Atitit.异常处理 嵌套  冗长的解决方案

Atitit 图像处理 调用opencv 通过java  api   attilax总结

Atitit  图像处理底色变红的解决

Atitit  jdbc 处理返回多个结果集

Atitit (Sketch Filter)素描滤镜的实现  图像处理  attilax总结