91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

java中怎么生成表格圖表

發布時間:2021-06-30 17:43:01 來源:億速云 閱讀:968 作者:Leah 欄目:大數據

本篇文章給大家分享的是有關java中怎么生成表格圖表,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

java中怎么生成表格圖表

項目有個需求是生成上圖的表格圖表,本來excel很容易生成上邊的表格圖,但是java poi不支持在服務器端把excel表格導出成圖片,在沒有找到合適的工具庫下,用java 2d實現同樣圖表。
這個表格圖分成標題、表頭、表中、表尾4個部分,
背景填充用:graphics.fillRect()
畫線條用:graphics.drawLine()
畫文字用:graphics.drawString()
主要用上邊三個java 2d方法實現,剩下的就是各種坐標位置的計算。
實現代碼:

package com.penngo.test;

import javax.imageio.ImageIO;
import java.awt.*;
import java.awt.image.BufferedImage;
import java.io.File;
import java.util.Arrays;
import java.util.List;

public class ExcelChart {
    private Font titleFont = new Font("宋體",Font.BOLD,20);
    private Font headFont = new Font("宋體",Font.BOLD,16);
    private Font rowFont = new Font("宋體",Font.PLAIN,14);
    private Font bottomFont = new Font("宋體",Font.PLAIN,14);

    private Color titleBackgroup = new Color(237, 125, 49);  // 標題背景色
    private Color headBackgroup = new Color(252, 228, 214);  // 表頭背景色
    private Color lineColor = new Color(237, 125,49);        // 線條顏色

    private int titleMargin = 8;
    private int headMargin = 8;
    private int rowMargin = 5;
    private int bottomMargin = 5;

    private int width;
    private int height;
    private int widthMargin = 10;   // x橫軸邊距
    private int heightMargin = 10;  // y軸邊框

    /**
     * 將圖片保存到指定位置
     * @param image 緩沖文件類
     * @param fileLocation 文件位置
     */
    public void createImage(BufferedImage image, File fileLocation) {
        try {
            ImageIO.write(image, "png", fileLocation);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

    /**
     * 字符串總寬度
     * @param g
     * @param str
     * @return
     */
    private int  getStringWidth(Graphics g,String str) {
        char[]  strcha=str.toCharArray();
        int strWidth = g.getFontMetrics().charsWidth(strcha, 0, str.length());
        return strWidth;
    }
    //字符高度
    private int  getStringHeight(Graphics g) {
        int height = g.getFontMetrics().getHeight();
        return height;
    }
    private int calculateImageHeight(int rowCount){
        BufferedImage image = new BufferedImage(100, 100,BufferedImage.TYPE_INT_RGB);
        Graphics graphics = image.getGraphics();
        graphics.setFont(titleFont);
        int titleRowHeight = getStringHeight(graphics) + titleMargin * 2;
        graphics.setFont(headFont);
        int headRowHeight = getStringHeight(graphics) + headMargin * 2;
        graphics.setFont(rowFont);
        int rowHeight = getStringHeight(graphics) + rowMargin * 2;
        graphics.setFont(bottomFont);
        int bottomRowHeight = getStringHeight(graphics) + bottomMargin * 2;
        int height = widthMargin * 2 + titleRowHeight + headRowHeight + rowHeight * rowCount + bottomRowHeight;
        return height;
    }
    public void createTableChart(File img, String title, String bottomTitle, List<String> headList, List<List<String>> rows, int width){

        widthMargin = 10;
        heightMargin = 10;
        this.width = width;
        this.height = calculateImageHeight(rows.size());

        BufferedImage image = new BufferedImage(width, height,BufferedImage.TYPE_INT_RGB);
        Graphics graphics = image.getGraphics();
        ((Graphics2D)graphics).setRenderingHint(RenderingHints.KEY_TEXT_ANTIALIASING, RenderingHints.VALUE_TEXT_ANTIALIAS_ON);
        ((Graphics2D)graphics).setRenderingHint(RenderingHints.KEY_ANTIALIASING, RenderingHints.VALUE_ANTIALIAS_ON);
        graphics.setColor(Color.WHITE);
        graphics.fillRect(0,0, width, height);


        int rowWidth = (width - widthMargin * 2) / headList.size();

        // 線條顏色
        Color lineColor = new Color(237, 125,49);

        // 創建標題背景
        int xTitle = widthMargin;
        int yTitle = heightMargin;
        graphics.setFont(getTitleFont());
        int titleHeight = getStringHeight(graphics);
        writeTitle(xTitle, yTitle, titleHeight, title, graphics);

        // 創建表頭
        int xHead = widthMargin;
        int yHead = yTitle + titleHeight + titleMargin * 2;
        graphics.setFont(getHeadFont());
        int headHeight = getStringHeight(graphics);
        writeHead(xHead, yHead,rowWidth, headHeight, headList,graphics);

        // 表格內容
        int xRow = widthMargin;
        int yRow = yHead + headHeight + headMargin * 2;
        graphics.setFont(rowFont);
        int rowHeight = getStringHeight(graphics);
        writeRow(xRow, yRow, rowWidth,rowHeight,headList, rows, graphics);

        // 表格底部
        int xBottom = widthMargin;
        int yBottom = yRow + (rowHeight + rowMargin * 2) * rows.size();
        graphics.setFont(bottomFont);
        int bottomHeight = getStringHeight(graphics);
        writeBottom(xBottom, yBottom, bottomHeight, bottomTitle, graphics);

        // 保存圖片
        createImage(image, img);
    }

    private void writeTitle(int xTitle, int yTitle, int titleHeight, String title, Graphics graphics){
        int titleWidth = getStringWidth(graphics, title);
        graphics.setColor(getTitleBackgroup());
        graphics.fillRect(xTitle,yTitle, width - widthMargin * 2 + 1, titleHeight + titleMargin * 2);

        // 標題文字
        graphics.setColor(Color.WHITE);
        graphics.drawString(title, widthMargin + (width - widthMargin * 2)/2 - titleWidth / 2, heightMargin + titleHeight + titleMargin - 3);

    }
    private void drawString(Graphics graphics, String txt, int x, int y){
        Graphics2D g2d = (Graphics2D)graphics;
        g2d.setRenderingHint(RenderingHints.KEY_TEXT_ANTIALIASING, RenderingHints.VALUE_TEXT_ANTIALIAS_ON);//設置抗鋸齒
        g2d.setPaint(new Color(0, 0, 0, 64));//陰影顏色
        g2d.drawString(txt, x, y);//先繪制陰影
        g2d.setPaint(Color.BLACK);//正文顏色
        g2d.drawString(txt, x, y);//用正文顏色覆蓋上去
    }
    /**
     * 寫入表頭文本
     */
    private void writeHead(int xHead, int yHead,int rowWidth, int headHeight, List<String> headList,Graphics graphics){
        // 背景填充
        graphics.setColor(getHeadBackgroup());
        graphics.fillRect(xHead, yHead, width - widthMargin * 2,  headHeight + headMargin * 2);
        // 表格豎線
        graphics.setColor(getLineColor());
        for(int i = 0;i < headList.size() + 1; i++){
            graphics.drawLine(xHead + i * rowWidth, yHead, xHead + i * rowWidth, yHead + headHeight + headMargin * 2);
        }

        graphics.setColor(Color.BLACK);
        for(int i = 0; i < headList.size(); i++){
            String str = headList.get(i);
            if(str.length() < 5){
                graphics.drawString(str, xHead + i * rowWidth + headMargin, yHead + headHeight + headMargin);
            }
            else{
                String t1 = str.substring(0, 5);
                int t1Width = getStringWidth(graphics, t1);
                graphics.drawString(t1, xHead + i * rowWidth + headMargin, yHead + headHeight - headMargin/2 + 1);
                String t2 = str.substring(5, str.length());
                int t2Width = getStringWidth(graphics, t2);
                int tdx = (t1Width - t2Width) / 2;
                graphics.drawString(t2, xHead + i * rowWidth + headMargin + tdx, yHead + headHeight + headMargin + 3);
            }
        }
    }

    /**
     * 寫入表數據
     */
    private void writeRow(int xRow, int yRow, int rowWidth,int rowHeight,List<String> headList, List<List<String>> rows,Graphics graphics){
        // 畫橫線
        int rowCount = rows.size() + 1;
        graphics.setColor(getLineColor());
        for(int i = 0; i< rowCount; i++){
            int y = yRow + i * (rowHeight + rowMargin * 2);
            graphics.drawLine(xRow, y, width - widthMargin, y);
        }
        // 畫豎線
        int colCount = headList.size() + 1;
        for(int c = 0; c < colCount; c++){
            int x = xRow + c * rowWidth;
            int maxY = yRow + rows.size() * (rowHeight + rowMargin * 2);
            graphics.drawLine(x, yRow, x, maxY);
        }
        // 寫入行數據
        graphics.setColor(Color.BLACK);
        for(int r = 0; r < rows.size(); r++){
            List<String> row = rows.get(r);
            for(int c = 0; c < row.size(); c++){
                int x = xRow + rowMargin + c * rowWidth;
                int y = yRow + rowHeight + rowMargin+  r * (rowHeight + rowMargin * 2) - 2;
//                graphics.drawString(row.get(c), x, y);
                drawString(graphics, row.get(c), x, y);
            }
        }
    }

    private void writeBottom(int xBottom, int yBottom, int bottomHeight, String bottomTitle, Graphics graphics){
        // 畫橫線
        graphics.setColor(getLineColor());
        graphics.drawLine(xBottom, yBottom + bottomHeight + bottomMargin * 2, width - widthMargin ,yBottom + bottomHeight + bottomMargin * 2);
        // 畫豎線
        graphics.drawLine(xBottom, yBottom, xBottom ,yBottom + bottomHeight + bottomMargin * 2);
        graphics.drawLine(width - widthMargin, yBottom, width - widthMargin ,yBottom + bottomHeight + bottomMargin * 2);

        graphics.setColor(Color.BLACK);
        int bottomTitleWidth = getStringWidth(graphics, bottomTitle);
        int x = width / 2 - bottomTitleWidth / 2;
        graphics.drawString(bottomTitle, x, yBottom + bottomHeight + bottomMargin);
    }

    public Font getTitleFont() {
        return titleFont;
    }

    public void setTitleFont(Font titleFont) {
        this.titleFont = titleFont;
    }

    public Font getHeadFont() {
        return headFont;
    }

    public void setHeadFont(Font headFont) {
        this.headFont = headFont;
    }

    public Font getRowFont() {
        return rowFont;
    }

    public void setRowFont(Font rowFont) {
        this.rowFont = rowFont;
    }

    public Font getBottomFont() {
        return bottomFont;
    }

    public void setBottomFont(Font bottomFont) {
        this.bottomFont = bottomFont;
    }

    public int getTitleMargin() {
        return titleMargin;
    }

    public void setTitleMargin(int titleMargin) {
        this.titleMargin = titleMargin;
    }

    public int getHeadMargin() {
        return headMargin;
    }

    public void setHeadMargin(int headMargin) {
        this.headMargin = headMargin;
    }

    public int getRowMargin() {
        return rowMargin;
    }

    public void setRowMargin(int rowMargin) {
        this.rowMargin = rowMargin;
    }

    public int getBottomMargin() {
        return bottomMargin;
    }

    public void setBottomMargin(int bottomMargin) {
        this.bottomMargin = bottomMargin;
    }

    public Color getLineColor() {
        return lineColor;
    }

    public void setLineColor(Color lineColor) {
        this.lineColor = lineColor;
    }

    public Color getTitleBackgroup() {
        return titleBackgroup;
    }

    public void setTitleBackgroup(Color titleBackgroup) {
        this.titleBackgroup = titleBackgroup;
    }

    public Color getHeadBackgroup() {
        return headBackgroup;
    }

    public void setHeadBackgroup(Color headBackgroup) {
        this.headBackgroup = headBackgroup;
    }

    public static void main(String[] args) throws Exception{

        ExcelChart tableChart = new ExcelChart();
        try {
            List<String> titleList = Arrays.asList("名稱","增幅","收入","收入凈利潤","今年收入增幅比例");
            List<List<String>> rows = Arrays.asList(
                    Arrays.asList("項目收入1", "6.05%", "9.95億", "1.83億", "5.74‰"),
                    Arrays.asList("項目收入2", "6.05%", "9.95億", "1.83億", "5.74‰"),
                    Arrays.asList("項目收入3", "6.05%", "9.95億", "1.83億", "5.74‰"),
                    Arrays.asList("項目收入4", "6.05%", "9.95億", "1.83億", "5.74‰"),
                    Arrays.asList("項目收入5", "6.05%", "9.95億", "1.83億", "5.74‰"),
                    Arrays.asList("項目收入6", "6.05%", "9.95億", "1.83億", "5.74‰"),
                    Arrays.asList("項目收入7", "6.05%", "9.95億", "1.83億", "5.74‰"),
                    Arrays.asList("項目收入8", "6.05%", "9.95億", "1.83億", "5.74‰"),
                    Arrays.asList("項目收入9", "6.05%", "9.95億", "1.83億", "5.74‰"),
                    Arrays.asList("項目收入10", "6.05%", "9.95億", "1.83億", "5.74‰")
            );
            tableChart.setTitleBackgroup(new Color(237, 125, 49));
            tableChart.setHeadBackgroup(new Color(252, 228, 214));
            tableChart.setLineColor(new Color(237, 125, 49));
            tableChart.createTableChart(new File("logs/tablechart1.png"),
                    "我是標題一二三四五六七八九十","日期:9月10日 制圖:https://my.oschina.net/penngo",
                    titleList,rows,600);


        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

以上就是java中怎么生成表格圖表,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

墨玉县| 邳州市| 同德县| 翁源县| 澳门| 清原| 皋兰县| 徐州市| 绥德县| 芦山县| 杭锦后旗| 辽宁省| 白玉县| 怀宁县| 本溪市| 涪陵区| 顺义区| 临颍县| 蓬安县| 皮山县| 杭锦旗| 衢州市| 滕州市| 肇庆市| 虞城县| 阳山县| 灵璧县| 海盐县| 临沂市| 南京市| 灯塔市| 宜兰市| 观塘区| 陕西省| 双牌县| 海伦市| 临猗县| 万盛区| 营口市| 田东县| 乌拉特前旗|