xlsxchartsheet.cpp 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159
  1. /****************************************************************************
  2. ** Copyright (c) 2013-2014 Debao Zhang <hello@debao.me>
  3. ** All right reserved.
  4. **
  5. ** Permission is hereby granted, free of charge, to any person obtaining
  6. ** a copy of this software and associated documentation files (the
  7. ** "Software"), to deal in the Software without restriction, including
  8. ** without limitation the rights to use, copy, modify, merge, publish,
  9. ** distribute, sublicense, and/or sell copies of the Software, and to
  10. ** permit persons to whom the Software is furnished to do so, subject to
  11. ** the following conditions:
  12. **
  13. ** The above copyright notice and this permission notice shall be
  14. ** included in all copies or substantial portions of the Software.
  15. **
  16. ** THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
  17. ** EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
  18. ** MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
  19. ** NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
  20. ** LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
  21. ** OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
  22. ** WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
  23. **
  24. ****************************************************************************/
  25. #include "xlsxchartsheet.h"
  26. #include "xlsxchartsheet_p.h"
  27. #include "xlsxworkbook.h"
  28. #include "xlsxutility_p.h"
  29. #include "xlsxdrawing_p.h"
  30. #include "xlsxdrawinganchor_p.h"
  31. #include "xlsxchart.h"
  32. #include <QXmlStreamReader>
  33. #include <QXmlStreamWriter>
  34. #include <QDir>
  35. QT_BEGIN_NAMESPACE_XLSX
  36. ChartsheetPrivate::ChartsheetPrivate(Chartsheet *p, Chartsheet::CreateFlag flag)
  37. : AbstractSheetPrivate(p, flag), chart(0)
  38. {
  39. }
  40. ChartsheetPrivate::~ChartsheetPrivate()
  41. {
  42. }
  43. /*!
  44. \class Chartsheet
  45. \inmodule QtXlsx
  46. \brief Represent one chartsheet in the workbook.
  47. */
  48. /*!
  49. * \internal
  50. */
  51. Chartsheet::Chartsheet(const QString &name, int id, Workbook *workbook, CreateFlag flag)
  52. :AbstractSheet(name, id, workbook, new ChartsheetPrivate(this, flag))
  53. {
  54. setSheetType(ST_ChartSheet);
  55. if (flag == Chartsheet::F_NewFromScratch) {
  56. d_func()->drawing = QSharedPointer<Drawing>(new Drawing(this, flag));
  57. DrawingAbsoluteAnchor *anchor = new DrawingAbsoluteAnchor(drawing(), DrawingAnchor::Picture);
  58. anchor->pos = QPoint(0, 0);
  59. anchor->ext = QSize(9293679, 6068786);
  60. QSharedPointer<Chart> chart = QSharedPointer<Chart>(new Chart(this, flag));
  61. chart->setChartType(Chart::CT_Bar);
  62. anchor->setObjectGraphicFrame(chart);
  63. d_func()->chart = chart.data();
  64. }
  65. }
  66. /*!
  67. * \internal
  68. *
  69. * Make a copy of this sheet.
  70. */
  71. Chartsheet *Chartsheet::copy(const QString &distName, int distId) const
  72. {
  73. //:Todo
  74. Q_UNUSED(distName)
  75. Q_UNUSED(distId)
  76. return 0;
  77. }
  78. /*!
  79. * Destroys this workssheet.
  80. */
  81. Chartsheet::~Chartsheet()
  82. {
  83. }
  84. /*!
  85. * Returns the chart object of the sheet.
  86. */
  87. Chart *Chartsheet::chart()
  88. {
  89. Q_D(Chartsheet);
  90. return d->chart;
  91. }
  92. void Chartsheet::saveToXmlFile(QIODevice *device) const
  93. {
  94. Q_D(const Chartsheet);
  95. d->relationships->clear();
  96. QXmlStreamWriter writer(device);
  97. writer.writeStartDocument(QStringLiteral("1.0"), true);
  98. writer.writeDefaultNamespace(QStringLiteral("http://schemas.openxmlformats.org/spreadsheetml/2006/main"));
  99. writer.writeNamespace(QStringLiteral("http://schemas.openxmlformats.org/officeDocument/2006/relationships"), QStringLiteral("r"));
  100. writer.writeStartElement(QStringLiteral("chartsheet"));
  101. writer.writeStartElement(QStringLiteral("sheetViews"));
  102. writer.writeEmptyElement(QStringLiteral("sheetView"));
  103. writer.writeAttribute(QStringLiteral("workbookViewId"), QString::number(0));
  104. writer.writeAttribute(QStringLiteral("zoomToFit"), QStringLiteral("1"));
  105. writer.writeEndElement(); //sheetViews
  106. int idx = d->workbook->drawings().indexOf(d->drawing.data());
  107. d->relationships->addWorksheetRelationship(QStringLiteral("/drawing"), QStringLiteral("../drawings/drawing%1.xml").arg(idx+1));
  108. writer.writeEmptyElement(QStringLiteral("drawing"));
  109. writer.writeAttribute(QStringLiteral("r:id"), QStringLiteral("rId%1").arg(d->relationships->count()));
  110. writer.writeEndElement();//chartsheet
  111. writer.writeEndDocument();
  112. }
  113. bool Chartsheet::loadFromXmlFile(QIODevice *device)
  114. {
  115. Q_D(Chartsheet);
  116. QXmlStreamReader reader(device);
  117. while (!reader.atEnd()) {
  118. reader.readNextStartElement();
  119. if (reader.tokenType() == QXmlStreamReader::StartElement) {
  120. if (reader.name() == QLatin1String("drawing")) {
  121. QString rId = reader.attributes().value(QStringLiteral("r:id")).toString();
  122. QString name = d->relationships->getRelationshipById(rId).target;
  123. QString path = QDir::cleanPath(splitPath(filePath())[0] + QLatin1String("/") + name);
  124. d->drawing = QSharedPointer<Drawing>(new Drawing(this, F_LoadFromExists));
  125. d->drawing->setFilePath(path);
  126. }
  127. }
  128. }
  129. return true;
  130. }
  131. QT_END_NAMESPACE_XLSX