通过看网上各种大牛的总结,和自己亲身测试总结一下Java图片的灰度处理方法
(1)我们熟知的图片中的像素点有RGB值。
(2)图片灰度化的方式大概分为四种,第一种是最大值法(取颜色RGB中的最大值作为灰度值);第二种是最小值法(取颜色RGB的最小值作为灰度值);第三种是均值法(取颜色的RGB的平均值作为灰度值);第四种是加权法灰度化(怎么加权最合适,效果最好,百度百科说的很全面)。
(3)废话不多说,记录一下我按照上述四种方法实现的效果和代码:
原图
按照上述四种方式分别灰度化后的效果如下面四图
(4)实例代码如下
package testhuidu; import java.awt.image.BufferedImage; import java.io.File; import java.io.IOException; import javax.imageio.ImageIO; public class TestHUidu { /** * 颜色分量转换为RGB值 * @param alpha * @param red * @param green * @param blue * @return */ private static int colorToRGB(int alpha, int red, int green, int blue) { int newPixel = 0; newPixel += alpha; newPixel = newPixel << 8; newPixel += red; newPixel = newPixel << 8; newPixel += green; newPixel = newPixel << 8; newPixel += blue; return newPixel; } public static void main(String[] args) throws IOException { grayImage(1,"ff.jpg", "1.jpg");//最大值法灰度化 grayImage(2,"ff.jpg", "2.jpg");//最小值法灰度化 grayImage(3,"ff.jpg", "3.jpg");//平均值法灰度化 grayImage(4,"ff.jpg", "4.jpg");//加权法灰度化 } /** * 图片灰度化的方法 * @param status 灰度化方法的种类,1表示最大值法,2表示最小值法,3表示均值法,4加权法 * @param imagePath 需要灰度化的图片的位置 * @param outPath 灰度化处理后生成的新的灰度图片的存放的位置 * @throws IOException */ public static void grayImage(int status,String imagePath, String outPath) throws IOException { File file = new File(imagePath); BufferedImage image = ImageIO.read(file); int width = image.getWidth(); int height = image.getHeight(); BufferedImage grayImage = new BufferedImage(width, height, image.getType()); //BufferedImage grayImage = new BufferedImage(width, height, BufferedImage.TYPE_BYTE_GRAY); for (int i = 0; i < width; i++) { for (int j = 0; j < height; j++) { int color = image.getRGB(i, j); final int r = (color >> 16) & 0xff; final int g = (color >> 8) & 0xff; final int b = color & 0xff; int gray=0; if(status==1){ gray=getBigger(r, g, b);//最大值法灰度化 }else if(status==2){ gray=getSmall(r, g, b);//最小值法灰度化 }else if(status==3){ gray=getAvg(r, g, b);//均值法灰度化 }else if(status==4){ gray = (int) (0.3 * r + 0.59 * g + 0.11 * b);//加权法灰度化 } System.out.println("像素坐标:" + " x=" + i + " y=" + j + " 灰度值=" + gray); grayImage.setRGB(i, j, colorToRGB(0, gray, gray, gray)); } } File newFile = new File(outPath); ImageIO.write(grayImage, "jpg", newFile); } //比较三个数的大小 public static int getBigger(int x,int y,int z){ if(x>=y&&x>=z){ return x; }else if(y>=x&&y>=z){ return y; }else if(z>=x&&z>=y){ return z; }else{ return 0; } } //比较三个是的大小取最小数 public static int getSmall(int x,int y,int z){ if(x<=y&&x<=z){ return x; }else if(y>=x&&y>=z){ return y; }else if(z>=x&&z>=y){ return z; }else{ return 0; } } //均值法 public static int getAvg(int x,int y,int z){ int avg=(x+y+z)/3; return avg; } }