diff options
author | ZackaryWelch <welch.zackary@gmail.com> | 2018-03-30 18:47:20 -0400 |
---|---|---|
committer | ZackaryWelch <welch.zackary@gmail.com> | 2018-03-30 18:47:20 -0400 |
commit | 62727f05297af2894d62630d387fb39e672b4451 (patch) | |
tree | 3c68671e3173fdce7e7994d702c9d3c348f218b6 /src-qt5/desktop-utils/lumina-pdf/PrintWidget.h | |
parent | Reset the default backend renderer to poppler. (diff) | |
download | lumina-62727f05297af2894d62630d387fb39e672b4451.tar.gz lumina-62727f05297af2894d62630d387fb39e672b4451.tar.bz2 lumina-62727f05297af2894d62630d387fb39e672b4451.zip |
Added support for internal links. Code added for Poppler backend but not enabled. Code enabled for MuPDF. Does not support extrnal links yet.
Diffstat (limited to 'src-qt5/desktop-utils/lumina-pdf/PrintWidget.h')
-rw-r--r-- | src-qt5/desktop-utils/lumina-pdf/PrintWidget.h | 66 |
1 files changed, 65 insertions, 1 deletions
diff --git a/src-qt5/desktop-utils/lumina-pdf/PrintWidget.h b/src-qt5/desktop-utils/lumina-pdf/PrintWidget.h index 92d82e11..3860b011 100644 --- a/src-qt5/desktop-utils/lumina-pdf/PrintWidget.h +++ b/src-qt5/desktop-utils/lumina-pdf/PrintWidget.h @@ -22,6 +22,33 @@ #include "Renderer.h" #include "TextData.h" +class LinkItem: public QGraphicsItem { +public: + LinkItem(QGraphicsItem *parent, TextData *_data) : QGraphicsItem(parent), bbox(_data->loc()), data(_data) { + setCacheMode(DeviceCoordinateCache); + setAcceptHoverEvents(true); + } + +QRectF boundingRect() const Q_DECL_OVERRIDE + { return bbox; } + +inline TextData* getData() const + { return data; } + +void paint(QPainter *painter, const QStyleOptionGraphicsItem *option, QWidget *widget) Q_DECL_OVERRIDE +{ + Q_UNUSED(widget); + painter->setClipRect(option->exposedRect); + painter->setBrush(QBrush(QColor(255, 255, 177, 100))); + painter->setPen(QPen(QColor(255, 255, 100, 125))); + painter->drawRect(bbox); +} + +private: + QRectF bbox; + TextData *data; +}; + class PageItem : public QGraphicsItem { public: PageItem(int _pageNum, QImage _pagePicture, QSize _paperSize) @@ -30,6 +57,7 @@ public: brect = QRectF(QPointF(-25, -25), QSizeF(paperSize)+QSizeF(50, 50)); setCacheMode(DeviceCoordinateCache); + setAcceptHoverEvents(true); } QRectF boundingRect() const Q_DECL_OVERRIDE @@ -80,7 +108,6 @@ private: QRectF brect; }; - class PrintWidget : public QGraphicsView { Q_OBJECT @@ -112,6 +139,7 @@ private: double zoomFactor; bool initialized, fitting; QList<QGraphicsItem*> pages; + QHash<int, QList<QGraphicsItem*>> links; int degrees; Renderer *BACKEND; @@ -158,6 +186,42 @@ protected: emit resized(); } + void mouseMoveEvent(QMouseEvent *e) Q_DECL_OVERRIDE { + QGraphicsView::mouseMoveEvent(e); + QGraphicsItem *item = scene->itemAt(mapToScene(e->pos()), transform()); + + if(item) { + LinkItem *link = dynamic_cast<LinkItem*>(item); + if(link) + link->setOpacity(1); + QList<QGraphicsItem*> linkList; + if(PageItem *page = dynamic_cast<PageItem*>(item)) + linkList = page->childItems(); + else + linkList = link->parentItem()->childItems(); + foreach(QGraphicsItem *linkItem, linkList) { + if(dynamic_cast<LinkItem*>(linkItem) == link) + continue; + dynamic_cast<LinkItem*>(linkItem)->setOpacity(0.1); + } + } + } + + void mouseReleaseEvent(QMouseEvent *e) Q_DECL_OVERRIDE { + QGraphicsView::mouseReleaseEvent(e); + QPointF scenePoint = mapToScene(e->pos()); + QGraphicsItem *item = scene->itemAt(scenePoint, transform()); + if(LinkItem *link = dynamic_cast<LinkItem*>(item)) { + PageItem *page = dynamic_cast<PageItem*>(link->parentItem()); + if(!BACKEND->isExternalLink(page->pageNumber()-1, link->getData()->text())) { + BACKEND->handleLink(link->getData()->text()); + }else{ + //Handle external link + } + link->setOpacity(0.1); + } + } + void showEvent(QShowEvent* e) Q_DECL_OVERRIDE { QGraphicsView::showEvent(e); emit resized(); |