ASCU_ALL/PrintPDF/MigraDoc.DocumentObjectModel/DocumentObjectModel.Shapes.Charts/Chart.cs
2021-05-25 17:00:45 +05:00

553 lines
17 KiB
C#

#region MigraDoc - Creating Documents on the Fly
//
// Authors:
// Stefan Lange
// Klaus Potzesny
// David Stephensen
//
// Copyright (c) 2001-2017 empira Software GmbH, Cologne Area (Germany)
//
// http://www.pdfsharp.com
// http://www.migradoc.com
// http://sourceforge.net/projects/pdfsharp
//
// Permission is hereby granted, free of charge, to any person obtaining a
// copy of this software and associated documentation files (the "Software"),
// to deal in the Software without restriction, including without limitation
// the rights to use, copy, modify, merge, publish, distribute, sublicense,
// and/or sell copies of the Software, and to permit persons to whom the
// Software is furnished to do so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included
// in all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
// THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
// DEALINGS IN THE SOFTWARE.
#endregion
using MigraDoc.DocumentObjectModel.publics;
using MigraDoc.DocumentObjectModel.Visitors;
namespace MigraDoc.DocumentObjectModel.Shapes.Charts
{
/// <summary>
/// Represents charts with different types.
/// </summary>
public class Chart : Shape, IVisitable
{
/// <summary>
/// Initializes a new instance of the Chart class.
/// </summary>
public Chart()
{
}
/// <summary>
/// Initializes a new instance of the Chart class with the specified parent.
/// </summary>
public Chart(DocumentObject parent) : base(parent) { }
/// <summary>
/// Initializes a new instance of the Chart class with the specified chart type.
/// </summary>
public Chart(ChartType type)
: this()
{
Type = type;
}
#region Methods
/// <summary>
/// Creates a deep copy of this object.
/// </summary>
public new Chart Clone()
{
return (Chart)DeepCopy();
}
/// <summary>
/// Implements the deep copy of the object.
/// </summary>
protected override object DeepCopy()
{
Chart chart = (Chart)base.DeepCopy();
if (chart._format != null)
{
chart._format = chart._format.Clone();
chart._format._parent = chart;
}
if (chart._xAxis != null)
{
chart._xAxis = chart._xAxis.Clone();
chart._xAxis._parent = chart;
}
if (chart._yAxis != null)
{
chart._yAxis = chart._yAxis.Clone();
chart._yAxis._parent = chart;
}
if (chart._zAxis != null)
{
chart._zAxis = chart._zAxis.Clone();
chart._zAxis._parent = chart;
}
if (chart._seriesCollection != null)
{
chart._seriesCollection = chart._seriesCollection.Clone();
chart._seriesCollection._parent = chart;
}
if (chart._xValues != null)
{
chart._xValues = chart._xValues.Clone();
chart._xValues._parent = chart;
}
if (chart._headerArea != null)
{
chart._headerArea = chart._headerArea.Clone();
chart._headerArea._parent = chart;
}
if (chart._bottomArea != null)
{
chart._bottomArea = chart._bottomArea.Clone();
chart._bottomArea._parent = chart;
}
if (chart._topArea != null)
{
chart._topArea = chart._topArea.Clone();
chart._topArea._parent = chart;
}
if (chart._footerArea != null)
{
chart._footerArea = chart._footerArea.Clone();
chart._footerArea._parent = chart;
}
if (chart._leftArea != null)
{
chart._leftArea = chart._leftArea.Clone();
chart._leftArea._parent = chart;
}
if (chart._rightArea != null)
{
chart._rightArea = chart._rightArea.Clone();
chart._rightArea._parent = chart;
}
if (chart._plotArea != null)
{
chart._plotArea = chart._plotArea.Clone();
chart._plotArea._parent = chart;
}
if (chart._dataLabel != null)
{
chart._dataLabel = chart._dataLabel.Clone();
chart._dataLabel._parent = chart;
}
return chart;
}
#endregion
#region Properties
/// <summary>
/// Gets or sets the base type of the chart.
/// ChartType of the series can be overwritten.
/// </summary>
public ChartType Type
{
get { return (ChartType)_type.Value; }
set { _type.Value = (int)value; }
}
[DV(Type = typeof(ChartType))]
public NEnum _type = NEnum.NullValue(typeof(ChartType));
/// <summary>
/// Gets or sets the default style name of the whole chart.
/// </summary>
public string Style
{
get { return _style.Value; }
set { _style.Value = value; }
}
[DV]
public NString _style = NString.NullValue;
/// <summary>
/// Gets the default paragraph format of the whole chart.
/// </summary>
public ParagraphFormat Format
{
get { return _format ?? (_format = new ParagraphFormat(this)); }
set
{
SetParent(value);
_format = value;
}
}
[DV]
public ParagraphFormat _format;
/// <summary>
/// Gets the X-Axis of the Chart.
/// </summary>
public Axis XAxis
{
get { return _xAxis ?? (_xAxis = new Axis(this)); }
set
{
SetParent(value);
_xAxis = value;
}
}
[DV]
public Axis _xAxis;
/// <summary>
/// Gets the Y-Axis of the Chart.
/// </summary>
public Axis YAxis
{
get { return _yAxis ?? (_yAxis = new Axis(this)); }
set
{
SetParent(value);
_yAxis = value;
}
}
[DV]
public Axis _yAxis;
/// <summary>
/// Gets the Z-Axis of the Chart.
/// </summary>
public Axis ZAxis
{
get { return _zAxis ?? (_zAxis = new Axis(this)); }
set
{
SetParent(value);
_zAxis = value;
}
}
[DV]
public Axis _zAxis;
/// <summary>
/// Gets the collection of the data series.
/// </summary>
public SeriesCollection SeriesCollection
{
get { return _seriesCollection ?? (_seriesCollection = new SeriesCollection(this)); }
set
{
SetParent(value);
_seriesCollection = value;
}
}
[DV(ItemType = typeof(Series))]
public SeriesCollection _seriesCollection;
/// <summary>
/// Gets the collection of the values written on the X-Axis.
/// </summary>
public XValues XValues
{
get { return _xValues ?? (_xValues = new XValues(this)); }
set
{
SetParent(value);
_xValues = value;
}
}
[DV(ItemType = typeof(Series))]
public XValues _xValues;
/// <summary>
/// Gets the header area of the chart.
/// </summary>
public TextArea HeaderArea
{
get { return _headerArea ?? (_headerArea = new TextArea(this)); }
set
{
SetParent(value);
_headerArea = value;
}
}
[DV]
public TextArea _headerArea;
/// <summary>
/// Gets the bottom area of the chart.
/// </summary>
public TextArea BottomArea
{
get { return _bottomArea ?? (_bottomArea = new TextArea(this)); }
set
{
SetParent(value);
_bottomArea = value;
}
}
[DV]
public TextArea _bottomArea;
/// <summary>
/// Gets the top area of the chart.
/// </summary>
public TextArea TopArea
{
get { return _topArea ?? (_topArea = new TextArea(this)); }
set
{
SetParent(value);
_topArea = value;
}
}
[DV]
public TextArea _topArea;
/// <summary>
/// Gets the footer area of the chart.
/// </summary>
public TextArea FooterArea
{
get { return _footerArea ?? (_footerArea = new TextArea(this)); }
set
{
SetParent(value);
_footerArea = value;
}
}
[DV]
public TextArea _footerArea;
/// <summary>
/// Gets the left area of the chart.
/// </summary>
public TextArea LeftArea
{
get { return _leftArea ?? (_leftArea = new TextArea(this)); }
set
{
SetParent(value);
_leftArea = value;
}
}
[DV]
public TextArea _leftArea;
/// <summary>
/// Gets the right area of the chart.
/// </summary>
public TextArea RightArea
{
get { return _rightArea ?? (_rightArea = new TextArea(this)); }
set
{
SetParent(value);
_rightArea = value;
}
}
[DV]
public TextArea _rightArea;
/// <summary>
/// Gets the plot (drawing) area of the chart.
/// </summary>
public PlotArea PlotArea
{
get { return _plotArea ?? (_plotArea = new PlotArea(this)); }
set
{
SetParent(value);
_plotArea = value;
}
}
[DV]
public PlotArea _plotArea;
/// <summary>
/// Gets or sets a value defining how blanks in the data series should be shown.
/// </summary>
public BlankType DisplayBlanksAs
{
get { return (BlankType)_displayBlanksAs.Value; }
set { _displayBlanksAs.Value = (int)value; }
}
[DV(Type = typeof(BlankType))]
public NEnum _displayBlanksAs = NEnum.NullValue(typeof(BlankType));
/// <summary>
/// Gets or sets whether XAxis Labels should be merged.
/// </summary>
public bool PivotChart
{
get { return _pivotChart.Value; }
set { _pivotChart.Value = value; }
}
[DV]
public NBool _pivotChart = NBool.NullValue;
/// <summary>
/// Gets the DataLabel of the chart.
/// </summary>
public DataLabel DataLabel
{
get { return _dataLabel ?? (_dataLabel = new DataLabel(this)); }
set
{
SetParent(value);
_dataLabel = value;
}
}
[DV]
public DataLabel _dataLabel;
/// <summary>
/// Gets or sets whether the chart has a DataLabel.
/// </summary>
public bool HasDataLabel
{
get { return _hasDataLabel.Value; }
set { _hasDataLabel.Value = value; }
}
[DV]
public NBool _hasDataLabel = NBool.NullValue;
#endregion
/// <summary>
/// Determines the type of the given axis.
/// </summary>
public string CheckAxis(Axis axis)
{
if ((_xAxis != null) && (axis == _xAxis))
return "xaxis";
if ((_yAxis != null) && (axis == _yAxis))
return "yaxis";
if ((_zAxis != null) && (axis == _zAxis))
return "zaxis";
return "";
}
/// <summary>
/// Determines the type of the given textarea.
/// </summary>
public string CheckTextArea(TextArea textArea)
{
if ((_headerArea != null) && (textArea == _headerArea))
return "headerarea";
if ((_footerArea != null) && (textArea == _footerArea))
return "footerarea";
if ((_leftArea != null) && (textArea == _leftArea))
return "leftarea";
if ((_rightArea != null) && (textArea == _rightArea))
return "rightarea";
if ((_topArea != null) && (textArea == _topArea))
return "toparea";
if ((_bottomArea != null) && (textArea == _bottomArea))
return "bottomarea";
return "";
}
#region public
/// <summary>
/// Converts Chart into DDL.
/// </summary>
public override void Serialize(Serializer serializer)
{
serializer.WriteLine("\\chart(" + Type + ")");
int pos = serializer.BeginAttributes();
base.Serialize(serializer);
if (!_displayBlanksAs.IsNull)
serializer.WriteSimpleAttribute("DisplayBlanksAs", DisplayBlanksAs);
if (!_pivotChart.IsNull)
serializer.WriteSimpleAttribute("PivotChart", PivotChart);
if (!_hasDataLabel.IsNull)
serializer.WriteSimpleAttribute("HasDataLabel", HasDataLabel);
if (!_style.IsNull)
serializer.WriteSimpleAttribute("Style", Style);
if (!IsNull("Format"))
_format.Serialize(serializer, "Format", null);
if (!IsNull("DataLabel"))
_dataLabel.Serialize(serializer);
serializer.EndAttributes(pos);
serializer.BeginContent();
if (!IsNull("PlotArea"))
_plotArea.Serialize(serializer);
if (!IsNull("HeaderArea"))
_headerArea.Serialize(serializer);
if (!IsNull("FooterArea"))
_footerArea.Serialize(serializer);
if (!IsNull("TopArea"))
_topArea.Serialize(serializer);
if (!IsNull("BottomArea"))
_bottomArea.Serialize(serializer);
if (!IsNull("LeftArea"))
_leftArea.Serialize(serializer);
if (!IsNull("RightArea"))
_rightArea.Serialize(serializer);
if (!IsNull("XAxis"))
_xAxis.Serialize(serializer);
if (!IsNull("YAxis"))
_yAxis.Serialize(serializer);
if (!IsNull("ZAxis"))
_zAxis.Serialize(serializer);
if (!IsNull("SeriesCollection"))
_seriesCollection.Serialize(serializer);
if (!IsNull("XValues"))
_xValues.Serialize(serializer);
serializer.EndContent();
}
/// <summary>
/// Allows the visitor object to visit the document object and its child objects.
/// </summary>
void IVisitable.AcceptVisitor(DocumentObjectVisitor visitor, bool visitChildren)
{
visitor.VisitChart(this);
if (visitChildren)
{
if (_bottomArea != null)
((IVisitable)_bottomArea).AcceptVisitor(visitor, true);
if (_footerArea != null)
((IVisitable)_footerArea).AcceptVisitor(visitor, true);
if (_headerArea != null)
((IVisitable)_headerArea).AcceptVisitor(visitor, true);
if (_leftArea != null)
((IVisitable)_leftArea).AcceptVisitor(visitor, true);
if (_rightArea != null)
((IVisitable)_rightArea).AcceptVisitor(visitor, true);
if (_topArea != null)
((IVisitable)_topArea).AcceptVisitor(visitor, true);
}
}
/// <summary>
/// Returns the meta object of this instance.
/// </summary>
public override Meta Meta
{
get { return _meta ?? (_meta = new Meta(typeof(Chart))); }
}
static Meta _meta;
#endregion
}
}