// Copyright (C) 2019 Jakub Melka // // This file is part of PdfForQt. // // PdfForQt is free software: you can redistribute it and/or modify // it under the terms of the GNU Lesser General Public License as published by // the Free Software Foundation, either version 3 of the License, or // (at your option) any later version. // // PdfForQt is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU Lesser General Public License for more details. // // You should have received a copy of the GNU Lesser General Public License // along with PDFForQt. If not, see . #ifndef PDFRENDERER_H #define PDFRENDERER_H #include "pdfpage.h" class QPainter; namespace pdf { enum RenderErrorType { Error, NotImplemented }; struct PDFRenderError { explicit PDFRenderError() = default; explicit PDFRenderError(RenderErrorType type, QString message) : type(type), message(std::move(message)) { } RenderErrorType type = RenderErrorType::Error; QString message; }; /// Renders the PDF page on the painter, or onto an image. class PDFRenderer { public: explicit PDFRenderer(const PDFDocument* document); enum Feature { Antialiasing = 0x0001, ///< Antialiasing for lines, shapes, etc. TextAntialiasing = 0x0002, ///< Antialiasing for drawing text SmoothImages = 0x0004 ///< Adjust images to the device space using smooth transformation (slower, but better performance quality) }; Q_DECLARE_FLAGS(Features, Feature) /// Paints desired page onto the painter. Page is painted in the rectangle using best-fit method. /// If the page doesn't exist, then error is returned. No exception is thrown. Rendering errors /// are reported and returned in the error list. If no error occured, empty list is returned. /// \param painter Painter /// \param rectangle Paint area for the page /// \param pageIndex Index of the page to be painted QList render(QPainter* painter, const QRectF& rectangle, size_t pageIndex) const; /// Paints desired page onto the painter. Page is painted using \p matrix, which maps page coordinates /// to the device coordinates. If the page doesn't exist, then error is returned. No exception is thrown. /// Rendering errors are reported and returned in the error list. If no error occured, empty list is returned. QList render(QPainter* painter, const QMatrix& matrix, size_t pageIndex) const; private: const PDFDocument* m_document; Features m_features; }; } // namespace pdf Q_DECLARE_OPERATORS_FOR_FLAGS(pdf::PDFRenderer::Features) #endif // PDFRENDERER_H