2017-04-27 229 views
1

這是我的代碼,它可以成功生成結果。我只是想爲情節添加網格線,但我無法管理它。有誰能幫助解決這個問題嗎?如何使用Apache POI將曲線添加到excel折線圖

import java.io.FileOutputStream; 
import org.apache.poi.ss.usermodel.*; 
import org.apache.poi.ss.usermodel.charts.*; 
import org.apache.poi.ss.util.CellRangeAddress; 
import org.apache.poi.xssf.usermodel.XSSFChart; 
import org.apache.poi.xssf.usermodel.XSSFWorkbook; 
import org.openxmlformats.schemas.drawingml.x2006.chart.*; 
import org.openxmlformats.schemas.spreadsheetml.x2006.main.*; 

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

     Workbook wb = new XSSFWorkbook(); 
     Sheet dataSheet = wb.createSheet("linechart"); 
     dataSheet.setDisplayGridlines(true); 

     final int NUM_OF_ROWS = 10; 
     final int NUM_OF_COLUMNS = 4; 

     Row row; 
     Cell cell; 
     for (int rowIndex = 0; rowIndex < NUM_OF_ROWS; rowIndex++) { 
      row = dataSheet.createRow((short) rowIndex); 
      for (int colIndex = 0; colIndex < NUM_OF_COLUMNS; colIndex++) { 
       cell = row.createCell((short) colIndex); 
       cell.setCellValue(rowIndex * ((colIndex + 1) + ((int) (Math.random() * 10)))); 
      } 
     } 

     Drawing drawing = dataSheet.createDrawingPatriarch(); 
     ClientAnchor anchor = drawing.createAnchor(0, 0, 0, 0, NUM_OF_COLUMNS + 2, 3, NUM_OF_COLUMNS + 15, 20); 

     Chart chart = drawing.createChart(anchor); 
     ChartLegend legend = chart.getOrCreateLegend(); 
     legend.setPosition(LegendPosition.RIGHT); 

     LineChartData data = chart.getChartDataFactory().createLineChartData(); 

     ChartAxis bottomAxis = chart.getChartAxisFactory().createCategoryAxis(AxisPosition.BOTTOM); 
     ValueAxis leftAxis = chart.getChartAxisFactory().createValueAxis(AxisPosition.LEFT); 
     leftAxis.setCrosses(AxisCrosses.AUTO_ZERO); 

     ChartDataSource<Number> xs = DataSources.fromNumericCellRange(dataSheet, new CellRangeAddress(0, NUM_OF_ROWS - 1, 0, 0)); 
     ChartDataSource<Number> ys1 = DataSources.fromNumericCellRange(dataSheet, new CellRangeAddress(0, NUM_OF_ROWS - 1, 1, 1)); 
     ChartDataSource<Number> ys2 = DataSources.fromNumericCellRange(dataSheet, new CellRangeAddress(0, NUM_OF_ROWS - 1, 2, 2)); 
     ChartDataSource<Number> ys3 = DataSources.fromNumericCellRange(dataSheet, new CellRangeAddress(0, NUM_OF_ROWS - 1, 3, 3)); 

     LineChartSeries series1 = data.addSeries(xs, ys1); 
     series1.setTitle("one"); 
     LineChartSeries series2 = data.addSeries(xs, ys2); 
     series2.setTitle("two"); 
     LineChartSeries series3 = data.addSeries(xs, ys3); 
     series3.setTitle("three"); 
     bottomAxis.setMajorTickMark(AxisTickMark.CROSS); 
     bottomAxis.setMinorTickMark(AxisTickMark.IN); 
     chart.plot(data, bottomAxis, leftAxis); 

     XSSFChart xssfChart = (XSSFChart) chart; 
     CTPlotArea plotArea = xssfChart.getCTChart().getPlotArea(); 
     plotArea.getLineChartArray()[0].getSmooth(); 
     CTBoolean ctBool = CTBoolean.Factory.newInstance(); 
     ctBool.setVal(false); 
     plotArea.getLineChartArray()[0].setSmooth(ctBool); 
     for (CTLineSer ser : plotArea.getLineChartArray()[0].getSerArray()) { 
      ser.addNewSpPr().addNewSolidFill().addNewSrgbClr().setVal(new byte[] {0,0,0}); 
      ser.setSmooth(ctBool); 
     } 


     CTMarker ctMarker = CTMarker.Factory.newInstance(); 
     ctMarker.setSymbol(CTMarkerStyle.Factory.newInstance()); 
     for (CTLineSer ser : plotArea.getLineChartArray()[0].getSerArray()) { 
      ser.setMarker(ctMarker); 
     } 

     plotArea.addNewSpPr().addNewLn().addNewSolidFill().addNewSrgbClr().setVal(new byte[] {11,0,0}); 

     CTFill myPatternFill= CTFill.Factory.newInstance();          
     CTPatternFill pFill=myPatternFill.addNewPatternFill(); 
     pFill.setPatternType(STPatternType.DARK_DOWN); 

     //plotArea.addNewSpPr().addNewLn().addNewGradFill().addNewLin(); 
     // plotArea.addNewSpPr().addNewBlipFill().addNewBlip(); 
     //CTTableGrid ctTableGrid = CTTableGrid.Factory.newInstance(); 
     //ctTableGrid.addNewGridCol(); 

     FileOutputStream fileOut = new FileOutputStream("chart.xlsx"); 
     wb.write(fileOut); 
     fileOut.close(); 
     System.out.println("complete!"); 
    } 

} 

這是我得到了什麼, existing result

這就是我想要的, desired result

誰能幫我這個問題?

回答

1

您可以使用此代碼做到這一點: 首先從圖表對象創建CTPlotArea

CTPlotArea plotArea = chart.getCTChart().getPlotArea(); 

然後用這個水平軸和垂直軸

plotArea.getCatAxArray()[0].addNewMajorGridlines(); 
plotArea.getValAxArray()[0].addNewMajorGridlines(); 

如果你想顯示次網格使用代碼代替

plotArea.getCatAxArray()[0].addNewMinorGridlines(); 
plotArea.getValAxArray()[0].addNewMinorGridlines(); 

代碼應放在chart.plot(數據,ChartAxis ... chartAxis)方法之後

+0

您也可以用7z或其他存檔程序打開.xlsx文件,然後轉到xl/charts/chart1.xml,將在XML文件中找到一些屬性,它們可以在POI Chart類中具有相同的方法名稱 –

相關問題