对图片进行边缘检测在很多领域是非常重要的,例如:车牌号码的识别。边缘检测用到的算法我这里既不关心也不去深究了,只提供算法,对算法有兴趣的读者可以自己去找找图像处理的书参考下,或者也可以给我留言。
以上算法大体思路是:拿到一个图片的内存对象:BufferedImage,然后创建一个和原始图片一样大小的新的BufferedImage内存对象,将经过处理后的图片信息存在新的内存对象里,并返回。
运行效果图:
边缘检测前的图片:
[img]http://www.kutoku.info/images/java/100606/edge1.png[/img]
边缘检测后的图片:
[img]http://www.kutoku.info/images/java/100606/edge2.png[/img]
具体的程序代码请参考附件。
文章地址:[url]http://javapub.iteye.com/blog/685468[/url]
相关文章
[b]Java图像图片 边缘检测[/b] [url]http://javapub.iteye.com/blog/685468[/url]
[b]Java图像变灰[/b] [url]http://javapub.iteye.com/blog/687082[/url]
[b]Java 给图片增加 水印图片 水印文字[/b] [url]Java 给图片增加 水印图片 水印文字[/url]
[b]Java图像渐变[/b] [url]http://javapub.iteye.com/blog/736799[/url]
[b]Java将大图片转成小图片[/b] [url]http://javapub.iteye.com/blog/666607[/url]
public final BufferedImage getPicEdge(BufferedImage originalPic) {
int imageWidth = originalPic.getWidth();
int imageHeight = originalPic.getHeight();
BufferedImage newPic = new BufferedImage(imageWidth, imageHeight,
BufferedImage.TYPE_3BYTE_BGR);
float[] elements = { 0.0f, -1.0f, 0.0f, -1.0f, 4.0f, -1.0f, 0.0f,
-1.0f, 0.0f };
// AffineTransform at = new AffineTransform();
Kernel kernel = new Kernel(3, 3, elements);
ConvolveOp cop = new ConvolveOp(kernel, ConvolveOp.EDGE_NO_OP, null);
cop.filter(originalPic, newPic);
return newPic;
}
以上算法大体思路是:拿到一个图片的内存对象:BufferedImage,然后创建一个和原始图片一样大小的新的BufferedImage内存对象,将经过处理后的图片信息存在新的内存对象里,并返回。
运行效果图:
边缘检测前的图片:
[img]http://www.kutoku.info/images/java/100606/edge1.png[/img]
边缘检测后的图片:
[img]http://www.kutoku.info/images/java/100606/edge2.png[/img]
具体的程序代码请参考附件。
文章地址:[url]http://javapub.iteye.com/blog/685468[/url]
相关文章
[b]Java图像图片 边缘检测[/b] [url]http://javapub.iteye.com/blog/685468[/url]
[b]Java图像变灰[/b] [url]http://javapub.iteye.com/blog/687082[/url]
[b]Java 给图片增加 水印图片 水印文字[/b] [url]Java 给图片增加 水印图片 水印文字[/url]
[b]Java图像渐变[/b] [url]http://javapub.iteye.com/blog/736799[/url]
[b]Java将大图片转成小图片[/b] [url]http://javapub.iteye.com/blog/666607[/url]