1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
|
// ================================ // Simple abstraction class between backend
// renderers
// ================================
// Written by Ken Moore: Feb 26, 2018
// Available under the 3-Clause BSD License
// ================================
#ifndef _LUMINA_PDF_BACKEND_RENDERER_H
#define _LUMINA_PDF_BACKEND_RENDERER_H
#include "Annotation.h"
#include "Bookmark.h"
#include "TextData.h"
#include "Widget.h"
#include <QDebug>
#include <QImage>
#include <QJsonObject>
#include <QMessageBox>
#include <QProcess>
#include <QString>
class Renderer : public QObject {
Q_OBJECT
private:
int pnum; // number of pages - set on loading document
bool needpass;
QString docpath; // save the path for the currently-loaded document
QString doctitle;
QJsonObject jobj;
int degrees;
QList<Bookmark *> bookmarks;
public:
Renderer();
~Renderer();
bool loadMultiThread();
// Information functions (usually needs to be loaded first)
virtual int numPages() { return pnum; }
virtual bool needPassword() { return needpass; }
virtual QString title() { return doctitle; }
virtual QJsonObject properties() { return jobj; }
virtual int hashSize();
virtual QImage imageHash(int pagenum);
virtual QSize imageSize(int pagenum);
virtual int rotatedDegrees() { return degrees; }
virtual QList<Bookmark *> getBookmarks() { return bookmarks; }
// Main access functions
virtual bool loadDocument(QString path, QString password);
virtual void renderPage(int pagenum, QSize DPI, int degrees = 0);
virtual QList<TextData *> searchDocument(QString text, bool matchCase);
virtual void traverseOutline(void *, int);
virtual void handleLink(QWidget *, QString);
virtual TextData *linkList(int, int);
virtual int linkSize(int);
virtual Annotation *annotList(int, int);
virtual int annotSize(int);
virtual Widget *widgetList(int, int);
virtual int widgetSize(int);
virtual void clearHash();
// Makes sure degrees is between 0 and 360 then rotates the matrix and
void setDegrees(int degrees) {
// Mods by 360, but adds and remods because of how C++ treats negative mods
this->degrees = (((this->degrees + degrees) % 360) + 360) % 360;
emit reloadPages(this->degrees);
}
virtual bool isDoneLoading();
virtual bool supportsExtraFeatures();
signals:
void PageLoaded();
void SetProgress(int);
void OrigSize(QSizeF);
void reloadPages(int);
void goToPosition(int, float, float);
};
#endif
|