JAVA生成直方圖Image
本程序修改至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 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!