X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fchatline.cpp;h=5c8f1cf32b4a6761e48e821bd055628ba05a7b67;hp=1abfcfb2eb8b39dc227ef0e9fd4cd011ff31f2bb;hb=7c656c77a85636c47d272996df67b9c55f862906;hpb=0b9f74984780aacbe85ca04c44ec6304c86557c2 diff --git a/src/qtui/chatline.cpp b/src/qtui/chatline.cpp index 1abfcfb2..5c8f1cf3 100644 --- a/src/qtui/chatline.cpp +++ b/src/qtui/chatline.cpp @@ -27,57 +27,85 @@ #include "chatline.h" #include "qtui.h" -Chatline::Chatline(const QModelIndex &index, QGraphicsItem *parent) : QGraphicsItem(parent) { - _timestampItem = new ChatItem(QPersistentModelIndex(index.sibling(index.row(), ChatlineModel::TimestampColumn)), this); - _senderItem = new ChatItem(QPersistentModelIndex(index.sibling(index.row(), ChatlineModel::SenderColumn)), this); - _contentsItem = new ChatItem(QPersistentModelIndex(index.sibling(index.row(), ChatlineModel::ContentsColumn)), this); +ChatLine::ChatLine(const QModelIndex &index, QGraphicsItem *parent) : QGraphicsItem(parent) { + _timestampItem = new ChatItem(QPersistentModelIndex(index.sibling(index.row(), ChatLineModel::TimestampColumn)), this); + _senderItem = new ChatItem(QPersistentModelIndex(index.sibling(index.row(), ChatLineModel::SenderColumn)), this); + _contentsItem = new ChatItem(QPersistentModelIndex(index.sibling(index.row(), ChatLineModel::ContentsColumn)), this); - _senderItem->setPos(80, 0); - _contentsItem->setPos(160, 0); + _timestampItem->setPos(0,0); + _width = _height = 0; + _selection = 0; } -Chatline::~Chatline() { +ChatLine::~ChatLine() { + delete _timestampItem; + delete _senderItem; + delete _contentsItem; +} +QRectF ChatLine::boundingRect () const { + //return childrenBoundingRect(); + return QRectF(0, 0, _width, _height); } -QRectF Chatline::boundingRect () const { - return childrenBoundingRect(); +ChatItem *ChatLine::item(ChatLineModel::ColumnType column) const { + switch(column) { + case ChatLineModel::TimestampColumn: return _timestampItem; + case ChatLineModel::SenderColumn: return _senderItem; + case ChatLineModel::ContentsColumn: return _contentsItem; + default: return 0; + } } -void Chatline::paint(QPainter *painter, const QStyleOptionGraphicsItem *option, QWidget *widget) { +qreal ChatLine::setGeometry(qreal width, qreal firstHandlePos, qreal secondHandlePos) { + if(width != _width) prepareGeometryChange(); + qreal firstsep = QtUi::style()->firstColumnSeparator()/2; + qreal secondsep = QtUi::style()->secondColumnSeparator()/2; + + _timestampItem->setWidth(firstHandlePos - firstsep); + _senderItem->setWidth(secondHandlePos - firstHandlePos - (firstsep+secondsep)); + _height = _contentsItem->setWidth(width - secondHandlePos - secondsep); + _senderItem->setPos(firstHandlePos + firstsep, 0); + _contentsItem->setPos(secondHandlePos + secondsep, 0); + + _width = width; + return _height; } -/* -void ChatLine::setColumnWidths(int tsColWidth, int senderColWidth, int textColWidth) { - if(tsColWidth >= 0) { - _tsColWidth = tsColWidth; - _tsItem->setWidth(tsColWidth); - } - if(senderColWidth >= 0) { - _senderColWidth = senderColWidth; - _senderItem->setWidth(senderColWidth); +void ChatLine::setSelected(bool selected, ChatLineModel::ColumnType minColumn) { + if(selected) { + quint8 sel = (_selection & 0x80) | 0x40 | minColumn; + if(sel != _selection) { + _selection = sel; + for(int i = 0; i < minColumn; i++) item((ChatLineModel::ColumnType)i)->clearSelection(); + for(int i = minColumn; i <= ChatLineModel::ContentsColumn; i++) item((ChatLineModel::ColumnType)i)->setFullSelection(); + update(); + } } - if(textColWidth >= 0) { - _textColWidth = textColWidth; - _textItem->setWidth(textColWidth); + else { + quint8 sel = _selection &= 0x80; + if(sel != _selection) { + _selection = sel; + for(int i = 0; i <= ChatLineModel::ContentsColumn; i++) item((ChatLineModel::ColumnType)i)->clearSelection(); + update(); + } } - layout(); } -void ChatLine::layout() { - prepareGeometryChange(); - _tsItem->setPos(QPointF(0, 0)); - _senderItem->setPos(QPointF(_tsColWidth + QtUi::style()->sepTsSender(), 0)); - _textItem->setPos(QPointF(_tsColWidth + QtUi::style()->sepTsSender() + _senderColWidth + QtUi::style()->sepSenderText(), 0)); +void ChatLine::setHighlighted(bool highlighted) { + if(highlighted) _selection |= 0x80; + else _selection &= 0x7f; + update(); } - -bool ChatLine::sceneEvent ( QEvent * event ) { - qDebug() <<(void*)this<< "receiving event"; - event->ignore(); - return false; +void ChatLine::paint(QPainter *painter, const QStyleOptionGraphicsItem *option, QWidget *widget) { + if(_selection & Highlighted) { + painter->fillRect(boundingRect(), QBrush(QtUi::style()->highlightColor())); + } + if(_selection & Selected) { + qreal left = item((ChatLineModel::ColumnType)(_selection & 0x3f))->x(); + QRectF selectRect(left, 0, width() - left, height()); + painter->fillRect(selectRect, QApplication::palette().brush(QPalette::Highlight)); + } } -*/ - -