From 7c78f651ee68ac7f9028f9a3640d4c8ae808c826 Mon Sep 17 00:00:00 2001 From: Manuel Nickschas Date: Tue, 25 Nov 2008 09:46:12 +0100 Subject: [PATCH] Find clickable at click position rather than relying on it being set by a hover event This might/should fix issues where a single click not always opened a link. At least I can't reproduce this anymore. As a side benefit, it also now ignores mouse movements during click that for some reason sometimes screwed up things. --- src/qtui/chatitem.cpp | 45 +++++++++++++++++++++++++------------------ src/qtui/chatitem.h | 2 ++ 2 files changed, 28 insertions(+), 19 deletions(-) diff --git a/src/qtui/chatitem.cpp b/src/qtui/chatitem.cpp index fcdbca49..97853250 100644 --- a/src/qtui/chatitem.cpp +++ b/src/qtui/chatitem.cpp @@ -463,6 +463,16 @@ QList ContentsChatItem::findClickables() const { return result; } +ContentsChatItem::Clickable ContentsChatItem::clickableAt(const QPointF &pos) const { + qint16 idx = posToCursor(pos); + for(int i = 0; i < privateData()->clickables.count(); i++) { + Clickable click = privateData()->clickables.at(i); + if(idx >= click.start && idx < click.start + click.length) + return click; + } + return Clickable(); +} + QVector ContentsChatItem::additionalFormats() const { // mark a clickable if hovered upon QVector fmt; @@ -490,7 +500,7 @@ void ContentsChatItem::endHoverMode() { void ContentsChatItem::handleClick(const QPointF &pos, ChatScene::ClickMode clickMode) { if(clickMode == ChatScene::SingleClick) { - Clickable click = privateData()->currentClickable; + Clickable click = clickableAt(pos); if(click.isValid()) { QString str = data(ChatLineModel::DisplayRole).toString().mid(click.start, click.length); switch(click.type) { @@ -509,7 +519,7 @@ void ContentsChatItem::handleClick(const QPointF &pos, ChatScene::ClickMode clic } else if(clickMode == ChatScene::DoubleClick) { chatScene()->setSelectingItem(this); setSelectionMode(PartialSelection); - Clickable click = privateData()->currentClickable; + Clickable click = clickableAt(pos); if(click.isValid()) { setSelectionStart(click.start); setSelectionEnd(click.start + click.length); @@ -543,23 +553,20 @@ void ContentsChatItem::hoverLeaveEvent(QGraphicsSceneHoverEvent *event) { void ContentsChatItem::hoverMoveEvent(QGraphicsSceneHoverEvent *event) { bool onClickable = false; - qint16 idx = posToCursor(event->pos()); - for(int i = 0; i < privateData()->clickables.count(); i++) { - Clickable click = privateData()->clickables.at(i); - if(idx >= click.start && idx < click.start + click.length) { - if(click.type == Clickable::Url) { - onClickable = true; - showWebPreview(click); - } else if(click.type == Clickable::Channel) { - // TODO: don't make clickable if it's our own name - // onClickable = true; //FIXME disabled for now - } - if(onClickable) { - setCursor(Qt::PointingHandCursor); - privateData()->currentClickable = click; - update(); - break; - } + Clickable click = clickableAt(event->pos()); + if(click.isValid()) { + if(click.type == Clickable::Url) { + onClickable = true; + showWebPreview(click); + } else if(click.type == Clickable::Channel) { + // TODO: don't make clickable if it's our own name + // onClickable = true; //FIXME disabled for now + } + if(onClickable) { + setCursor(Qt::PointingHandCursor); + privateData()->currentClickable = click; + update(); + return; } } if(!onClickable) endHoverMode(); diff --git a/src/qtui/chatitem.h b/src/qtui/chatitem.h index b0afbfa1..d68f3151 100644 --- a/src/qtui/chatitem.h +++ b/src/qtui/chatitem.h @@ -209,6 +209,8 @@ private: inline ContentsChatItemPrivate *privateData() const; QList findClickables() const; + Clickable clickableAt(const QPointF &pos) const; + void endHoverMode(); void showWebPreview(const Clickable &click); void clearWebPreview(); -- 2.20.1