10 #ifndef __LIBPAGEMAKER_GEOMETRY_H__
11 #define __LIBPAGEMAKER_GEOMETRY_H__
15 #include <librevenge/librevenge.h>
24 template <
typename Unit>
struct Point
29 Point(Unit x, Unit y) : m_x(x), m_y(y)
45 PMDXForm(
const uint32_t rotationDegree,
const uint32_t skewDegree,
const PMDShapePoint xformTopLeft,
const PMDShapePoint xformBotRight,
const PMDShapePoint rotatingPoint,
const uint32_t xformId)
46 : m_rotationDegree(rotationDegree), m_skewDegree(skewDegree), m_xformTopLeft(xformTopLeft), m_xformBotRight(xformBotRight), m_rotatingPoint(rotatingPoint), m_xformId(xformId)
53 virtual std::vector<PMDShapePoint>
getPoints()
const = 0;
56 virtual double getSkew()
const = 0;
65 virtual std::string
getText()
const = 0;
68 virtual librevenge::RVNGBinaryData
getBitmap()
const = 0;
85 : m_bboxTopLeft(bboxTopLeft), m_bboxBotRight(bboxBotRight), m_mirrored(mirrored), m_strokeProps(strokeProps)
130 std::vector<PMDShapePoint> points;
139 points.push_back(m_bboxTopLeft);
140 points.push_back(m_bboxBotRight);
169 return std::vector<PMDCharProperties>(1);
174 return std::vector<PMDParaProperties>(1);
179 librevenge::RVNGBinaryData temp;
201 : m_points(points), m_isClosed(isClosed), m_bboxTopLeft(bboxTopLeft), m_bboxBotRight(bboxBotRight), m_xFormContainer(xFormContainer), m_fillProps(fillProps), m_strokeProps(strokeProps)
207 return (-1 * (
double)temp/1000 * (
M_PI/180));
213 return (-1 * (
double)temp/1000 * (
M_PI/180));
273 return std::vector<PMDCharProperties>(1);
278 return std::vector<PMDParaProperties>(1);
283 librevenge::RVNGBinaryData temp;
302 PMDTextBox(
const PMDShapePoint &bboxTopLeft,
const PMDShapePoint &bboxBotRight,
const PMDXForm &xFormContainer,
const std::string text,
const std::vector<PMDCharProperties> charProps,
const std::vector<PMDParaProperties> paraProps)
303 : m_bboxTopLeft(bboxTopLeft), m_bboxBotRight(bboxBotRight),m_xFormContainer(xFormContainer), m_text(text), m_charProps(charProps), m_paraProps(paraProps)
309 return (-1 * (
double)temp/1000 * (
M_PI/180));
315 return (-1 * (
double)temp/1000 * (
M_PI/180));
350 std::vector<PMDShapePoint> points;
352 points.push_back(m_bboxTopLeft);
389 librevenge::RVNGBinaryData temp;
408 : m_bboxTopLeft(bboxTopLeft), m_bboxBotRight(bboxBotRight),m_xFormContainer(xFormContainer), m_fillProps(fillProps), m_strokeProps(strokeProps)
414 return (-1 * (
double)temp/1000 * (
M_PI/180));
420 return (-1 * (
double)temp/1000 * (
M_PI/180));
455 std::vector<PMDShapePoint> points;
457 points.push_back(m_bboxTopLeft);
459 points.push_back(m_bboxBotRight);
487 return std::vector<PMDCharProperties>(1);
492 return std::vector<PMDParaProperties>(1);
497 librevenge::RVNGBinaryData temp;
516 : m_bboxTopLeft(bboxTopLeft), m_bboxBotRight(bboxBotRight), m_xFormContainer(xFormContainer), m_fillProps(fillProps), m_strokeProps(strokeProps)
522 return (-1 * (
double)temp/1000 * (
M_PI/180));
528 return (-1 * (
double)temp/1000 * (
M_PI/180));
553 std::vector<PMDShapePoint> points;
555 points.push_back(m_bboxTopLeft);
556 points.push_back(m_bboxBotRight);
593 return std::vector<PMDCharProperties>(1);
598 return std::vector<PMDParaProperties>(1);
603 librevenge::RVNGBinaryData temp;
620 PMDBitmap(
const PMDShapePoint &bboxTopLeft,
const PMDShapePoint &bboxBotRight,
const PMDXForm &xFormContainer,
const librevenge::RVNGBinaryData &bitmap)
621 : m_bboxTopLeft(bboxTopLeft), m_bboxBotRight(bboxBotRight), m_xFormContainer(xFormContainer),m_bitmap(bitmap)
627 return (-1 * (
double)temp/1000 * (
M_PI/180));
633 return (-1 * (
double)temp/1000 * (
M_PI/180));
668 std::vector<PMDShapePoint> points;
670 points.push_back(m_bboxTopLeft);
672 points.push_back(m_bboxBotRight);
700 return std::vector<PMDCharProperties>(1);
705 return std::vector<PMDParaProperties>(1);
724 : m_tl(bboxTopLeft), m_tr(topRight), m_bl(bottomLeft), m_br(bottomRight)
729 double xInches = point.
m_x.toInches(),
730 yInches = point.
m_y.toInches();
731 double newX = m_tl * xInches + m_tr * yInches,
732 newY = m_bl * xInches + m_br * yInches;
736 std::pair<InchPoint, InchPoint>
737 getBoundingBox(
const PMDLineSet &lineSet,
const TransformationMatrix &matrix);
double getSkew() const override
Definition: geometry.h:630
PMDShapePoint getBboxBotRight() const override
Definition: geometry.h:443
PMDStrokeProperties getStrokeProperties() const override
Definition: geometry.h:367
std::string getText() const override
Definition: geometry.h:162
PMDFillProperties getFillProperties() const override
Definition: geometry.h:683
std::vector< PMDCharProperties > m_charProps
Definition: geometry.h:298
const uint8_t SHAPE_TYPE_ELLIPSE
Definition: constants.h:55
PMDShapePoint getXformBotRight() const override
Definition: geometry.h:103
const uint8_t SHAPE_TYPE_TEXTBOX
Definition: constants.h:56
PMDShapePoint m_bboxBotRight
Definition: geometry.h:194
double getRotation() const override
Definition: geometry.h:204
librevenge::RVNGBinaryData getBitmap() const override
Definition: geometry.h:387
double getSkew() const override
Definition: geometry.h:525
double getRotation() const override
Definition: geometry.h:306
std::string getText() const override
Definition: geometry.h:266
PMDBitmap(const PMDShapePoint &bboxTopLeft, const PMDShapePoint &bboxBotRight, const PMDXForm &xFormContainer, const librevenge::RVNGBinaryData &bitmap)
Definition: geometry.h:620
uint32_t m_rotationDegree
Definition: geometry.h:38
Definition: geometry.h:612
double getRotation() const override
Definition: geometry.h:88
PMDShapePoint m_xformBotRight
Definition: geometry.h:41
PMDShapePoint m_bboxBotRight
Definition: geometry.h:295
std::vector< PMDCharProperties > getCharProperties() const override
Definition: geometry.h:485
PMDStrokeProperties getStrokeProperties() const override
Definition: geometry.h:475
InchPoint transform(const Point< Unit > &point) const
Definition: geometry.h:727
std::vector< PMDShapePoint > getPoints() const override
Definition: geometry.h:128
PMDShapePoint getBboxBotRight() const override
Definition: geometry.h:338
PMDFillProperties getFillProperties() const override
Definition: geometry.h:362
PMDFillProperties getFillProperties() const override
Definition: geometry.h:470
virtual PMDShapePoint getBboxTopLeft() const =0
std::vector< PMDCharProperties > getCharProperties() const override
Definition: geometry.h:167
virtual std::string getText() const =0
bool getIsClosed() const override
Definition: geometry.h:661
Point< PMDShapeUnit > PMDShapePoint
Definition: geometry.h:33
PMDShapePoint getBboxBotRight() const override
Definition: geometry.h:123
Point(Unit x, Unit y)
Definition: geometry.h:29
double getSkew() const override
Definition: geometry.h:417
Definition: geometry.h:76
std::vector< PMDParaProperties > m_paraProps
Definition: geometry.h:299
PMDPolygon(std::vector< PMDShapePoint > points, bool isClosed, const PMDShapePoint &bboxTopLeft, const PMDShapePoint &bboxBotRight, const PMDXForm &xFormContainer, const PMDFillProperties fillProps, const PMDStrokeProperties strokeProps)
Definition: geometry.h:200
virtual bool getIsClosed() const =0
PMDRectangle(const PMDShapePoint &bboxTopLeft, const PMDShapePoint &bboxBotRight, const PMDXForm &xFormContainer, const PMDFillProperties fillProps, const PMDStrokeProperties strokeProps)
Definition: geometry.h:407
PMDShapePoint getXformTopLeft() const override
Definition: geometry.h:531
std::vector< PMDParaProperties > getParaProperties() const override
Definition: geometry.h:596
librevenge::RVNGBinaryData getBitmap() const override
Definition: geometry.h:601
std::vector< PMDShapePoint > getPoints() const override
Definition: geometry.h:453
PMDShapePoint getXformTopLeft() const override
Definition: geometry.h:318
PMDShapePoint m_bboxTopLeft
Definition: geometry.h:78
double getSkew() const override
Definition: geometry.h:312
std::vector< PMDShapePoint > getPoints() const override
Definition: geometry.h:666
PMDShapePoint getXformTopLeft() const override
Definition: geometry.h:636
std::string m_text
Definition: geometry.h:297
PMDShapePoint getBboxTopLeft() const override
Definition: geometry.h:118
std::vector< PMDParaProperties > getParaProperties() const override
Definition: geometry.h:172
std::vector< PMDParaProperties > getParaProperties() const override
Definition: geometry.h:276
double getSkew() const override
Definition: geometry.h:210
uint8_t shapeType() const override
Definition: geometry.h:145
bool getIsClosed() const override
Definition: geometry.h:343
virtual double getRotation() const =0
double m_bl
Definition: geometry.h:720
std::pair< InchPoint, InchPoint > getBoundingBox(const PMDLineSet &lineSet, const TransformationMatrix &matrix)
Definition: geometry.cpp:16
PMDShapePoint getXformTopLeft() const override
Definition: geometry.h:98
PMDFillProperties m_fillProps
Definition: geometry.h:196
virtual librevenge::RVNGBinaryData getBitmap() const =0
PMDShapePoint getBboxTopLeft() const override
Definition: geometry.h:333
librevenge::RVNGBinaryData getBitmap() const override
Definition: geometry.h:177
librevenge::RVNGBinaryData m_bitmap
Definition: geometry.h:617
~PMDEllipse() override
Definition: geometry.h:607
Definition: geometry.h:24
PMDStrokeProperties getStrokeProperties() const override
Definition: geometry.h:261
Definition: geometry.h:718
librevenge::RVNGBinaryData getBitmap() const override
Definition: geometry.h:281
double getRotation() const override
Definition: geometry.h:411
virtual PMDShapePoint getXformBotRight() const =0
~PMDLine() override
Definition: geometry.h:183
double m_tl
Definition: geometry.h:720
virtual PMDStrokeProperties getStrokeProperties() const =0
PMDShapePoint getXformBotRight() const override
Definition: geometry.h:641
PMDShapePoint m_bboxTopLeft
Definition: geometry.h:614
PMDFillProperties m_fillProps
Definition: geometry.h:403
PMDShapePoint getRotatingPoint() const override
Definition: geometry.h:226
std::vector< PMDShapePoint > getPoints() const override
Definition: geometry.h:348
PMDShapePoint getXformTopLeft() const override
Definition: geometry.h:423
PMDShapePoint m_bboxBotRight
Definition: geometry.h:615
Definition: geometry.h:189
PMDShapePoint getXformBotRight() const override
Definition: geometry.h:323
PMDShapePoint getRotatingPoint() const override
Definition: geometry.h:541
std::string getText() const override
Definition: geometry.h:586
PMDStrokeProperties m_strokeProps
Definition: geometry.h:512
virtual ~PMDLineSet()
Definition: geometry.h:71
uint8_t m_fillType
Definition: PMDTypes.h:45
PMDShapePoint getBboxTopLeft() const override
Definition: geometry.h:561
const uint8_t SHAPE_TYPE_POLY
Definition: constants.h:53
std::string getText() const override
Definition: geometry.h:372
virtual double getSkew() const =0
uint32_t m_skewDegree
Definition: geometry.h:39
virtual PMDShapePoint getRotatingPoint() const =0
PMDLine(const PMDShapePoint &bboxTopLeft, const PMDShapePoint &bboxBotRight, const bool mirrored, const PMDStrokeProperties strokeProps)
Definition: geometry.h:84
~PMDBitmap() override
Definition: geometry.h:713
virtual std::vector< PMDParaProperties > getParaProperties() const =0
PMDShapePoint getXformBotRight() const override
Definition: geometry.h:428
std::vector< PMDParaProperties > getParaProperties() const override
Definition: geometry.h:703
PMDEllipse(const PMDShapePoint &bboxTopLeft, const PMDShapePoint &bboxBotRight, const PMDXForm &xFormContainer, const PMDFillProperties fillProps, const PMDStrokeProperties strokeProps)
Definition: geometry.h:515
~PMDTextBox() override
Definition: geometry.h:393
std::vector< PMDCharProperties > getCharProperties() const override
Definition: geometry.h:271
uint8_t shapeType() const override
Definition: geometry.h:465
PMDStrokeProperties getStrokeProperties() const override
Definition: geometry.h:157
bool getIsClosed() const override
Definition: geometry.h:448
PMDShapePoint getXformBotRight() const override
Definition: geometry.h:536
PMDShapePoint m_xformTopLeft
Definition: geometry.h:40
PMDShapePoint getXformBotRight() const override
Definition: geometry.h:221
PMDShapePoint m_bboxBotRight
Definition: geometry.h:79
PMDXForm m_xFormContainer
Definition: geometry.h:195
uint8_t shapeType() const override
Definition: geometry.h:251
Unit m_x
Definition: geometry.h:26
PMDFillProperties getFillProperties() const override
Definition: geometry.h:256
double m_br
Definition: geometry.h:720
uint8_t shapeType() const override
Definition: geometry.h:357
PMDShapePoint m_bboxTopLeft
Definition: geometry.h:400
PMDShapePoint getBboxBotRight() const override
Definition: geometry.h:236
std::vector< PMDCharProperties > getCharProperties() const override
Definition: geometry.h:591
std::string getText() const override
Definition: geometry.h:480
~PMDRectangle() override
Definition: geometry.h:501
Unit m_y
Definition: geometry.h:27
PMDShapePoint m_bboxBotRight
Definition: geometry.h:401
#define M_PI
Definition: libpagemaker_utils.h:28
Definition: geometry.h:50
double getRotation() const override
Definition: geometry.h:519
std::vector< PMDCharProperties > getCharProperties() const override
Definition: geometry.h:377
bool m_mirrored
Definition: geometry.h:80
PMDShapePoint getBboxTopLeft() const override
Definition: geometry.h:438
std::vector< PMDShapePoint > getPoints() const override
Definition: geometry.h:246
virtual std::vector< PMDShapePoint > getPoints() const =0
uint8_t shapeType() const override
Definition: geometry.h:678
uint8_t shapeType() const override
Definition: geometry.h:571
const uint8_t FILL_SOLID
Definition: constants.h:62
bool getIsClosed() const override
Definition: geometry.h:546
Point< double > InchPoint
Definition: geometry.h:34
PMDXForm m_xFormContainer
Definition: geometry.h:402
PMDFillProperties getFillProperties() const override
Definition: geometry.h:150
Definition: geometry.h:292
virtual uint8_t shapeType() const =0
uint32_t m_xformId
Definition: geometry.h:43
std::vector< PMDCharProperties > getCharProperties() const override
Definition: geometry.h:698
PMDShapePoint getBboxTopLeft() const override
Definition: geometry.h:651
Definition: PMDTypes.h:43
PMDShapePoint m_bboxTopLeft
Definition: geometry.h:508
PMDStrokeProperties m_strokeProps
Definition: geometry.h:197
PMDStrokeProperties m_strokeProps
Definition: geometry.h:404
PMDShapePoint m_rotatingPoint
Definition: geometry.h:42
PMDXForm m_xFormContainer
Definition: geometry.h:510
std::string getText() const override
Definition: geometry.h:693
PMDTextBox(const PMDShapePoint &bboxTopLeft, const PMDShapePoint &bboxBotRight, const PMDXForm &xFormContainer, const std::string text, const std::vector< PMDCharProperties > charProps, const std::vector< PMDParaProperties > paraProps)
Definition: geometry.h:302
Definition: PMDTypes.h:53
PMDStrokeProperties getStrokeProperties() const override
Definition: geometry.h:581
std::vector< PMDParaProperties > getParaProperties() const override
Definition: geometry.h:382
PMDShapePoint getXformTopLeft() const override
Definition: geometry.h:216
PMDXForm m_xFormContainer
Definition: geometry.h:616
Definition: geometry.h:22
bool getIsClosed() const override
Definition: geometry.h:241
const uint8_t SHAPE_TYPE_RECT
Definition: constants.h:54
PMDShapePoint getBboxTopLeft() const override
Definition: geometry.h:231
Definition: geometry.h:506
PMDShapePoint getRotatingPoint() const override
Definition: geometry.h:646
~PMDPolygon() override
Definition: geometry.h:287
librevenge::RVNGBinaryData getBitmap() const override
Definition: geometry.h:495
virtual PMDShapePoint getBboxBotRight() const =0
const uint8_t SHAPE_TYPE_LINE
Definition: constants.h:52
double getSkew() const override
Definition: geometry.h:93
PMDShapePoint getBboxBotRight() const override
Definition: geometry.h:656
PMDShapePoint getRotatingPoint() const override
Definition: geometry.h:328
PMDShapePoint getRotatingPoint() const override
Definition: geometry.h:433
PMDShapePoint getRotatingPoint() const override
Definition: geometry.h:108
PMDStrokeProperties m_strokeProps
Definition: geometry.h:81
PMDShapePoint getBboxBotRight() const override
Definition: geometry.h:566
std::vector< PMDShapePoint > m_points
Definition: geometry.h:191
PMDXForm(const uint32_t rotationDegree, const uint32_t skewDegree, const PMDShapePoint xformTopLeft, const PMDShapePoint xformBotRight, const PMDShapePoint rotatingPoint, const uint32_t xformId)
Definition: geometry.h:45
virtual PMDFillProperties getFillProperties() const =0
librevenge::RVNGBinaryData getBitmap() const override
Definition: geometry.h:708
PMDFillProperties getFillProperties() const override
Definition: geometry.h:576
TransformationMatrix(double bboxTopLeft, double topRight, double bottomLeft, double bottomRight)
Definition: geometry.h:723
bool m_isClosed
Definition: geometry.h:192
PMDShapePoint m_bboxTopLeft
Definition: geometry.h:193
virtual std::vector< PMDCharProperties > getCharProperties() const =0
PMDStrokeProperties getStrokeProperties() const override
Definition: geometry.h:688
std::vector< PMDParaProperties > getParaProperties() const override
Definition: geometry.h:490
Definition: geometry.h:398
const uint8_t SHAPE_TYPE_BITMAP
Definition: constants.h:57
PMDXForm m_xFormContainer
Definition: geometry.h:296
double m_tr
Definition: geometry.h:720
virtual PMDShapePoint getXformTopLeft() const =0
bool getIsClosed() const override
Definition: geometry.h:113
PMDShapePoint m_bboxBotRight
Definition: geometry.h:509
PMDShapePoint m_bboxTopLeft
Definition: geometry.h:294
Definition: geometry.h:36
PMDFillProperties m_fillProps
Definition: geometry.h:511
std::vector< PMDShapePoint > getPoints() const override
Definition: geometry.h:551
double getRotation() const override
Definition: geometry.h:624