X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fchatline.cpp;h=0e4df2268c91a944df1c165e9c93fa0291857464;hp=5f03d9d09a74b52cf363cecbb38c9b10c2913c76;hb=ba9de06a8634a30863d54001cb8f934746333d58;hpb=2c1463264301d5cc5b75b65a5924fb91e33d66dc diff --git a/src/qtui/chatline.cpp b/src/qtui/chatline.cpp index 5f03d9d0..0e4df226 100644 --- a/src/qtui/chatline.cpp +++ b/src/qtui/chatline.cpp @@ -27,22 +27,19 @@ #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); - - _timestampItem->setPos(0,0); - _width = _height = 0; - _selection = 0; - - if(_contentsItem->data(MessageModel::FlagsRole).toInt() & Message::Highlight) setHighlighted(true); -} - -ChatLine::~ChatLine() { - delete _timestampItem; - delete _senderItem; - delete _contentsItem; +ChatLine::ChatLine(int row, QAbstractItemModel *model, QGraphicsItem *parent) + : QGraphicsItem(parent), + _row(row), // needs to be set before the items + _timestampItem(ChatLineModel::TimestampColumn, model, this), + _senderItem(ChatLineModel::SenderColumn, model, this), + _contentsItem(ChatLineModel::ContentsColumn, model, this), + _width(0), + _height(0), + _selection(0) +{ + Q_ASSERT(model); + QModelIndex index = model->index(row, ChatLineModel::ContentsColumn); + setHighlighted(model->data(index, MessageModel::FlagsRole).toInt() & Message::Highlight); } QRectF ChatLine::boundingRect () const { @@ -50,26 +47,31 @@ QRectF ChatLine::boundingRect () const { return QRectF(0, 0, _width, _height); } -ChatItem *ChatLine::item(ChatLineModel::ColumnType column) const { +ChatItem &ChatLine::item(ChatLineModel::ColumnType column) { switch(column) { - case ChatLineModel::TimestampColumn: return _timestampItem; - case ChatLineModel::SenderColumn: return _senderItem; - case ChatLineModel::ContentsColumn: return _contentsItem; - default: return 0; + case ChatLineModel::TimestampColumn: + return _timestampItem; + case ChatLineModel::SenderColumn: + return _senderItem; + case ChatLineModel::ContentsColumn: + return _contentsItem; + default: + return *(ChatItem *)0; // provoke an error } } qreal ChatLine::setGeometry(qreal width, qreal firstHandlePos, qreal secondHandlePos) { - if(width != _width) prepareGeometryChange(); + 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); + _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); + _senderItem.setPos(firstHandlePos + firstsep, 0); + _contentsItem.setPos(secondHandlePos + secondsep, 0); _width = width; return _height; @@ -80,15 +82,18 @@ void ChatLine::setSelected(bool selected, ChatLineModel::ColumnType minColumn) { 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(); + 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(); } } else { quint8 sel = _selection & 0x80; if(sel != _selection) { _selection = sel; - for(int i = 0; i <= ChatLineModel::ContentsColumn; i++) item((ChatLineModel::ColumnType)i)->clearSelection(); + for(int i = 0; i <= ChatLineModel::ContentsColumn; i++) + item((ChatLineModel::ColumnType)i).clearSelection(); update(); } } @@ -105,7 +110,7 @@ void ChatLine::paint(QPainter *painter, const QStyleOptionGraphicsItem *option, painter->fillRect(boundingRect(), QBrush(QtUi::style()->highlightColor())); } if(_selection & Selected) { - qreal left = item((ChatLineModel::ColumnType)(_selection & 0x3f))->x(); + qreal left = item((ChatLineModel::ColumnType)(_selection & 0x3f)).x(); QRectF selectRect(left, 0, width() - left, height()); painter->fillRect(selectRect, QApplication::palette().brush(QPalette::Highlight)); }