#ifndef QXLSX_XLSXDOCUMENT_H #define QXLSX_XLSXDOCUMENT_H #include "xlsxglobal.h" #include class QIODevice; class QImage; namespace QXlsx { class Workbook; class Worksheet; class Package; class Format; class DocumentPrivate; class Q_XLSX_EXPORT Document : public QObject { Q_OBJECT Q_DECLARE_PRIVATE(Document) public: explicit Document(QObject *parent = 0); Document(const QString &xlsxName, QObject *parent=0); Document(QIODevice *device, QObject *parent=0); ~Document(); Format *createFormat(); int write(const QString cell, const QVariant &value, Format *format=0); int write(int row, int col, const QVariant &value, Format *format=0); int insertImage(int row, int column, const QImage &image, double xOffset=0, double yOffset=0, double xScale=1, double yScale=1); int mergeCells(const QString &range); int unmergeCells(const QString &range); bool setRow(int row, double height, Format* format=0, bool hidden=false); bool setColumn(int colFirst, int colLast, double width, Format* format=0, bool hidden=false); QString documentProperty(const QString &name) const; void setDocumentProperty(const QString &name, const QString &property); QStringList documentPropertyNames() const; Workbook *workbook() const; bool addWorksheet(const QString &name = QString()); bool insertWorkSheet(int index, const QString &name = QString()); Worksheet *activedWorksheet() const; int activedWorksheetIndex() const; void setActivedWorksheetIndex(int index); bool save(); bool saveAs(const QString &xlsXname); bool saveAs(QIODevice *device); private: friend class Package; Q_DISABLE_COPY(Document) DocumentPrivate * const d_ptr; }; } // namespace QXlsx #endif // QXLSX_XLSXDOCUMENT_H