File indexing completed on 2024-05-19 04:26:41

0001 /*
0002  *  SPDX-FileCopyrightText: 2020 Dmitry Kazakov <dimula73@gmail.com>
0003  *
0004  *  SPDX-License-Identifier: GPL-2.0-or-later
0005  */
0006 
0007 #ifndef KISBEZIERTRANSFORMMESH_H
0008 #define KISBEZIERTRANSFORMMESH_H
0009 
0010 #include "kritaimage_export.h"
0011 #include "KisBezierMesh.h"
0012 
0013 #include "kis_types.h"
0014 
0015 namespace KisBezierTransformMeshDetail {
0016 
0017 class KRITAIMAGE_EXPORT KisBezierTransformMesh : public KisBezierMesh
0018 {
0019 public:
0020     KisBezierTransformMesh()
0021     {
0022     }
0023     KisBezierTransformMesh(const QRectF &srcRect, const QSize &size = QSize(2,2))
0024         : KisBezierMesh(srcRect, size)
0025     {
0026     }
0027 
0028     PatchIndex hitTestPatch(const QPointF &pt, QPointF *localPointResult = 0) const;
0029 
0030     static void transformPatch(const KisBezierPatch &patch,
0031                                const QPoint &srcQImageOffset,
0032                                const QImage &srcImage,
0033                                const QPoint &dstQImageOffset,
0034                                QImage *dstImage);
0035 
0036     static void transformPatch(const KisBezierPatch &patch,
0037                                KisPaintDeviceSP srcDevice,
0038                                KisPaintDeviceSP dstDevice);
0039 
0040 
0041     void transformMesh(const QPoint &srcQImageOffset,
0042                        const QImage &srcImage,
0043                        const QPoint &dstQImageOffset,
0044                        QImage *dstImage) const;
0045 
0046     void transformMesh(KisPaintDeviceSP srcDevice,
0047                        KisPaintDeviceSP dstDevice) const;
0048 
0049     QRect approxNeedRect(const QRect &rc) const;
0050     QRect approxChangeRect(const QRect &rc) const;
0051 
0052     static QRectF calcTightSrcRectRangeInParamSpace(const KisBezierPatch &patch,
0053                                                     const QRectF &srcSpaceRect,
0054                                                     qreal srcPrecision);
0055 
0056     friend KRITAIMAGE_EXPORT void saveValue(QDomElement *parent, const QString &tag, const KisBezierTransformMesh &mesh);
0057     friend KRITAIMAGE_EXPORT bool loadValue(const QDomElement &parent, KisBezierTransformMesh *mesh);
0058 
0059     QRect hitTestPatchInSourceSpace(const QRectF &rect) const;
0060 
0061 private:
0062     patch_const_iterator hitTestPatchImpl(const QPointF &pt, QPointF *localPointResult = 0) const;
0063 };
0064 
0065 KRITAIMAGE_EXPORT
0066 void saveValue(QDomElement *parent, const QString &tag, const KisBezierTransformMesh &mesh);
0067 
0068 KRITAIMAGE_EXPORT
0069 bool loadValue(const QDomElement &parent, KisBezierTransformMesh *mesh);
0070 
0071 }
0072 
0073 namespace KisDomUtils {
0074 using KisBezierTransformMeshDetail::loadValue;
0075 using KisBezierTransformMeshDetail::saveValue;
0076 }
0077 
0078 using KisBezierTransformMesh = KisBezierTransformMeshDetail::KisBezierTransformMesh;
0079 
0080 #endif // KISBEZIERTRANSFORMMESH_H