JAVA生成直方圖Image

jopen 12年前發布 | 5K 次閱讀 Dagger B2C

本程序修改至http://blog.csdn.net/lazy_p/article/details/5400268 ,以前是用的applet來呈現效果的。修改為返回一張BufferedImage圖片,便于應用到項目中去,比如Web、C/S

架構的程序都能應用。

package com.image.histogram;

import java.awt.Color;
import java.awt.Font;
import java.awt.FontMetrics;
import java.awt.Graphics;
import java.awt.image.BufferedImage;
import java.io.File;
import java.io.IOException;

import javax.imageio.ImageIO;

/**
 * 柱狀圖
 *
 * @author lazy_p
 * @date 2010-3-20
 */
public class PlaneHistogram {
    private final int histogramWidth = 15;// 柱形圖的寬度
    private final int histogramPitch = 10;// 柱形圖的間距
    private float scaling = 1f;// 縮放的比例
    private int maxStrWidth = 0; // 字符串需要的最大寬度

    /**
     * <pre>
     *   參數b[i]和str[i]必須對應
     * </pre>
     *
     * @param g
     * @param title
     * @param v
     * @param str
     * @param color
     *            可以為空
     */
    public BufferedImage paintPlaneHistogram(String title, int[] v,
            String[] str, Color[] color) {
        int width = str.length * histogramWidth+str.length*histogramPitch+50;
        int height = 255;
        scaling = calculateScale(v, height);//計算縮放比例

        BufferedImage bufferImage = new BufferedImage(width, height,
                BufferedImage.TYPE_INT_RGB);
        Graphics g = bufferImage.getGraphics();
        g.setColor(Color.WHITE);
        g.fillRect(0, 0, width, height);
        FontMetrics metrics = null;

        g.setFont(new Font(null, Font.BOLD, 18));
        g.setColor(Color.RED);

        g.drawString(title, (bufferImage.getWidth() - g.getFontMetrics()
                .stringWidth(title)) >> 1, 30);// 畫標題

        g.setFont(new Font(null, Font.PLAIN, 12));

        metrics = g.getFontMetrics();

        g.setColor(Color.BLACK);

        g.drawLine(10, 0, 10, height - 15); // 畫Y坐標
        g.drawLine(10, height - 15, width, height - 15);// 畫X坐標

        int j = 0;
        int colorCount=color.length;

        for (int i = 0; i < v.length; ++i) {

            if (color != null){
                g.setColor(color[j]);// 設置前景色
                if(j+1<colorCount){
                    j++;
                }else{
                    j=0;
                }
            }else{
                g.setColor(Color.RED);
            }

            int x = 20 + i
                    * (histogramPitch + histogramWidth + (maxStrWidth >> 1));// 計算出X坐標
            int y = height - 16 - (int) (v[i] * scaling); // 計算出Y坐標

            // 畫占的比例
            g.drawString(v[i] + "", x
                    - ((metrics.stringWidth(v[i] + "") - histogramWidth) >> 1),
                    y);

            // 畫平面的柱狀圖
            g.drawRect(x, y, histogramWidth, (int) (v[i] * scaling));
            g.fillRect(x, y, histogramWidth, (int) (v[i] * scaling));

            // 畫每一項表示的東西
            g.drawString(str[i], x
                    - ((metrics.stringWidth(str[i]) - histogramWidth) >> 1),
                    height - 2);
        }

        return bufferImage;
    }

    /**
     * 計算縮放比例
     * @param v
     * @param h 圖片的高度
     * @return
     */
    public float calculateScale(int[] v , int h){
        float scale = 1f;
        int max = Integer.MIN_VALUE;
        for(int i=0 , len=v.length ; i < len ;++i){
            if(v[i]>h && v[i]>max){
                max=v[i];
            }
        }
        if(max > h){
            scale=((int)(h*1.0f/max*1000))*1.0f/1000;
        }
        return scale;
    }

    public static void main(String[] args)  {
        PlaneHistogram planeHistogram = new PlaneHistogram();

        BufferedImage image = planeHistogram.paintPlaneHistogram("顏色直方圖",
                        new int[]{100,200,300}, new String[]{"a" , "b" , "c"} ,  new Color[] {Color.RED, Color.GREEN, Color.BLACK, Color.BLUE });
        File output = new File("G:/333.jpg");
        try {
            ImageIO.write(image, "jpg", output);
        } catch (IOException e) {
            e.printStackTrace();
        }
    }

}


轉自:http://blog.csdn.net/lazy_p/article/details/7206088

 本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!