前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Java 实现灰度图转真彩图

Java 实现灰度图转真彩图

作者头像
一写代码就开心
发布2023-11-02 08:57:55
1540
发布2023-11-02 08:57:55
举报
文章被收录于专栏:java和pythonjava和python

1 问题

Java 实现灰度图转真彩图

在这里插入图片描述
在这里插入图片描述

将以上的图片,jpg png 都可以,转为有颜色的

2 实现

代码语言:javascript
复制
import javax.imageio.ImageIO;
import java.awt.*;
import java.awt.image.BufferedImage;
import java.awt.image.Raster;
import java.io.File;

public class DatUtils {

    public static void main(String[] args) {
        File file = new File("C:\\Users\\\\55\\1.jpg");
        File file1 = new File("C:\\Users\\\\55");
        System.out.println(picGrayToColour(file.getPath(),file1.getPath(),"33.jpg"));

    }
    /**
     * 灰度图转真彩图
     * @param path-灰度图路径
     * @param outPath-真彩图输出路径
     */
    public static boolean picGrayToColour(String path, String outPath, String picName){
        try {
            File file = new File(path);
            BufferedImage bufferedImage = ImageIO.read(file);
            BufferedImage bImage=new BufferedImage(bufferedImage.getWidth(),bufferedImage.getHeight(),BufferedImage.TYPE_4BYTE_ABGR);
            Raster data = bufferedImage.getData();
            for(int i=0;i<bufferedImage.getHeight();i++){
                for(int j=0;j<bufferedImage.getWidth();j++){
                    double[] pixel = data.getPixel(j, i, new double[4]);
                    int rgba;
                    if(pixel[0]<10){
                        rgba = new Color(0,0,0,0).getRGB();
                    }else {
                        int[] colorMsg = getColorMsg(pixel[0]);
                        rgba = new Color(colorMsg[0],colorMsg[1],colorMsg[2],colorMsg[3]).getRGB();
                    }
                    bImage.setRGB(j,i,rgba);
                }
            }
            //创建文件与文件夹
            File outFile = new File(outPath);
            if (!outFile.exists()) {
                outFile.mkdirs();
            }
            File pic = new File(outPath + File.separator + picName);
            if (!pic.exists()) {
                pic.createNewFile();
            }
            ImageIO.write(bImage,"png", pic);
            return true;
        }catch (Exception e){
            return false;
        }
    }

    private static int[] getColorMsg(double data){
        int[] gradient = new int[]{10,15, 20, 25, 30, 35, 40, 45, 50, 55, 60, 65, 70};
        int[][] gradientColor = new int[][]{{1, 160, 246, 255}, {0, 236, 236, 255}, {0, 216, 0, 255}, {1, 144, 0, 255}, {255, 255, 0, 255}, {231, 192, 0, 255}, {255, 144, 0, 255}, {255, 0, 0, 255}, {214, 0, 0, 255}, {192, 0, 0, 255}, {255, 0, 240, 255}, {150, 0, 180, 255}, {173, 144, 240, 255}};
        int[] colorMsg = new int[4];
        for(int i=0;i<gradient.length-1;i++){
            if(data<=gradient[i]){
                colorMsg = gradientColor[i];
                break;
            }
            if(data==gradient[i+1]){
                colorMsg = gradientColor[i+1];
                break;
            }
            if(data>gradient[i]&&data<gradient[i+1]){
                //                colorMsg[0] = new Double((gradientColor[i+1][0]-gradientColor[i][0])/(gradient[i+1]-gradient[i])*(data-gradient[i])+gradientColor[i][0]).intValue();
                //                colorMsg[1] = new Double((gradientColor[i+1][1]-gradientColor[i][1])/(gradient[i+1]-gradient[i])*(data-gradient[i])+gradientColor[i][1]).intValue();
                //                colorMsg[2] = new Double((gradientColor[i+1][2]-gradientColor[i][2])/(gradient[i+1]-gradient[i])*(data-gradient[i])+gradientColor[i][2]).intValue();
                colorMsg[0] = Double.valueOf((gradientColor[i+1][0]-gradientColor[i][0])/(gradient[i+1]-gradient[i])*(data-gradient[i])+gradientColor[i][0]).intValue();
                colorMsg[1] = Double.valueOf((gradientColor[i+1][1]-gradientColor[i][1])/(gradient[i+1]-gradient[i])*(data-gradient[i])+gradientColor[i][1]).intValue();
                colorMsg[2] = Double.valueOf((gradientColor[i+1][2]-gradientColor[i][2])/(gradient[i+1]-gradient[i])*(data-gradient[i])+gradientColor[i][2]).intValue();

                colorMsg[3] = 255;
                break;
            }
            if(i+1==gradient.length-1){
                colorMsg = gradientColor[i+1];
            }
        }
        return colorMsg;
    }
}
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2023-11-01,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1 问题
  • 2 实现
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档