主な問題は次のとおりです。QTreeWidget
クラスをメインツリーとして使用しています。これは、このツリー構造を表示する必要があります。
[Today]
[Row1]
[Row2]
[SubRow21]
[SubRow22]
[Row3]
[Yesterday]
[Row4]
[SubRow41]
[etc]
QtDesigner
では、このスタイル シート コードを設定しました。
QTreeWidget#treeWidget::item
{
height: 24px;
border: none;
background-position: bottom left;
background-image: url(:/backgrounds/images/backgrounds/row_back.png);
}
QTreeWidget#treeWidget::item:selected
{
color: #000000;
background-position: bottom left;
background-image: url(:/spreadsheet/images/spreadsheet/row_back_selected.png);
}
すべてのアイテムは * row_back.png * 背景画像で描画されますが、 [今日]行と[昨日]行には別の背景画像を描画する必要があります。これらの目的のために、スタイルを新しい背景画像にリセットするために、クラスを継承QStyledItemDelegate
しましたが、メソッドはわかりません。
void MyColumnDelegate::paint( QPainter* painter, const QStyleOptionViewItem& option, const QModelIndex& index ) const
{
QStyleOptionViewItemV4 op = option;
if( isPeriod( index ) )
{
// here I heed to change background image!!!
//QStyle* style = op.widget ? op.widget->style() : QApplication::style();
//style->drawControl( QStyle::CE_ItemViewItem, &op, painter, op.widget );
//QRect backgroundRect( option.rect.x() + 5, option.rect.y() + 5, 18, 18 );
//style->drawItemPixmap( painter, backgroundRect, Qt::AlignCenter, QPixmap( SOME_PIC ) );
//QStyledItemDelegate::paint( painter, op, index );
return;
}
op.text = "";
QStyle* style = op.widget ? op.widget->style() : QApplication::style();
style->drawControl( QStyle::CE_ItemViewItem, &op, painter, op.widget );
QModelIndex dataIndex = index.model()->index( index.row(), ePosChain, index.parent() );
LetterInfo data = index.model()->data( dataIndex, PackageDataRole ).value< LetterInfo >();
switch( data.document_.state_ )
{
case( eStateSignedByOwner ):
painter->drawPixmap( getPos( op, index, QPixmap( IMAGE2 ) ), QPixmap( IMAGE2 ) );
break;
case( eStateSignedByHost ):
painter->drawPixmap( getPos( op, index, QPixmap( IMAGE1 ) ), QPixmap( IMAGE1 ) );
break;
}
painter->drawText( getTextPos( op, index ), data.text );
}
何か助けはありますか?
ありがとう!