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);
Java:SpringBoot项目中MongoTemplate的新增、删除、更新、查询操作
Java:SpringBoot项目中MongoTemplate的新增、删除、更新、查询操作