RGB转换测试对比度的核心算法:
开发项目过程中,对于手机屏幕截图,需要对获取到的截图的任意部分进行区域颜色对比度的识别操作,由此判定任意指定区域是否满足某对比度基本标准,但是该功能在网上任何地方都没有找到过Java方面的代码,于是根据RGB转换测试的原理:即获取每个像素点的RGB,通过RGB对比度定义公式进行像素点的集合换取。
通过上述思路,开发了一下核心功能代码。代码如下,可以配合注释理解。由于项目保密性原因,只摘取一部分核心逻辑代码。其实核心就是通过Java自带的库进行像素点的获取,然后通过数学公式进行处理。读者感兴趣的话可自行查阅转换公式,从而达到给定任意某区域的手机截图获取颜色对比度。
image = ImageIO.read(file); int width=image.getWidth(); int height=image.getHeight(); int minx=image.getMinX(); int miny=image.getMinY(); //首先读入图片,然后指定区域。 System.out.println("width="+width+",height="+height+"."); System.out.println("minx="+minx+",miniy="+miny+"."); for(int i=minx;i<width;i+=5) { flag = 1; for(int j=miny;j<height;j+=1) { flag =1; int pixel=image.getRGB(i,j); r1 = (pixel & 0xff0000) >> 16; g1 = (pixel & 0xff00) >> 8; b1= (pixel & 0xff); // System.out.println(i+"=i,"+j+"=j,("+rgb1[0]+","+rgb1[1]+","+rgb1[2]+")"); //获取每个像素点的RGB。 } luminanace(r, g, b) { var a = [r, g, b].map(function (v) { v /= 255; return v <= 0.03928 ? v / 12.92 : Math.pow((v + 0.055) / 1.055, 2.4); }); return a[0] * 0.2126 + a[1] * 0.7152 + a[2] * 0.0722; }, //进行公式转换 获取对比度(不是Java语言) var brightest = Math.max(lum1, lum2); var darkest = Math.min(lum1, lum2); //进行对比度处理并输出结果。 return (brightest + 0.05) / (darkest + 0.05);