mirror of
https://github.com/ONLYOFFICE/core.git
synced 2026-04-07 13:55:33 +08:00
1180 lines
42 KiB
C++
1180 lines
42 KiB
C++
/*
|
|
* (c) Copyright Ascensio System SIA 2010-2017
|
|
*
|
|
* This program is a free software product. You can redistribute it and/or
|
|
* modify it under the terms of the GNU Affero General Public License (AGPL)
|
|
* version 3 as published by the Free Software Foundation. In accordance with
|
|
* Section 7(a) of the GNU AGPL its Section 15 shall be amended to the effect
|
|
* that Ascensio System SIA expressly excludes the warranty of non-infringement
|
|
* of any third-party rights.
|
|
*
|
|
* This program is distributed WITHOUT ANY WARRANTY; without even the implied
|
|
* warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. For
|
|
* details, see the GNU AGPL at: http://www.gnu.org/licenses/agpl-3.0.html
|
|
*
|
|
* You can contact Ascensio System SIA at Lubanas st. 125a-25, Riga, Latvia,
|
|
* EU, LV-1021.
|
|
*
|
|
* The interactive user interfaces in modified source and object code versions
|
|
* of the Program must display Appropriate Legal Notices, as required under
|
|
* Section 5 of the GNU AGPL version 3.
|
|
*
|
|
* Pursuant to Section 7(b) of the License you must retain the original Product
|
|
* logo when distributing the program. Pursuant to Section 7(e) we decline to
|
|
* grant you any rights under trademark law for use of our trademarks.
|
|
*
|
|
* All the Product's GUI elements, including illustrations and icon sets, as
|
|
* well as technical writing content are licensed under the terms of the
|
|
* Creative Commons Attribution-ShareAlike 4.0 International. See the License
|
|
* terms at http://creativecommons.org/licenses/by-sa/4.0/legalcode
|
|
*
|
|
*/
|
|
|
|
#include "Converter.h"
|
|
#include "../utils.h"
|
|
|
|
#include "XlsxConverter.h"
|
|
#include "DocxConverter.h"
|
|
|
|
#include "../OdfFormat/odf_conversion_context.h"
|
|
|
|
#include "../OdfFormat/odf_text_context.h"
|
|
#include "../OdfFormat/odf_drawing_context.h"
|
|
|
|
#include "../OdfFormat/style_text_properties.h"
|
|
#include "../OdfFormat/style_paragraph_properties.h"
|
|
|
|
#include "../../../Common/DocxFormat/Source/XlsxFormat/Xlsx.h"
|
|
|
|
|
|
namespace Oox2Odf
|
|
{
|
|
void OoxConverter::convert(OOX::Spreadsheet::CT_ChartSpace *oox_chart)
|
|
{
|
|
if (!oox_chart)return;
|
|
|
|
convert(oox_chart->m_externalData);
|
|
|
|
convert(oox_chart->m_oSpPr.GetPointer());
|
|
convert(oox_chart->m_oTxPr.GetPointer());
|
|
|
|
convert(oox_chart->m_chart->m_title);
|
|
convert(oox_chart->m_chart->m_legend);
|
|
|
|
odf_context()->chart_context()->start_plot_area();
|
|
{
|
|
convert(oox_chart->m_chart->m_plotArea);
|
|
|
|
bool chart3D = (oox_chart->m_chart->m_view3D) ? true : false;
|
|
convert(oox_chart->m_chart->m_floor, 1, chart3D);
|
|
if (chart3D) convert(oox_chart->m_chart->m_backWall, 2, chart3D);
|
|
//convert(oox_chart->m_chart->m_sizeWall, 3, chart3D);
|
|
}
|
|
odf_context()->chart_context()->end_plot_area();
|
|
}
|
|
|
|
//void OoxConverter::convert(OOX::Spreadsheet::CRichText* rich)
|
|
//{
|
|
// if (rich == NULL)return;
|
|
//
|
|
// odf_context()->chart_context()->start_text();
|
|
// OoxConverter::convert(rich->m_oBodyPr.GetPointer());
|
|
//
|
|
// for (size_t i = 0; i < rich->m_arrItems.size();i++)
|
|
// {
|
|
// OoxConverter::convert(rich->m_arrItems[i]);
|
|
// }
|
|
// odf_context()->chart_context()->end_text();
|
|
//}
|
|
//void OoxConverter::convert(OOX::Spreadsheet::CTextProperties* txPr)
|
|
//{
|
|
// if (txPr == NULL)return;
|
|
//
|
|
// odf_context()->chart_context()->start_text();
|
|
// OoxConverter::convert(txPr->m_oBodyPr.GetPointer());
|
|
//
|
|
// for (size_t i = 0; i < txPr->m_arrItems.size();i++)
|
|
// {
|
|
// OoxConverter::convert(txPr->m_arrItems[i]);
|
|
// }
|
|
// odf_context()->chart_context()->end_text();
|
|
//}
|
|
void OoxConverter::convert(OOX::Spreadsheet::CT_Tx* ct_tx)
|
|
{
|
|
if (ct_tx == NULL)return;
|
|
|
|
convert(ct_tx->m_oRich.GetPointer());
|
|
}
|
|
void OoxConverter::convert(OOX::Spreadsheet::CT_Layout* ct_layout)
|
|
{
|
|
if (ct_layout == NULL)return;
|
|
if (ct_layout->m_manualLayout == NULL)return;
|
|
|
|
int m_xMode=0, m_yMode=0, m_wMode=0,m_hMode=0;
|
|
|
|
if (ct_layout->m_manualLayout->m_xMode && ct_layout->m_manualLayout->m_xMode->m_val) m_xMode = *ct_layout->m_manualLayout->m_xMode->m_val;
|
|
if (ct_layout->m_manualLayout->m_yMode && ct_layout->m_manualLayout->m_yMode->m_val) m_yMode = *ct_layout->m_manualLayout->m_yMode->m_val;
|
|
if (ct_layout->m_manualLayout->m_hMode && ct_layout->m_manualLayout->m_hMode->m_val) m_hMode = *ct_layout->m_manualLayout->m_hMode->m_val;
|
|
if (ct_layout->m_manualLayout->m_wMode && ct_layout->m_manualLayout->m_wMode->m_val) m_wMode = *ct_layout->m_manualLayout->m_wMode->m_val;
|
|
|
|
if (ct_layout->m_manualLayout->m_x) odf_context()->chart_context()->set_layout_x(ct_layout->m_manualLayout->m_x->m_val,m_xMode);
|
|
if (ct_layout->m_manualLayout->m_y) odf_context()->chart_context()->set_layout_y(ct_layout->m_manualLayout->m_y->m_val,m_yMode);
|
|
if (ct_layout->m_manualLayout->m_w) odf_context()->chart_context()->set_layout_w(ct_layout->m_manualLayout->m_w->m_val,m_wMode);
|
|
if (ct_layout->m_manualLayout->m_h) odf_context()->chart_context()->set_layout_h(ct_layout->m_manualLayout->m_h->m_val,m_hMode);
|
|
}
|
|
|
|
void OoxConverter::convert(OOX::Spreadsheet::CT_Title* ct_title)
|
|
{
|
|
if (ct_title == NULL)return;
|
|
|
|
odf_context()->chart_context()->start_title();
|
|
convert(ct_title->m_oSpPr.GetPointer());
|
|
convert(ct_title->m_layout);
|
|
convert(ct_title->m_oTxPr.GetPointer());
|
|
///////////////////////////////
|
|
convert(ct_title->m_tx);
|
|
odf_context()->chart_context()->end_element();
|
|
}
|
|
void OoxConverter::convert(OOX::Spreadsheet::CT_Legend* ct_legend)
|
|
{
|
|
if (ct_legend == NULL)return;
|
|
|
|
odf_context()->chart_context()->start_legend();
|
|
convert(ct_legend->m_oSpPr.GetPointer());
|
|
convert(ct_legend->m_layout);
|
|
if ((ct_legend->m_legendPos) && (ct_legend->m_legendPos->m_val))
|
|
odf_context()->chart_context()->set_legend_position(*ct_legend->m_legendPos->m_val);
|
|
|
|
convert(ct_legend->m_oTxPr.GetPointer());
|
|
if (ct_legend->m_legendEntry.size() > 0)
|
|
{
|
|
convert(ct_legend->m_legendEntry[0]); // в odf_writer нет в легенде множественности стилей
|
|
}
|
|
//////////////////////
|
|
odf_context()->chart_context()->end_element();
|
|
}
|
|
void OoxConverter::convert(OOX::Spreadsheet::CT_LegendEntry* ct_legend)
|
|
{
|
|
if (ct_legend == NULL)return;
|
|
|
|
convert(ct_legend->m_oTxPr.GetPointer());
|
|
}
|
|
void OoxConverter::convert(OOX::Spreadsheet::CT_PlotArea* ct_plotArea)
|
|
{
|
|
if (ct_plotArea == NULL)return;
|
|
|
|
bool chart3D = false;
|
|
|
|
convert(ct_plotArea->m_layout);
|
|
///////////////////////
|
|
for (size_t i = 0; i < ct_plotArea->m_Items1.size(); i++)
|
|
{
|
|
if (!ct_plotArea->m_ItemsElementName1[i]) continue;
|
|
switch(*ct_plotArea->m_ItemsElementName1[i])
|
|
{
|
|
case OOX::Spreadsheet::itemschoicetype6CATAX: convert((OOX::Spreadsheet::CT_CatAx*)ct_plotArea->m_Items1[i]);break;
|
|
case OOX::Spreadsheet::itemschoicetype6DATEAX: convert((OOX::Spreadsheet::CT_DateAx*)ct_plotArea->m_Items1[i]);break;
|
|
case OOX::Spreadsheet::itemschoicetype6SERAX: convert((OOX::Spreadsheet::CT_SerAx*)ct_plotArea->m_Items1[i]);break;
|
|
case OOX::Spreadsheet::itemschoicetype6VALAX: convert((OOX::Spreadsheet::CT_ValAx*)ct_plotArea->m_Items1[i]);break;
|
|
}
|
|
}
|
|
for (size_t i=0; i< ct_plotArea->m_Items.size(); i++)//
|
|
{
|
|
if (!ct_plotArea->m_ItemsElementName0[i]) continue;
|
|
switch(*ct_plotArea->m_ItemsElementName0[i])
|
|
{
|
|
case OOX::Spreadsheet::itemschoicetype5AREA3DCHART: convert((OOX::Spreadsheet::CT_Area3DChart*) ct_plotArea->m_Items[i]); chart3D = true; break;
|
|
case OOX::Spreadsheet::itemschoicetype5AREACHART: convert((OOX::Spreadsheet::CT_AreaChart*) ct_plotArea->m_Items[i]);break;
|
|
case OOX::Spreadsheet::itemschoicetype5BAR3DCHART: convert((OOX::Spreadsheet::CT_Bar3DChart*) ct_plotArea->m_Items[i]); chart3D = true; break;
|
|
case OOX::Spreadsheet::itemschoicetype5BARCHART: convert((OOX::Spreadsheet::CT_BarChart*) ct_plotArea->m_Items[i]);break;
|
|
case OOX::Spreadsheet::itemschoicetype5BUBBLECHART: convert((OOX::Spreadsheet::CT_BubbleChart*) ct_plotArea->m_Items[i]);break;
|
|
case OOX::Spreadsheet::itemschoicetype5DOUGHNUTCHART: convert((OOX::Spreadsheet::CT_DoughnutChart*) ct_plotArea->m_Items[i]);break;
|
|
case OOX::Spreadsheet::itemschoicetype5LINE3DCHART: convert((OOX::Spreadsheet::CT_Line3DChart*) ct_plotArea->m_Items[i]); chart3D = true; break;
|
|
case OOX::Spreadsheet::itemschoicetype5LINECHART: convert((OOX::Spreadsheet::CT_LineChart*) ct_plotArea->m_Items[i]);break;
|
|
case OOX::Spreadsheet::itemschoicetype5OFPIECHART: convert((OOX::Spreadsheet::CT_OfPieChart*) ct_plotArea->m_Items[i]);break;
|
|
case OOX::Spreadsheet::itemschoicetype5PIE3DCHART: convert((OOX::Spreadsheet::CT_Pie3DChart*) ct_plotArea->m_Items[i]); chart3D = true; break;
|
|
case OOX::Spreadsheet::itemschoicetype5PIECHART: convert((OOX::Spreadsheet::CT_PieChart*) ct_plotArea->m_Items[i]);break;
|
|
case OOX::Spreadsheet::itemschoicetype5RADARCHART: convert((OOX::Spreadsheet::CT_RadarChart*) ct_plotArea->m_Items[i]);break;
|
|
case OOX::Spreadsheet::itemschoicetype5SCATTERCHART: convert((OOX::Spreadsheet::CT_ScatterChart*) ct_plotArea->m_Items[i]);break;
|
|
case OOX::Spreadsheet::itemschoicetype5STOCKCHART: convert((OOX::Spreadsheet::CT_StockChart*) ct_plotArea->m_Items[i]);break;
|
|
case OOX::Spreadsheet::itemschoicetype5SURFACE3DCHART: convert((OOX::Spreadsheet::CT_Surface3DChart*) ct_plotArea->m_Items[i]); chart3D = true; break;
|
|
case OOX::Spreadsheet::itemschoicetype5SURFACECHART: convert((OOX::Spreadsheet::CT_SurfaceChart*) ct_plotArea->m_Items[i]);break;
|
|
}
|
|
}
|
|
if (ct_plotArea->m_dTable)
|
|
{
|
|
}
|
|
if (chart3D == false)
|
|
{
|
|
odf_context()->chart_context()->start_wall();
|
|
{
|
|
convert(ct_plotArea->m_oSpPr.GetPointer());
|
|
}
|
|
odf_context()->chart_context()->end_element();
|
|
}
|
|
}
|
|
//////////////////////////////////////////////////////////////////////////////////////////////
|
|
void OoxConverter::convert(OOX::Spreadsheet::CT_CatAx* axis)
|
|
{
|
|
if (axis == NULL)return;
|
|
|
|
odf_context()->chart_context()->start_axis();
|
|
odf_context()->chart_context()->set_axis_dimension(1);
|
|
if (axis->m_axId && axis->m_axId->m_val)
|
|
odf_context()->chart_context()->set_axis_id(*axis->m_axId->m_val);
|
|
convert(axis->m_oSpPr.GetPointer());
|
|
if (axis->m_scaling)
|
|
{
|
|
if (axis->m_scaling->m_logBase)
|
|
odf_context()->chart_context()->set_axis_logarithmic(true);
|
|
if (axis->m_scaling->m_orientation && axis->m_scaling->m_orientation->m_val)
|
|
odf_context()->chart_context()->set_axis_orientation(*axis->m_scaling->m_orientation->m_val);
|
|
if (axis->m_scaling->m_min && axis->m_scaling->m_min->m_val) odf_context()->chart_context()->set_axis_min(*axis->m_scaling->m_min->m_val);
|
|
if (axis->m_scaling->m_max && axis->m_scaling->m_max->m_val) odf_context()->chart_context()->set_axis_max(*axis->m_scaling->m_max->m_val);
|
|
}
|
|
if (axis->m_majorTickMark && axis->m_majorTickMark->m_val)
|
|
odf_context()->chart_context()->set_axis_tick_major(*axis->m_majorTickMark->m_val);
|
|
|
|
if (axis->m_minorTickMark && axis->m_minorTickMark->m_val)
|
|
odf_context()->chart_context()->set_axis_tick_minor(*axis->m_minorTickMark->m_val);
|
|
|
|
if (axis->m_tickLblPos)
|
|
{
|
|
if (axis->m_tickLblPos->m_val)odf_context()->chart_context()->set_display_label_position(*axis->m_tickLblPos->m_val);
|
|
odf_context()->chart_context()->set_display_label(true);
|
|
}
|
|
if (axis->m_axPos && axis->m_axPos->m_val)
|
|
odf_context()->chart_context()->set_axis_position(*axis->m_axPos->m_val);
|
|
if (axis->m_tickLblPos && axis->m_tickLblPos->m_val)
|
|
odf_context()->chart_context()->set_axis_label_position(*axis->m_tickLblPos->m_val);
|
|
|
|
///////////////////
|
|
convert(axis->m_oTxPr.GetPointer());
|
|
convert(axis->m_title);
|
|
convert(axis->m_majorGridlines, 1);
|
|
convert(axis->m_minorGridlines, 2);
|
|
odf_context()->chart_context()->end_element();
|
|
}
|
|
void OoxConverter::convert(OOX::Spreadsheet::CT_DateAx* axis)
|
|
{
|
|
if (axis == NULL)return;
|
|
|
|
odf_context()->chart_context()->start_axis();
|
|
odf_context()->chart_context()->set_axis_dimension(1);
|
|
if (axis->m_axId && axis->m_axId->m_val)
|
|
odf_context()->chart_context()->set_axis_id(*axis->m_axId->m_val);
|
|
convert(axis->m_oSpPr.GetPointer());
|
|
if (axis->m_scaling)
|
|
{
|
|
if (axis->m_scaling->m_logBase)
|
|
odf_context()->chart_context()->set_axis_logarithmic(true);
|
|
if (axis->m_scaling->m_orientation && axis->m_scaling->m_orientation->m_val)
|
|
odf_context()->chart_context()->set_axis_orientation(*axis->m_scaling->m_orientation->m_val);
|
|
if (axis->m_scaling->m_min && axis->m_scaling->m_min->m_val) odf_context()->chart_context()->set_axis_min(*axis->m_scaling->m_min->m_val);
|
|
if (axis->m_scaling->m_max && axis->m_scaling->m_max->m_val) odf_context()->chart_context()->set_axis_max(*axis->m_scaling->m_max->m_val);
|
|
|
|
}
|
|
if (axis->m_majorTickMark && axis->m_majorTickMark->m_val)
|
|
odf_context()->chart_context()->set_axis_tick_major(*axis->m_majorTickMark->m_val);
|
|
|
|
if (axis->m_minorTickMark && axis->m_minorTickMark->m_val)
|
|
odf_context()->chart_context()->set_axis_tick_minor(*axis->m_minorTickMark->m_val);
|
|
|
|
if (axis->m_tickLblPos)
|
|
{
|
|
if (axis->m_tickLblPos->m_val)odf_context()->chart_context()->set_display_label_position(*axis->m_tickLblPos->m_val);
|
|
odf_context()->chart_context()->set_display_label(true);
|
|
}
|
|
if (axis->m_axPos && axis->m_axPos->m_val)
|
|
odf_context()->chart_context()->set_axis_position(*axis->m_axPos->m_val);
|
|
//////////////////
|
|
convert(axis->m_oTxPr.GetPointer());
|
|
convert(axis->m_title);
|
|
convert(axis->m_majorGridlines, 1);
|
|
convert(axis->m_minorGridlines, 2);
|
|
odf_context()->chart_context()->end_element();
|
|
}
|
|
void OoxConverter::convert(OOX::Spreadsheet::CT_SerAx* axis)
|
|
{
|
|
if (axis == NULL)return;
|
|
|
|
odf_context()->chart_context()->start_axis();
|
|
odf_context()->chart_context()->set_axis_dimension(1);
|
|
if (axis->m_axId && axis->m_axId->m_val)
|
|
odf_context()->chart_context()->set_axis_id(*axis->m_axId->m_val);
|
|
convert(axis->m_oSpPr.GetPointer());
|
|
if (axis->m_scaling)
|
|
{
|
|
if (axis->m_scaling->m_logBase)
|
|
odf_context()->chart_context()->set_axis_logarithmic(true);
|
|
if (axis->m_scaling->m_orientation && axis->m_scaling->m_orientation->m_val)
|
|
odf_context()->chart_context()->set_axis_orientation(*axis->m_scaling->m_orientation->m_val);
|
|
if (axis->m_scaling->m_min && axis->m_scaling->m_min->m_val) odf_context()->chart_context()->set_axis_min(*axis->m_scaling->m_min->m_val);
|
|
if (axis->m_scaling->m_max && axis->m_scaling->m_max->m_val) odf_context()->chart_context()->set_axis_max(*axis->m_scaling->m_max->m_val);
|
|
}
|
|
if (axis->m_majorTickMark && axis->m_majorTickMark->m_val)
|
|
odf_context()->chart_context()->set_axis_tick_major(*axis->m_majorTickMark->m_val);
|
|
|
|
if (axis->m_minorTickMark && axis->m_minorTickMark->m_val)
|
|
odf_context()->chart_context()->set_axis_tick_minor(*axis->m_minorTickMark->m_val);
|
|
|
|
if (axis->m_tickLblPos)
|
|
{
|
|
if (axis->m_tickLblPos->m_val)odf_context()->chart_context()->set_display_label_position(*axis->m_tickLblPos->m_val);
|
|
odf_context()->chart_context()->set_display_label(true);
|
|
}
|
|
|
|
if (axis->m_axPos && axis->m_axPos->m_val)
|
|
odf_context()->chart_context()->set_axis_position(*axis->m_axPos->m_val);
|
|
///////////////////////////
|
|
convert(axis->m_oTxPr.GetPointer());
|
|
convert(axis->m_title);
|
|
convert(axis->m_majorGridlines, 1);
|
|
convert(axis->m_minorGridlines, 2);
|
|
odf_context()->chart_context()->end_element();
|
|
}
|
|
void OoxConverter::convert(OOX::Spreadsheet::CT_ValAx* axis)
|
|
{
|
|
if (axis == NULL)return;
|
|
|
|
odf_context()->chart_context()->start_axis();
|
|
odf_context()->chart_context()->set_axis_dimension(2);
|
|
if (axis->m_axId && axis->m_axId->m_val)
|
|
odf_context()->chart_context()->set_axis_id(*axis->m_axId->m_val);
|
|
convert(axis->m_oSpPr.GetPointer());
|
|
if (axis->m_scaling)
|
|
{
|
|
if (axis->m_scaling->m_logBase)
|
|
odf_context()->chart_context()->set_axis_logarithmic(true);
|
|
if (axis->m_scaling->m_orientation && axis->m_scaling->m_orientation->m_val)
|
|
odf_context()->chart_context()->set_axis_orientation(*axis->m_scaling->m_orientation->m_val);
|
|
if (axis->m_scaling->m_min && axis->m_scaling->m_min->m_val)odf_context()->chart_context()->set_axis_min(*axis->m_scaling->m_min->m_val);
|
|
if (axis->m_scaling->m_max && axis->m_scaling->m_max->m_val)odf_context()->chart_context()->set_axis_max(*axis->m_scaling->m_max->m_val);
|
|
}
|
|
if (axis->m_majorTickMark && axis->m_majorTickMark->m_val)
|
|
odf_context()->chart_context()->set_axis_tick_major(*axis->m_majorTickMark->m_val);
|
|
|
|
if (axis->m_minorTickMark && axis->m_minorTickMark->m_val)
|
|
odf_context()->chart_context()->set_axis_tick_minor(*axis->m_minorTickMark->m_val);
|
|
|
|
if (axis->m_tickLblPos)
|
|
{
|
|
if (axis->m_tickLblPos->m_val)odf_context()->chart_context()->set_display_label_position(*axis->m_tickLblPos->m_val);
|
|
odf_context()->chart_context()->set_display_label(true);
|
|
}
|
|
if (axis->m_axPos && axis->m_axPos->m_val)
|
|
odf_context()->chart_context()->set_axis_position(*axis->m_axPos->m_val);
|
|
/////////////////////////////
|
|
convert(axis->m_oTxPr.GetPointer());
|
|
convert(axis->m_title);
|
|
convert(axis->m_majorGridlines, 1);
|
|
convert(axis->m_minorGridlines, 2);
|
|
odf_context()->chart_context()->end_element();
|
|
}
|
|
////////////////////////////////////////////////////////////////////////////////////////////
|
|
void OoxConverter::convert(OOX::Spreadsheet::CT_ChartLines *line, int type)
|
|
{
|
|
if (line == NULL)return;
|
|
|
|
if (type <3)//grid lines
|
|
{
|
|
odf_context()->chart_context()->start_grid(type);
|
|
convert(line->m_oSpPr.GetPointer());
|
|
odf_context()->chart_context()->end_element();
|
|
}
|
|
//if (type == 3)//drop line
|
|
//{
|
|
// odf_context()->chart_context()->s
|
|
//}
|
|
if (type == 4)//Hi-Lo line
|
|
{
|
|
odf_context()->chart_context()->start_stock_range_line();
|
|
convert(line->m_oSpPr.GetPointer());
|
|
odf_context()->chart_context()->end_element();
|
|
}
|
|
}
|
|
|
|
void OoxConverter::convert(OOX::Spreadsheet::CT_Area3DChart *chart)
|
|
{
|
|
if (chart == NULL)return;
|
|
|
|
odf_context()->chart_context()->set_chart_type(L"area");
|
|
odf_context()->chart_context()->set_chart_3D(true);
|
|
|
|
convert (chart->m_dropLines, 3);
|
|
|
|
if (chart->m_grouping && chart->m_grouping->m_val)
|
|
odf_context()->chart_context()->set_chart_grouping(*chart->m_grouping->m_val);
|
|
|
|
for (size_t i = 0; i < chart->m_ser.size(); i++)
|
|
{
|
|
convert(chart->m_ser[i]);
|
|
}
|
|
}
|
|
void OoxConverter::convert(OOX::Spreadsheet::CT_AreaChart *chart)
|
|
{
|
|
if (chart == NULL)return;
|
|
|
|
odf_context()->chart_context()->set_chart_type(L"area");
|
|
|
|
if (chart->m_grouping && chart->m_grouping->m_val)
|
|
odf_context()->chart_context()->set_chart_grouping(*chart->m_grouping->m_val);
|
|
|
|
convert (chart->m_dropLines, 3);
|
|
|
|
odf_context()->chart_context()->start_group_series();
|
|
convert(chart->m_dLbls);
|
|
|
|
for (size_t i=0; i < chart->m_ser.size(); i++)
|
|
{
|
|
convert(chart->m_ser[i]);
|
|
}
|
|
for (size_t i=0; i < chart->m_axId.size(); i++)
|
|
{
|
|
odf_context()->chart_context()->add_axis_group_series(*chart->m_axId[i]->m_val);
|
|
}
|
|
odf_context()->chart_context()->end_group_series();
|
|
}
|
|
void OoxConverter::convert(OOX::Spreadsheet::CT_Bar3DChart *chart)
|
|
{
|
|
if (chart == NULL)return;
|
|
|
|
odf_context()->chart_context()->set_chart_type(L"bar");
|
|
odf_context()->chart_context()->set_chart_3D(true);
|
|
|
|
if (chart->m_shape && chart->m_shape->m_val)
|
|
odf_context()->chart_context()->set_chart_bar_type(*chart->m_shape->m_val);
|
|
|
|
if (chart->m_grouping && chart->m_grouping->m_val)
|
|
odf_context()->chart_context()->set_chart_bar_grouping(*chart->m_grouping->m_val);
|
|
|
|
if (chart->m_barDir && chart->m_barDir->m_val)
|
|
odf_context()->chart_context()->set_chart_bar_direction(*chart->m_barDir->m_val);
|
|
|
|
if (chart->m_gapWidth && chart->m_gapWidth->m_val)
|
|
odf_context()->chart_context()->set_chart_bar_gap_width(*chart->m_gapWidth->m_val);
|
|
|
|
//if (chart->m_overlap && chart->m_overlap->m_val)
|
|
// odf_context()->chart_context()->set_chart_bar_overlap(*chart->m_overlap->m_val);
|
|
|
|
odf_context()->chart_context()->start_group_series();
|
|
convert(chart->m_dLbls);
|
|
|
|
for (size_t i = 0; i < chart->m_ser.size(); i++)
|
|
{
|
|
convert(chart->m_ser[i]);
|
|
}
|
|
for (size_t i = 0; i < chart->m_axId.size(); i++)
|
|
{
|
|
odf_context()->chart_context()->add_axis_group_series(*chart->m_axId[i]->m_val);
|
|
}
|
|
odf_context()->chart_context()->end_group_series();
|
|
}
|
|
void OoxConverter::convert(OOX::Spreadsheet::CT_BarChart *chart)
|
|
{
|
|
if (chart == NULL)return;
|
|
|
|
odf_context()->chart_context()->set_chart_type(L"bar");
|
|
|
|
if (chart->m_grouping && chart->m_grouping->m_val)
|
|
odf_context()->chart_context()->set_chart_bar_grouping(*chart->m_grouping->m_val);
|
|
|
|
if (chart->m_barDir && chart->m_barDir->m_val)
|
|
odf_context()->chart_context()->set_chart_bar_direction(*chart->m_barDir->m_val);
|
|
|
|
if (chart->m_gapWidth && chart->m_gapWidth->m_val)
|
|
odf_context()->chart_context()->set_chart_bar_gap_width(*chart->m_gapWidth->m_val);
|
|
|
|
if (chart->m_overlap && chart->m_overlap->m_val)
|
|
odf_context()->chart_context()->set_chart_bar_overlap(*chart->m_overlap->m_val);
|
|
|
|
odf_context()->chart_context()->start_group_series();
|
|
convert(chart->m_dLbls);
|
|
|
|
for (size_t i = 0; i < chart->m_ser.size(); i++)
|
|
{
|
|
convert(chart->m_ser[i]);
|
|
}
|
|
for (size_t i = 0; i < chart->m_axId.size(); i++)
|
|
{
|
|
odf_context()->chart_context()->add_axis_group_series(*chart->m_axId[i]->m_val);
|
|
}
|
|
odf_context()->chart_context()->end_group_series();
|
|
}
|
|
void OoxConverter::convert(OOX::Spreadsheet::CT_Line3DChart *chart)
|
|
{
|
|
odf_context()->chart_context()->set_chart_type(L"line");
|
|
odf_context()->chart_context()->set_chart_3D(true);
|
|
|
|
if (chart->m_grouping && chart->m_grouping->m_val)
|
|
odf_context()->chart_context()->set_chart_grouping(*chart->m_grouping->m_val);
|
|
|
|
convert (chart->m_dropLines, 3);
|
|
|
|
odf_context()->chart_context()->start_group_series();
|
|
convert(chart->m_dLbls);
|
|
for (size_t i = 0; i < chart->m_ser.size(); i++)
|
|
{
|
|
convert(chart->m_ser[i]);
|
|
}
|
|
for (size_t i = 0; i < chart->m_axId.size(); i++)
|
|
{
|
|
odf_context()->chart_context()->add_axis_group_series(*chart->m_axId[i]->m_val);
|
|
}
|
|
odf_context()->chart_context()->end_group_series();
|
|
}
|
|
void OoxConverter::convert(OOX::Spreadsheet::CT_LineChart *chart)
|
|
{
|
|
if (chart == NULL)return;
|
|
|
|
odf_context()->chart_context()->set_chart_type(L"line");
|
|
|
|
if (chart->m_grouping && chart->m_grouping->m_val)
|
|
odf_context()->chart_context()->set_chart_grouping(*chart->m_grouping->m_val);
|
|
|
|
if (chart->m_marker && chart->m_marker->m_val && (*chart->m_marker->m_val == true))
|
|
odf_context()->chart_context()->set_marker_type(12); //auto type
|
|
|
|
convert (chart->m_dropLines, 3);
|
|
|
|
odf_context()->chart_context()->start_group_series();
|
|
convert(chart->m_dLbls);
|
|
for (size_t i = 0; i < chart->m_ser.size(); i++)
|
|
{
|
|
convert(chart->m_ser[i]);
|
|
}
|
|
for (size_t i = 0; i < chart->m_axId.size(); i++)
|
|
{
|
|
odf_context()->chart_context()->add_axis_group_series(*chart->m_axId[i]->m_val);
|
|
}
|
|
odf_context()->chart_context()->end_group_series();
|
|
}
|
|
void OoxConverter::convert(OOX::Spreadsheet::CT_Pie3DChart *chart)
|
|
{
|
|
if (chart == NULL)return;
|
|
|
|
odf_context()->chart_context()->set_chart_type(L"circle");
|
|
odf_context()->chart_context()->set_chart_3D(true);
|
|
|
|
odf_context()->chart_context()->start_group_series();
|
|
convert(chart->m_dLbls);
|
|
for (size_t i = 0; i < chart->m_ser.size(); i++)
|
|
{
|
|
convert(chart->m_ser[i]);
|
|
}
|
|
//for (size_t i = 0; i < chart->m_axId.size(); i++)
|
|
//{
|
|
// odf_context()->chart_context()->add_axis_group_series(*chart->m_axId[i]->m_val);
|
|
//}
|
|
odf_context()->chart_context()->end_group_series();
|
|
}
|
|
void OoxConverter::convert(OOX::Spreadsheet::CT_PieChart *chart)
|
|
{
|
|
if (chart == NULL)return;
|
|
|
|
odf_context()->chart_context()->set_chart_type(L"circle");
|
|
|
|
odf_context()->chart_context()->start_group_series();
|
|
convert(chart->m_dLbls);
|
|
for (size_t i = 0; i < chart->m_ser.size(); i++)
|
|
{
|
|
convert(chart->m_ser[i]);
|
|
}
|
|
//for (size_t i = 0; i < chart->m_axId.size(); i++)
|
|
//{
|
|
// odf_context()->chart_context()->add_axis_group_series(*chart->m_axId[i]->m_val);
|
|
//}
|
|
odf_context()->chart_context()->end_group_series();
|
|
}
|
|
void OoxConverter::convert(OOX::Spreadsheet::CT_Surface3DChart *chart)
|
|
{
|
|
if (chart == NULL)return;
|
|
|
|
odf_context()->chart_context()->set_chart_type(L"surface");
|
|
odf_context()->chart_context()->set_chart_3D(true);
|
|
|
|
odf_context()->chart_context()->start_group_series();
|
|
for (size_t i = 0; i < chart->m_ser.size(); i++)
|
|
{
|
|
convert(chart->m_ser[i]);
|
|
}
|
|
for (size_t i = 0; i < chart->m_axId.size(); i++)
|
|
{
|
|
odf_context()->chart_context()->add_axis_group_series(*chart->m_axId[i]->m_val);
|
|
}
|
|
odf_context()->chart_context()->end_group_series();
|
|
}
|
|
void OoxConverter::convert(OOX::Spreadsheet::CT_SurfaceChart *chart)
|
|
{
|
|
if (chart == NULL)return;
|
|
|
|
odf_context()->chart_context()->set_chart_type(L"surface");
|
|
|
|
odf_context()->chart_context()->start_group_series();
|
|
for (size_t i = 0; i < chart->m_ser.size(); i++)
|
|
{
|
|
convert(chart->m_ser[i]);
|
|
}
|
|
for (size_t i = 0; i < chart->m_axId.size(); i++)
|
|
{
|
|
odf_context()->chart_context()->add_axis_group_series(*chart->m_axId[i]->m_val);
|
|
}
|
|
odf_context()->chart_context()->end_group_series();
|
|
}
|
|
void OoxConverter::convert(OOX::Spreadsheet::CT_BubbleChart *chart)
|
|
{
|
|
if (chart == NULL)return;
|
|
|
|
odf_context()->chart_context()->set_chart_type(L"bubble");
|
|
|
|
odf_context()->chart_context()->start_group_series();
|
|
convert(chart->m_dLbls);
|
|
for (size_t i = 0; i < chart->m_ser.size(); i++)
|
|
{
|
|
convert(chart->m_ser[i]);
|
|
}
|
|
for (size_t i = 0; i < chart->m_axId.size(); i++)
|
|
{
|
|
odf_context()->chart_context()->add_axis_group_series(*chart->m_axId[i]->m_val);
|
|
}
|
|
odf_context()->chart_context()->end_group_series();
|
|
}
|
|
void OoxConverter::convert(OOX::Spreadsheet::CT_DoughnutChart *chart)
|
|
{
|
|
if (chart == NULL)return;
|
|
|
|
odf_context()->chart_context()->set_chart_type(L"ring");
|
|
|
|
//m_holeSize
|
|
|
|
odf_context()->chart_context()->start_group_series();
|
|
convert(chart->m_dLbls);
|
|
for (size_t i = 0; i < chart->m_ser.size(); i++)
|
|
{
|
|
convert(chart->m_ser[i]);
|
|
}
|
|
odf_context()->chart_context()->end_group_series();
|
|
}
|
|
void OoxConverter::convert(OOX::Spreadsheet::CT_ScatterChart *chart)
|
|
{
|
|
if (chart == NULL)return;
|
|
|
|
odf_context()->chart_context()->set_chart_type(L"scatter");
|
|
convert(chart->m_dLbls);
|
|
if (chart->m_varyColors && chart->m_varyColors->m_val)
|
|
odf_context()->chart_context()->set_chart_colored(*chart->m_varyColors->m_val);
|
|
if (chart->m_scatterStyle && chart->m_scatterStyle->m_val)
|
|
odf_context()->chart_context()->set_chart_scatter_type(*chart->m_scatterStyle->m_val);
|
|
|
|
|
|
odf_context()->chart_context()->start_group_series();
|
|
for (size_t i = 0; i < chart->m_ser.size(); i++)
|
|
{
|
|
convert(chart->m_ser[i]);
|
|
}
|
|
for (size_t i = 0; i < chart->m_axId.size(); i++)
|
|
{
|
|
odf_context()->chart_context()->add_axis_group_series(*chart->m_axId[i]->m_val);
|
|
}
|
|
odf_context()->chart_context()->end_group_series();
|
|
}
|
|
void OoxConverter::convert(OOX::Spreadsheet::CT_RadarChart *chart)
|
|
{
|
|
if (chart == NULL)return;
|
|
|
|
odf_context()->chart_context()->set_chart_type(L"radar");
|
|
if (chart->m_radarStyle && chart->m_radarStyle->m_val)
|
|
odf_context()->chart_context()->set_chart_radar_type(*chart->m_radarStyle->m_val);
|
|
//odf_context()->chart_context()->set_chart_grouping(2);???
|
|
|
|
odf_context()->chart_context()->start_group_series();
|
|
convert(chart->m_dLbls);
|
|
for (size_t i = 0; i < chart->m_ser.size(); i++)
|
|
{
|
|
convert(chart->m_ser[i]);
|
|
}
|
|
//for (size_t i = 0; i < chart->m_axId.size(); i++)
|
|
//{
|
|
// odf_context()->chart_context()->add_axis_group_series(**chart->m_axId[i]->m_val->m_val);
|
|
//}
|
|
odf_context()->chart_context()->end_group_series();
|
|
}
|
|
void OoxConverter::convert(OOX::Spreadsheet::CT_StockChart *chart)
|
|
{
|
|
if (chart == NULL)return;
|
|
|
|
odf_context()->chart_context()->set_chart_type(L"stock");
|
|
|
|
odf_context()->chart_context()->start_group_series();
|
|
convert(chart->m_dLbls);
|
|
for (size_t i = 0; i < chart->m_ser.size(); i++)
|
|
{
|
|
convert(chart->m_ser[i]);
|
|
}
|
|
for (size_t i = 0; i < chart->m_axId.size(); i++)
|
|
{
|
|
odf_context()->chart_context()->add_axis_group_series(*chart->m_axId[i]->m_val);
|
|
}
|
|
convert (chart->m_dropLines ,3);
|
|
if (chart->m_upDownBars)
|
|
{
|
|
odf_context()->chart_context()->set_chart_stock_candle_stick(true);
|
|
|
|
std::wstring gap_width;
|
|
if (chart->m_upDownBars->m_gapWidth && chart->m_upDownBars->m_gapWidth->m_val)
|
|
{
|
|
gap_width = *chart->m_upDownBars->m_gapWidth->m_val;
|
|
/*odf_context()->chart_context()->set_chart_bar_gap_width(gap_width);*/
|
|
}
|
|
|
|
if (chart->m_upDownBars->m_upBars)
|
|
{
|
|
odf_context()->chart_context()->start_stock_gain_marker();
|
|
convert(chart->m_upDownBars->m_upBars->m_oSpPr.GetPointer());
|
|
if (gap_width.length() > 0)
|
|
odf_context()->chart_context()->set_chart_bar_gap_width(gap_width);
|
|
odf_context()->chart_context()->end_element();
|
|
}
|
|
if (chart->m_upDownBars->m_downBars)
|
|
{
|
|
odf_context()->chart_context()->start_stock_loss_marker();
|
|
convert(chart->m_upDownBars->m_downBars->m_oSpPr.GetPointer());
|
|
if (gap_width.length() > 0)
|
|
odf_context()->chart_context()->set_chart_bar_gap_width(gap_width);
|
|
odf_context()->chart_context()->end_element();
|
|
}
|
|
}
|
|
convert (chart->m_hiLowLines, 4);
|
|
odf_context()->chart_context()->end_group_series();
|
|
}
|
|
void OoxConverter::convert(OOX::Spreadsheet::CT_OfPieChart *chart)
|
|
{
|
|
if (chart == NULL)return;
|
|
|
|
odf_context()->chart_context()->set_chart_type(L"circle");
|
|
|
|
odf_context()->chart_context()->start_group_series();
|
|
convert(chart->m_dLbls);
|
|
for (size_t i = 0; i < chart->m_ser.size(); i++)
|
|
{
|
|
convert(chart->m_ser[i]);
|
|
}
|
|
//for (size_t i = 0; i < chart->m_axId.size(); i++)
|
|
//{
|
|
// odf_context()->chart_context()->add_axis_group_series(*chart->m_axId[i]->m_val);
|
|
//}
|
|
odf_context()->chart_context()->end_group_series();
|
|
}
|
|
void OoxConverter::convert(OOX::Spreadsheet::CT_AreaSer* ser)
|
|
{
|
|
odf_context()->chart_context()->start_series(L"area");
|
|
convert(ser->m_oSpPr.GetPointer());
|
|
convert(ser->m_dLbls);
|
|
|
|
convert(ser->m_cat, 1);
|
|
convert(ser->m_val);
|
|
|
|
convert(ser->m_tx);
|
|
if (ser->m_dPt.size() > 0)
|
|
{
|
|
convert(NULL, ser->m_dPt);
|
|
}
|
|
odf_context()->chart_context()->end_series();
|
|
}
|
|
void OoxConverter::convert(OOX::Spreadsheet::CT_BubbleSer* ser)
|
|
{
|
|
if (ser == NULL)return;
|
|
|
|
odf_context()->chart_context()->start_series(L"bubble");
|
|
convert(ser->m_oSpPr.GetPointer());
|
|
convert(ser->m_dLbls);
|
|
convert(ser->m_xVal, 2);
|
|
convert(ser->m_tx);
|
|
if (ser->m_dPt.size() > 0)
|
|
{
|
|
convert(NULL, ser->m_dPt);
|
|
}
|
|
odf_context()->chart_context()->end_series();
|
|
|
|
odf_context()->chart_context()->start_series(L"bubble");
|
|
convert(ser->m_oSpPr.GetPointer());
|
|
convert(ser->m_dLbls);
|
|
convert(ser->m_yVal);
|
|
convert(ser->m_tx);
|
|
if (ser->m_dPt.size() > 0)
|
|
{
|
|
convert(NULL, ser->m_dPt);
|
|
}
|
|
odf_context()->chart_context()->end_series();
|
|
|
|
odf_context()->chart_context()->start_series(L"bubble");
|
|
convert(ser->m_oSpPr.GetPointer());
|
|
convert(ser->m_dLbls);
|
|
convert(ser->m_bubbleSize);
|
|
convert(ser->m_tx);
|
|
if (ser->m_dPt.size() > 0)
|
|
{
|
|
convert(NULL, ser->m_dPt);
|
|
}
|
|
odf_context()->chart_context()->end_series();
|
|
}
|
|
void OoxConverter::convert(OOX::Spreadsheet::CT_SurfaceSer* ser)
|
|
{
|
|
if (ser == NULL)return;
|
|
|
|
odf_context()->chart_context()->start_series(L"surface");
|
|
convert(ser->m_oSpPr.GetPointer());
|
|
|
|
convert(ser->m_cat, 1);
|
|
convert(ser->m_val);
|
|
|
|
convert(ser->m_tx);
|
|
odf_context()->chart_context()->end_series();
|
|
}
|
|
void OoxConverter::convert(OOX::Spreadsheet::CT_PieSer* ser)
|
|
{
|
|
if (ser == NULL)return;
|
|
|
|
odf_context()->chart_context()->start_series(L"circle");
|
|
if (ser->m_explosion && ser->m_explosion->m_val)
|
|
odf_context()->chart_context()->set_series_pie_explosion(*ser->m_explosion->m_val);
|
|
convert(ser->m_oSpPr.GetPointer());
|
|
convert(ser->m_dLbls);
|
|
|
|
convert(ser->m_cat, 1);
|
|
convert(ser->m_val);
|
|
|
|
convert(ser->m_tx);
|
|
if (ser->m_dPt.size() > 0)
|
|
{
|
|
convert(NULL, ser->m_dPt);
|
|
}
|
|
odf_context()->chart_context()->end_series();
|
|
}
|
|
void OoxConverter::convert(OOX::Spreadsheet::CT_BarSer* ser)
|
|
{
|
|
if (ser == NULL)return;
|
|
|
|
odf_context()->chart_context()->start_series(L"bar");
|
|
convert(ser->m_oSpPr.GetPointer());
|
|
convert(ser->m_dLbls);
|
|
|
|
convert(ser->m_cat, 1);
|
|
convert(ser->m_val);
|
|
|
|
convert(ser->m_tx);
|
|
if (ser->m_dPt.size() > 0)
|
|
{
|
|
convert(NULL, ser->m_dPt);
|
|
}
|
|
if (ser->m_shape && ser->m_shape->m_val)
|
|
odf_context()->chart_context()->set_chart_bar_type(*ser->m_shape->m_val);
|
|
else
|
|
odf_context()->chart_context()->set_chart_bar_type(-1);
|
|
//m_trendline;
|
|
//m_errBars
|
|
odf_context()->chart_context()->end_series();
|
|
}
|
|
void OoxConverter::convert(OOX::Spreadsheet::CT_ScatterSer* ser)
|
|
{
|
|
if (ser == NULL)return;
|
|
|
|
if (ser->m_yVal)
|
|
{
|
|
odf_context()->chart_context()->start_series(L"scatter");
|
|
convert(ser->m_oSpPr.GetPointer());
|
|
convert(ser->m_dLbls);
|
|
|
|
convert(ser->m_xVal, 2);//domain
|
|
convert(ser->m_yVal);
|
|
|
|
convert(ser->m_tx);
|
|
if (ser->m_marker || ser->m_dPt.size() > 0)
|
|
{
|
|
convert(ser->m_marker, ser->m_dPt);
|
|
}
|
|
odf_context()->chart_context()->end_series();
|
|
}
|
|
else if (ser->m_xVal)
|
|
{
|
|
odf_context()->chart_context()->start_series(L"scatter");
|
|
convert(ser->m_oSpPr.GetPointer());
|
|
convert(ser->m_dLbls);
|
|
|
|
convert(ser->m_xVal, 1);
|
|
|
|
convert(ser->m_tx);
|
|
if (ser->m_marker || ser->m_dPt.size() > 0)
|
|
{
|
|
convert(ser->m_marker, ser->m_dPt);
|
|
}
|
|
odf_context()->chart_context()->end_series();
|
|
}
|
|
}
|
|
void OoxConverter::convert(OOX::Spreadsheet::CT_RadarSer* ser)
|
|
{
|
|
if (ser == NULL)return;
|
|
|
|
odf_context()->chart_context()->start_series(L"radar");
|
|
convert(ser->m_oSpPr.GetPointer());
|
|
convert(ser->m_dLbls);
|
|
|
|
convert(ser->m_cat, 1);
|
|
convert(ser->m_val);
|
|
|
|
convert(ser->m_tx);
|
|
if (ser->m_marker || ser->m_dPt.size() > 0)
|
|
{
|
|
convert(ser->m_marker, ser->m_dPt);
|
|
}
|
|
odf_context()->chart_context()->end_series();
|
|
}
|
|
void OoxConverter::convert(OOX::Spreadsheet::CT_LineSer* ser)
|
|
{
|
|
if (ser == NULL)return;
|
|
|
|
odf_context()->chart_context()->start_series(L"line");
|
|
convert(ser->m_oSpPr.GetPointer());
|
|
convert(ser->m_dLbls);
|
|
|
|
convert(ser->m_cat, 1);
|
|
convert(ser->m_val);
|
|
|
|
convert(ser->m_tx);
|
|
if (ser->m_marker || ser->m_dPt.size() > 0)
|
|
{
|
|
convert(ser->m_marker, ser->m_dPt);
|
|
}
|
|
odf_context()->chart_context()->end_series();
|
|
}
|
|
void OoxConverter::convert(OOX::Spreadsheet::CT_Marker* marker, std::vector<OOX::Spreadsheet::CT_DPt*> & dPt)
|
|
{
|
|
if (dPt.size() <1) return convert(marker);
|
|
|
|
long count_point = odf_context()->chart_context()->get_count_data_points_series();
|
|
long current_point = 0;
|
|
long set_point;
|
|
for (size_t i = 0; i < dPt.size(); i++)
|
|
{
|
|
if (dPt[i] == NULL)continue;
|
|
|
|
if (dPt[i]->m_idx && dPt[i]->m_idx->m_val) set_point = *dPt[i]->m_idx->m_val;
|
|
|
|
if (set_point - current_point > 0)
|
|
{
|
|
odf_context()->chart_context()->start_data_point_series(set_point - current_point);
|
|
convert(marker);
|
|
odf_context()->chart_context()->end_element();
|
|
}
|
|
odf_context()->chart_context()->start_data_point_series(1);
|
|
convert(dPt[i]->m_oSpPr.GetPointer());
|
|
convert(dPt[i]->m_marker);
|
|
if (dPt[i]->m_explosion && dPt[i]->m_explosion->m_val)
|
|
odf_context()->chart_context()->set_series_pie_explosion(*dPt[i]->m_explosion->m_val);
|
|
odf_context()->chart_context()->end_element();
|
|
|
|
current_point = set_point+1;
|
|
}
|
|
if (count_point - current_point >0)
|
|
{
|
|
odf_context()->chart_context()->start_data_point_series(count_point - current_point);
|
|
convert(marker);
|
|
odf_context()->chart_context()->end_element();
|
|
}
|
|
}
|
|
void OoxConverter::convert(OOX::Spreadsheet::CT_Marker* marker)
|
|
{
|
|
if (marker == NULL) return;
|
|
|
|
if (marker->m_symbol && marker->m_symbol->m_val)
|
|
odf_context()->chart_context()->set_marker_type(*marker->m_symbol->m_val);
|
|
if (marker->m_size && marker->m_size->m_val)
|
|
odf_context()->chart_context()->set_marker_size(*marker->m_size->m_val);
|
|
convert(marker->m_oSpPr.GetPointer());
|
|
}
|
|
void OoxConverter::convert(OOX::Spreadsheet::CT_DLbls* ser_lbls)
|
|
{
|
|
if (ser_lbls == NULL)return;
|
|
|
|
for (size_t i = 0; i < ser_lbls->m_Items.size(); i++)
|
|
{
|
|
bool boolVal = false;
|
|
|
|
OOX::Spreadsheet::CT_Boolean * ct_boolean = (OOX::Spreadsheet::CT_Boolean*)ser_lbls->m_Items[i];
|
|
if (ct_boolean && ct_boolean->m_val) boolVal = * ct_boolean->m_val;
|
|
|
|
switch(*ser_lbls->m_ItemsElementName0[i])
|
|
{
|
|
case OOX::Spreadsheet::itemschoicetype3DELETE :
|
|
odf_context()->chart_context()->set_label_delete(boolVal); break;
|
|
case OOX::Spreadsheet::itemschoicetype3SHOWBUBBLESIZE:
|
|
odf_context()->chart_context()->set_label_show_bubble_size(boolVal); break;
|
|
case OOX::Spreadsheet::itemschoicetype3SHOWCATNAME:
|
|
odf_context()->chart_context()->set_label_show_cat_name(boolVal); break;
|
|
case OOX::Spreadsheet::itemschoicetype3SHOWLEADERLINES:
|
|
odf_context()->chart_context()->set_label_show_leader_line(boolVal); break;
|
|
case OOX::Spreadsheet::itemschoicetype3SHOWLEGENDKEY:
|
|
odf_context()->chart_context()->set_label_show_legend_key(boolVal); break;
|
|
case OOX::Spreadsheet::itemschoicetype3SHOWPERCENT:
|
|
odf_context()->chart_context()->set_label_show_percent(boolVal); break;
|
|
case OOX::Spreadsheet::itemschoicetype3SHOWSERNAME:
|
|
odf_context()->chart_context()->set_label_show_ser_name(boolVal); break;
|
|
case OOX::Spreadsheet::itemschoicetype3SHOWVAL:
|
|
odf_context()->chart_context()->set_label_show_values(boolVal); break;
|
|
|
|
//case OOX::Spreadsheet::itemschoicetype3SPPR: convert((OOX::Spreadsheet:: *)ser_lbls->m_Items[i]); break;
|
|
//case OOX::Spreadsheet::itemschoicetype3TXPR: convert((OOX::Spreadsheet:: *)ser_lbls->m_Items[i]); break;
|
|
|
|
//case OOX::Spreadsheet::itemschoicetype3DLBLPOS: convert((OOX::Spreadsheet:: *)ser_lbls->m_Items[i]); break;
|
|
//case OOX::Spreadsheet::itemschoicetype3LEADERLINES: convert((OOX::Spreadsheet::CT_ChartLines *)ser_lbls->m_Items[i]); break;
|
|
//case OOX::Spreadsheet::itemschoicetype3NUMFMT: convert((OOX::Spreadsheet:: *)ser_lbls->m_Items[i]); break;
|
|
//case OOX::Spreadsheet::itemschoicetype3SEPARATOR: convert((OOX::Spreadsheet:: *)ser_lbls->m_Items[i]); break;
|
|
}
|
|
}
|
|
}
|
|
void OoxConverter::convert(OOX::Spreadsheet::CT_SerTx* ser_tx)
|
|
{
|
|
if (ser_tx == NULL)return;
|
|
|
|
if (ser_tx->m_strRef)
|
|
{
|
|
if (ser_tx->m_strRef->m_f)
|
|
odf_context()->chart_context()->set_series_label_formula(*ser_tx->m_strRef->m_f);
|
|
|
|
convert(ser_tx->m_strRef->m_strCache, false, true);
|
|
}
|
|
//if (ser_tx->m_v)odf_context()->chart_context()->set_series_name(*ser_tx->m_v);
|
|
|
|
}
|
|
void OoxConverter::convert(OOX::Spreadsheet::CT_AxDataSource* cat, int type)
|
|
{
|
|
if (cat == NULL) return;
|
|
|
|
if (cat->m_numLit)
|
|
{
|
|
odf_context()->chart_context()->set_series_value_formula(L"");
|
|
|
|
convert(cat->m_numLit, false, false);
|
|
}
|
|
else if (cat->m_strLit)
|
|
{
|
|
odf_context()->chart_context()->set_category_axis_formula(L"", type);
|
|
convert(cat->m_strLit, true, false);
|
|
}
|
|
else if (cat->m_strRef)
|
|
{
|
|
if (cat->m_strRef->m_f)
|
|
odf_context()->chart_context()->set_category_axis_formula(*cat->m_strRef->m_f, type);
|
|
|
|
convert(cat->m_strRef->m_strCache, true, false);
|
|
}
|
|
else if (cat->m_numRef)
|
|
{
|
|
if (cat->m_numRef->m_f)
|
|
odf_context()->chart_context()->set_category_axis_formula(*cat->m_numRef->m_f, type);
|
|
|
|
convert(cat->m_numRef->m_numCache, true, false);
|
|
}
|
|
|
|
}
|
|
void OoxConverter::convert(OOX::Spreadsheet::CT_NumDataSource* val)
|
|
{
|
|
if (val == NULL) return;
|
|
|
|
if (val->m_numLit)
|
|
{
|
|
odf_context()->chart_context()->set_series_value_formula(L"");
|
|
|
|
convert(val->m_numLit, false, false);
|
|
}
|
|
else if (val->m_numRef)
|
|
{
|
|
if (val->m_numRef->m_f)odf_context()->chart_context()->set_series_value_formula(*val->m_numRef->m_f);
|
|
|
|
convert(val->m_numRef->m_numCache, false, false);
|
|
}
|
|
|
|
}
|
|
///////////////////////////////////////////////////////////////////////////////////////////////
|
|
void OoxConverter::convert(OOX::Spreadsheet::CT_Surface* ct_surface, int type, bool chart3D)
|
|
{
|
|
if (ct_surface == NULL && chart3D == false)return;
|
|
//floor, side, back
|
|
if (type == 1)odf_context()->chart_context()->start_floor();
|
|
if (type == 2)odf_context()->chart_context()->start_wall();
|
|
//if (type == 3)odf_context()->chart_context()->start_back_wall();
|
|
|
|
if (ct_surface)
|
|
{
|
|
convert(ct_surface->m_oSpPr.GetPointer());
|
|
}
|
|
else if (chart3D)//тока для 3D так - хз почему
|
|
{
|
|
odf_context()->chart_context()->set_no_fill(true);
|
|
}
|
|
odf_context()->chart_context()->end_element();
|
|
}
|
|
void OoxConverter::convert(OOX::Spreadsheet::CT_ExternalData *external_data)
|
|
{
|
|
if (external_data == NULL)return;
|
|
//данные для диаграммы внутренние !!!
|
|
|
|
if (external_data->m_id == NULL)return;
|
|
|
|
//CString pathEmbeddings = GetEmbeddings(*external_data->m_id);
|
|
//oO
|
|
//unpack
|
|
|
|
//get/check Format - xlsx
|
|
//конверт sheets -> table:table
|
|
|
|
//или
|
|
//convert xlsx -> ods & read tables???
|
|
|
|
odf_context()->chart_context()->set_local_table(true);//пока пользуем кэш ....
|
|
}
|
|
void OoxConverter::convert(OOX::Spreadsheet::CT_NumData *num_data, bool categories, bool label)
|
|
{
|
|
if (num_data == NULL)return;
|
|
|
|
//std::vector<double> data;
|
|
std::vector<std::wstring> data;
|
|
|
|
for (size_t i = 0; i < num_data->m_pt.size(); i++)
|
|
{
|
|
if (num_data->m_pt[i] && num_data->m_pt[i]->m_v)
|
|
{
|
|
data.push_back(*num_data->m_pt[i]->m_v);
|
|
//double val=0;
|
|
//try
|
|
//{
|
|
// val = boost::lexical_cast<double>(num_data->m_pt[i]->m_v->GetBuffer());
|
|
//}catch(...)
|
|
//{
|
|
//}
|
|
//data.push_back(val);
|
|
}
|
|
}
|
|
std::wstring format;
|
|
if (num_data->m_formatCode) format = *num_data->m_formatCode;
|
|
|
|
odf_context()->chart_context()->set_cash(format, data, categories, label);
|
|
}
|
|
|
|
void OoxConverter::convert(OOX::Spreadsheet::CT_StrData *str_data, bool categories, bool label)
|
|
{
|
|
if (str_data == NULL)return;
|
|
std::vector<std::wstring> data;
|
|
|
|
for (size_t i = 0; i < str_data->m_pt.size(); i++)
|
|
{
|
|
if (str_data->m_pt[i] && str_data->m_pt[i]->m_v)
|
|
data.push_back(*str_data->m_pt[i]->m_v);
|
|
|
|
}
|
|
std::wstring format;
|
|
|
|
odf_context()->chart_context()->set_cash(format, data, categories, label);
|
|
}
|
|
}
|