// Copyright (C) 2019-2021 Jakub Melka // // This file is part of PDF4QT. // // PDF4QT 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 // with the written consent of the copyright owner, any later version. // // PDF4QT 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 PDF4QT. If not, see . #ifndef PDFIMAGE_H #define PDFIMAGE_H #include "pdfobject.h" #include "pdfcolorspaces.h" #include "pdfoperationcontrol.h" #include class QByteArray; namespace pdf { class PDFStream; class PDFDocument; class PDFObjectStorage; class PDFRenderErrorReporter; /// Alternate image object. Defines alternate image, which /// can be shown in some circumstances instead of main image. class PDFAlternateImage { public: explicit inline PDFAlternateImage() = default; /// Parses alternate image dictionary object. /// \param storage Object storage /// \param object Alternate image object static PDFAlternateImage parse(const PDFObjectStorage* storage, PDFObject object); PDFObjectReference getImage() const { return m_image; } PDFObjectReference getOc() const { return m_oc; } bool isDefaultForPrinting() const { return m_defaultForPrinting; } private: PDFObjectReference m_image; PDFObjectReference m_oc; bool m_defaultForPrinting = false; }; class PDF4QTLIBCORESHARED_EXPORT PDFImage { public: PDFImage() = default; /// Creates image from the content and the dictionary. If image can't be created, then exception is thrown. /// \param document Document /// \param stream Stream with image /// \param colorSpace Color space of the image /// \param isSoftMask Is it a soft mask image? /// \param renderingIntent Default rendering intent of the image /// \param errorReporter Error reporter for reporting errors (or warnings) static PDFImage createImage(const PDFDocument* document, const PDFStream* stream, PDFColorSpacePointer colorSpace, bool isSoftMask, RenderingIntent renderingIntent, PDFRenderErrorReporter* errorReporter); /// Returns image transformed from image data and color space QImage getImage(const PDFCMS* cms, PDFRenderErrorReporter* reporter, const PDFOperationControl* operationControl) const; /// Returns rendering intent of the image RenderingIntent getRenderingIntent() const { return m_renderingIntent; } /// Color space of image samples const PDFColorSpacePointer& getColorSpace() const { return m_colorSpace; } /// Should PDF processor perform interpolation on this image? bool isInterpolated() const { return m_interpolate; } /// Array of alternate images const std::vector& getAlternates() const { return m_alternates; } /// Returns name of image, under which is referenced in resources dictionary. /// It was mandatory in PDF 1.0, otherwise it is optional and now it is deprecated /// in PDF 2.0 specification. const QByteArray& getName() const { return m_name; } /// Returns idenfitier to structural parent in structure tree PDFInteger getStructuralParent() const { return m_structuralParent; } /// Web capture content set identifier const QByteArray& getWebCaptureContentSetID() const { return m_webCaptureContentSetId; } const PDFObject& getOPI() const { return m_OPI; } const PDFObject& getOC() const { return m_OC; } const PDFObject& getMetadata() const { return m_metadata; } const PDFObject& getAssociatedFiles() const { return m_associatedFiles; } const PDFObject& getMeasure() const { return m_measure; } const PDFObject& getPointData() const { return m_pointData; } const PDFImageData& getImageData() const { return m_imageData; } const PDFImageData& getSoftMaskData() const { return m_softMask; } static bool canBeConvertedToMonochromatic(const QImage& image); private: PDFImageData m_imageData; PDFImageData m_softMask; PDFColorSpacePointer m_colorSpace; RenderingIntent m_renderingIntent = RenderingIntent::Perceptual; bool m_interpolate = false; std::vector m_alternates; QByteArray m_name; QByteArray m_webCaptureContentSetId; PDFInteger m_structuralParent = 0; PDFObject m_OPI; PDFObject m_OC; PDFObject m_metadata; PDFObject m_associatedFiles; PDFObject m_measure; PDFObject m_pointData; }; } // namespace pdf #endif // PDFIMAGE_H