From 87891450ba80a8c737257d3c0e73dd2fc970593e Mon Sep 17 00:00:00 2001 From: Nick Burch Date: Tue, 25 May 2010 15:59:26 +0000 Subject: [PATCH] Apply patches from Peter Kutak from bugs 49334 and 49242 - HSSFChart improvements by tracking more records git-svn-id: https://svn.apache.org/repos/asf/poi/trunk@948080 13f79535-47bb-0310-9956-ffa450edef68 --- src/documentation/content/xdocs/status.xml | 2 + .../apache/poi/hssf/record/RecordFactory.java | 5 +- .../apache/poi/hssf/record/UnknownRecord.java | 1 - .../apache/poi/hssf/usermodel/HSSFChart.java | 109 ++++++++++++++++-- 4 files changed, 105 insertions(+), 12 deletions(-) diff --git a/src/documentation/content/xdocs/status.xml b/src/documentation/content/xdocs/status.xml index 102f6cb529..068ab153af 100644 --- a/src/documentation/content/xdocs/status.xml +++ b/src/documentation/content/xdocs/status.xml @@ -34,6 +34,8 @@ + 49334 - Track the ValueRangeRecords of charts in HSSFChart, to allow the basic axis operations + 49242 - Track the LinkDataRecords of charts in HSSFChart Improved performance of XSSFWorkbook.write 48846 - Avoid NPE when finding cell comments 49325 - Ensure that CTPhoneticPr is included in poi-ooxml jar diff --git a/src/java/org/apache/poi/hssf/record/RecordFactory.java b/src/java/org/apache/poi/hssf/record/RecordFactory.java index da4a065f9b..e99534ce62 100644 --- a/src/java/org/apache/poi/hssf/record/RecordFactory.java +++ b/src/java/org/apache/poi/hssf/record/RecordFactory.java @@ -210,8 +210,9 @@ public final class RecordFactory { TopMarginRecord.class, UncalcedRecord.class, UseSelFSRecord.class, - UserSViewBegin.class, - UserSViewEnd.class, + UserSViewBegin.class, + UserSViewEnd.class, + ValueRangeRecord.class, VCenterRecord.class, VerticalPageBreakRecord.class, WindowOneRecord.class, diff --git a/src/java/org/apache/poi/hssf/record/UnknownRecord.java b/src/java/org/apache/poi/hssf/record/UnknownRecord.java index 7056cb2c31..20b352456d 100644 --- a/src/java/org/apache/poi/hssf/record/UnknownRecord.java +++ b/src/java/org/apache/poi/hssf/record/UnknownRecord.java @@ -241,7 +241,6 @@ public final class UnknownRecord extends StandardRecord { case 0x101B: case 0x101D: case 0x101E: - case 0x101F: case 0x1020: case 0x1021: case 0x1022: diff --git a/src/scratchpad/src/org/apache/poi/hssf/usermodel/HSSFChart.java b/src/scratchpad/src/org/apache/poi/hssf/usermodel/HSSFChart.java index 725659044c..9192d97d78 100644 --- a/src/scratchpad/src/org/apache/poi/hssf/usermodel/HSSFChart.java +++ b/src/scratchpad/src/org/apache/poi/hssf/usermodel/HSSFChart.java @@ -18,7 +18,6 @@ package org.apache.poi.hssf.usermodel; import java.util.ArrayList; -import java.util.Iterator; import java.util.List; import org.apache.poi.hssf.record.chart.*; @@ -37,6 +36,7 @@ import org.apache.poi.hssf.record.UnknownRecord; import org.apache.poi.hssf.record.VCenterRecord; import org.apache.poi.hssf.record.formula.Area3DPtg; import org.apache.poi.hssf.record.formula.Ptg; +import org.apache.poi.hssf.record.chart.LinkedDataRecord; /** * Has methods for construction of a chart object. @@ -49,8 +49,9 @@ public final class HSSFChart { private LegendRecord legendRecord; private ChartTitleFormatRecord chartTitleFormat; private SeriesTextRecord chartTitleText; - - private List series = new ArrayList(); + private List valueRanges = new ArrayList(); + + private List series = new ArrayList(); private HSSFChart(ChartRecord chartRecord) { this.chartRecord = chartRecord; @@ -137,13 +138,12 @@ public final class HSSFChart { * these charts yet, as this is very limited support */ public static HSSFChart[] getSheetCharts(HSSFSheet sheet) { - List charts = new ArrayList(); + List charts = new ArrayList(); HSSFChart lastChart = null; - + HSSFSeries lastSeries = null; // Find records of interest - List records = sheet.getSheet().getRecords(); - for(Iterator it = records.iterator(); it.hasNext();) { - RecordBase r = (RecordBase)it.next(); + List records = sheet.getSheet().getRecords(); + for(RecordBase r : records) { if(r instanceof ChartRecord) { lastChart = new HSSFChart((ChartRecord)r); @@ -155,6 +155,7 @@ public final class HSSFChart { if(r instanceof SeriesRecord) { HSSFSeries series = lastChart.new HSSFSeries( (SeriesRecord)r ); lastChart.series.add(series); + lastSeries = series; } if(r instanceof ChartTitleFormatRecord) { lastChart.chartTitleFormat = @@ -173,6 +174,13 @@ public final class HSSFChart { lastChart.chartTitleText = str; } } + if(r instanceof LinkedDataRecord) { + LinkedDataRecord data = (LinkedDataRecord)r; + lastSeries.insertData( data ); + } + if(r instanceof ValueRangeRecord){ + lastChart.valueRanges.add((ValueRangeRecord)r); + } } return (HSSFChart[]) @@ -228,6 +236,35 @@ public final class HSSFChart { throw new IllegalStateException("No chart title found to change"); } } + + /** + * Set value range (basic Axis Options) + * @param axisIndex 0 - primary axis, 1 - secondary axis + * @param minimum minimum value; Double.NaN - automatic; null - no change + * @param maximum maximum value; Double.NaN - automatic; null - no change + * @param majorUnit major unit value; Double.NaN - automatic; null - no change + * @param minorUnit minor unit value; Double.NaN - automatic; null - no change + */ + public void setValueRange( int axisIndex, Double minimum, Double maximum, Double majorUnit, Double minorUnit){ + ValueRangeRecord valueRange = (ValueRangeRecord)valueRanges.get( axisIndex ); + if( valueRange == null ) return; + if( minimum != null ){ + valueRange.setAutomaticMinimum(minimum.isNaN()); + valueRange.setMinimumAxisValue(minimum); + } + if( maximum != null ){ + valueRange.setAutomaticMaximum(maximum.isNaN()); + valueRange.setMaximumAxisValue(maximum); + } + if( majorUnit != null ){ + valueRange.setAutomaticMajor(majorUnit.isNaN()); + valueRange.setMajorIncrement(majorUnit); + } + if( minorUnit != null ){ + valueRange.setAutomaticMinor(minorUnit.isNaN()); + valueRange.setMinorIncrement(minorUnit); + } + } private SeriesIndexRecord createSeriesIndexRecord( int index ) { @@ -348,7 +385,7 @@ public final class HSSFChart { return new UnknownRecord((short)0x00EC, data); } - private void createAxisRecords( List records ) + private void createAxisRecords( List records ) { records.add( createAxisParentRecord() ); records.add( createBeginRecord() ); @@ -867,11 +904,30 @@ public final class HSSFChart { public class HSSFSeries { private SeriesRecord series; private SeriesTextRecord seriesTitleText; + private LinkedDataRecord dataName; + private LinkedDataRecord dataValues; + private LinkedDataRecord dataCategoryLabels; + private LinkedDataRecord dataSecondaryCategoryLabels; + private int dataReaded = 0; /* package */ HSSFSeries(SeriesRecord series) { this.series = series; } + public void insertData(LinkedDataRecord data){ + switch(dataReaded){ + case 0: dataName = data; + break; + case 1: dataValues = data; + break; + case 2: dataCategoryLabels = data; + break; + case 3: dataSecondaryCategoryLabels = data; + break; + } + dataReaded++; + } + public short getNumValues() { return series.getNumValues(); } @@ -905,5 +961,40 @@ public final class HSSFChart { throw new IllegalStateException("No series title found to change"); } } + + /** + * @return record with data names + */ + public LinkedDataRecord getDataName(){ + return dataName; + } + + /** + * @return record with data values + */ + public LinkedDataRecord getDataValues(){ + return dataValues; + } + + /** + * @return record with data category labels + */ + public LinkedDataRecord getDataCategoryLabels(){ + return dataCategoryLabels; + } + + /** + * @return record with data secondary category labels + */ + public LinkedDataRecord getDataSecondaryCategoryLabels() { + return dataSecondaryCategoryLabels; + } + + /** + * @return record with series + */ + public SeriesRecord getSeries() { + return series; + } } }