mirror of https://github.com/apache/poi.git
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
This commit is contained in:
parent
8c952b66ad
commit
87891450ba
|
@ -34,6 +34,8 @@
|
||||||
|
|
||||||
<changes>
|
<changes>
|
||||||
<release version="3.7-SNAPSHOT" date="2010-??-??">
|
<release version="3.7-SNAPSHOT" date="2010-??-??">
|
||||||
|
<action dev="POI-DEVELOPERS" type="add">49334 - Track the ValueRangeRecords of charts in HSSFChart, to allow the basic axis operations</action>
|
||||||
|
<action dev="POI-DEVELOPERS" type="add">49242 - Track the LinkDataRecords of charts in HSSFChart</action>
|
||||||
<action dev="POI-DEVELOPERS" type="add">Improved performance of XSSFWorkbook.write </action>
|
<action dev="POI-DEVELOPERS" type="add">Improved performance of XSSFWorkbook.write </action>
|
||||||
<action dev="POI-DEVELOPERS" type="fix">48846 - Avoid NPE when finding cell comments</action>
|
<action dev="POI-DEVELOPERS" type="fix">48846 - Avoid NPE when finding cell comments</action>
|
||||||
<action dev="POI-DEVELOPERS" type="fix">49325 - Ensure that CTPhoneticPr is included in poi-ooxml jar</action>
|
<action dev="POI-DEVELOPERS" type="fix">49325 - Ensure that CTPhoneticPr is included in poi-ooxml jar</action>
|
||||||
|
|
|
@ -210,8 +210,9 @@ public final class RecordFactory {
|
||||||
TopMarginRecord.class,
|
TopMarginRecord.class,
|
||||||
UncalcedRecord.class,
|
UncalcedRecord.class,
|
||||||
UseSelFSRecord.class,
|
UseSelFSRecord.class,
|
||||||
UserSViewBegin.class,
|
UserSViewBegin.class,
|
||||||
UserSViewEnd.class,
|
UserSViewEnd.class,
|
||||||
|
ValueRangeRecord.class,
|
||||||
VCenterRecord.class,
|
VCenterRecord.class,
|
||||||
VerticalPageBreakRecord.class,
|
VerticalPageBreakRecord.class,
|
||||||
WindowOneRecord.class,
|
WindowOneRecord.class,
|
||||||
|
|
|
@ -241,7 +241,6 @@ public final class UnknownRecord extends StandardRecord {
|
||||||
case 0x101B:
|
case 0x101B:
|
||||||
case 0x101D:
|
case 0x101D:
|
||||||
case 0x101E:
|
case 0x101E:
|
||||||
case 0x101F:
|
|
||||||
case 0x1020:
|
case 0x1020:
|
||||||
case 0x1021:
|
case 0x1021:
|
||||||
case 0x1022:
|
case 0x1022:
|
||||||
|
|
|
@ -18,7 +18,6 @@
|
||||||
package org.apache.poi.hssf.usermodel;
|
package org.apache.poi.hssf.usermodel;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Iterator;
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
import org.apache.poi.hssf.record.chart.*;
|
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.VCenterRecord;
|
||||||
import org.apache.poi.hssf.record.formula.Area3DPtg;
|
import org.apache.poi.hssf.record.formula.Area3DPtg;
|
||||||
import org.apache.poi.hssf.record.formula.Ptg;
|
import org.apache.poi.hssf.record.formula.Ptg;
|
||||||
|
import org.apache.poi.hssf.record.chart.LinkedDataRecord;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Has methods for construction of a chart object.
|
* Has methods for construction of a chart object.
|
||||||
|
@ -49,8 +49,9 @@ public final class HSSFChart {
|
||||||
private LegendRecord legendRecord;
|
private LegendRecord legendRecord;
|
||||||
private ChartTitleFormatRecord chartTitleFormat;
|
private ChartTitleFormatRecord chartTitleFormat;
|
||||||
private SeriesTextRecord chartTitleText;
|
private SeriesTextRecord chartTitleText;
|
||||||
|
private List<ValueRangeRecord> valueRanges = new ArrayList<ValueRangeRecord>();
|
||||||
|
|
||||||
private List series = new ArrayList();
|
private List<HSSFSeries> series = new ArrayList<HSSFSeries>();
|
||||||
|
|
||||||
private HSSFChart(ChartRecord chartRecord) {
|
private HSSFChart(ChartRecord chartRecord) {
|
||||||
this.chartRecord = chartRecord;
|
this.chartRecord = chartRecord;
|
||||||
|
@ -137,13 +138,12 @@ public final class HSSFChart {
|
||||||
* these charts yet, as this is very limited support
|
* these charts yet, as this is very limited support
|
||||||
*/
|
*/
|
||||||
public static HSSFChart[] getSheetCharts(HSSFSheet sheet) {
|
public static HSSFChart[] getSheetCharts(HSSFSheet sheet) {
|
||||||
List charts = new ArrayList();
|
List<HSSFChart> charts = new ArrayList<HSSFChart>();
|
||||||
HSSFChart lastChart = null;
|
HSSFChart lastChart = null;
|
||||||
|
HSSFSeries lastSeries = null;
|
||||||
// Find records of interest
|
// Find records of interest
|
||||||
List records = sheet.getSheet().getRecords();
|
List<RecordBase> records = sheet.getSheet().getRecords();
|
||||||
for(Iterator it = records.iterator(); it.hasNext();) {
|
for(RecordBase r : records) {
|
||||||
RecordBase r = (RecordBase)it.next();
|
|
||||||
|
|
||||||
if(r instanceof ChartRecord) {
|
if(r instanceof ChartRecord) {
|
||||||
lastChart = new HSSFChart((ChartRecord)r);
|
lastChart = new HSSFChart((ChartRecord)r);
|
||||||
|
@ -155,6 +155,7 @@ public final class HSSFChart {
|
||||||
if(r instanceof SeriesRecord) {
|
if(r instanceof SeriesRecord) {
|
||||||
HSSFSeries series = lastChart.new HSSFSeries( (SeriesRecord)r );
|
HSSFSeries series = lastChart.new HSSFSeries( (SeriesRecord)r );
|
||||||
lastChart.series.add(series);
|
lastChart.series.add(series);
|
||||||
|
lastSeries = series;
|
||||||
}
|
}
|
||||||
if(r instanceof ChartTitleFormatRecord) {
|
if(r instanceof ChartTitleFormatRecord) {
|
||||||
lastChart.chartTitleFormat =
|
lastChart.chartTitleFormat =
|
||||||
|
@ -173,6 +174,13 @@ public final class HSSFChart {
|
||||||
lastChart.chartTitleText = str;
|
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[])
|
return (HSSFChart[])
|
||||||
|
@ -229,6 +237,35 @@ public final class HSSFChart {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 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 )
|
private SeriesIndexRecord createSeriesIndexRecord( int index )
|
||||||
{
|
{
|
||||||
SeriesIndexRecord r = new SeriesIndexRecord();
|
SeriesIndexRecord r = new SeriesIndexRecord();
|
||||||
|
@ -348,7 +385,7 @@ public final class HSSFChart {
|
||||||
return new UnknownRecord((short)0x00EC, data);
|
return new UnknownRecord((short)0x00EC, data);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void createAxisRecords( List records )
|
private void createAxisRecords( List<Record> records )
|
||||||
{
|
{
|
||||||
records.add( createAxisParentRecord() );
|
records.add( createAxisParentRecord() );
|
||||||
records.add( createBeginRecord() );
|
records.add( createBeginRecord() );
|
||||||
|
@ -867,11 +904,30 @@ public final class HSSFChart {
|
||||||
public class HSSFSeries {
|
public class HSSFSeries {
|
||||||
private SeriesRecord series;
|
private SeriesRecord series;
|
||||||
private SeriesTextRecord seriesTitleText;
|
private SeriesTextRecord seriesTitleText;
|
||||||
|
private LinkedDataRecord dataName;
|
||||||
|
private LinkedDataRecord dataValues;
|
||||||
|
private LinkedDataRecord dataCategoryLabels;
|
||||||
|
private LinkedDataRecord dataSecondaryCategoryLabels;
|
||||||
|
private int dataReaded = 0;
|
||||||
|
|
||||||
/* package */ HSSFSeries(SeriesRecord series) {
|
/* package */ HSSFSeries(SeriesRecord series) {
|
||||||
this.series = 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() {
|
public short getNumValues() {
|
||||||
return series.getNumValues();
|
return series.getNumValues();
|
||||||
}
|
}
|
||||||
|
@ -905,5 +961,40 @@ public final class HSSFChart {
|
||||||
throw new IllegalStateException("No series title found to change");
|
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;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue