3

問題

  • QTreeViewオブジェクトと、QStandardItemModelウィジェットを表示するためのモデルがあります。
  • 一部のアイテムについてsetDataは、パラメーターを使用してそれらを分割するメソッドを使用してデータを設定しました。
  • そのため、アイコンといくつかのテキストデータを含むアイテムに対して異なる背景のピックスマップを描画する必要があります。QStandardItem
  • そして、すべてのアイテムオブジェクトを再描画したくありません。つまり、アイコンとテキストです。背景を変更するだけです。

最初に、私はそれを考えていました:

  • Qt Designer2つの異なる背景画像を持つオブジェクトにCSSスタイルシートを設定できましたが、メソッド QStandardItem がありません setProperty...

例:

QTreeView#treeView::item[ROLE="AAA"],
QTreeView#treeView::branch[ROLE="AAA"]
{
    height: 25px;
    border: none;
    color: #564f5b;
    background-image: url(:/backgrounds/images/row1.png);
    background-position: top left;
}

QTreeView#treeView::item[ROLE="BBB"],
QTreeView#treeView::branch[ROLE="BBB"]
{
    height: 25px;
    border: none;
    color: #564f5b;
    background-image: url(:/backgrounds/images/row2.png);
    background-position: top left;
}
  • QStyledItemDelegate次に、クラスから継承された独自のデリゲートを作成し、メソッドpaintを再実装しましたが、コードが上書きされるため、バックグラウンドを変更することはできません...QStyledItemDelegate::paint( painter, opt, index );drawPixmap

例:

QStyleOptionViewItemV4 opt = option; // Для обхода QTBUG-4310
opt.state &= ~QStyle::State_HasFocus; // Чтобы не рисовался прямоугольник фокуса 

QStyledItemDelegate::paint( painter, opt, index );    

// HERE I WANT TO CHANGE BACKGROUND (DEFAULT IS ALREADY SET IN DESIGNER WITH ABOVE CODE)
if( index.data( SORT_ROLE ).toBool() )
{
    const QPixmap pixmap( ":/backgrounds/images/backgrounds/contractor_row__high_priority.png" );
    painter->drawPixmap( option.rect, pixmap, pixmap.rect() );

    QStyledItemDelegate::paint( painter, opt, index );
}

だから私は立ち往生しています...

4

2 に答える 2

6

これが私のトリックです:

Designerスタイルシート部分:

QTreeView#treeView
{
    border: none;
    background-color:#f0f0f1;
}   

QTreeView#treeView::item,
QTreeView#treeView::branch
{
    height: 25px;
    border: none;
    color: #564f5b;
}

QTreeView#treeView::item:selected,
QTreeView#treeView::branch:selected
{
    border-bottom: none;
    color: #ffffff;    
    background-image: url(:/backgrounds/images/backgrounds/kontragents_row_selection.png);
    background-position: top left;  

}

QTreeView#treeView::item:selected:!active,
QTreeView#treeView::branch:selected:!active
{
    color: #ffffff;
}

再実装されたpaint()メソッドを委任します。

void paint( QPainter* painter, const QStyleOptionViewItem& option, const QModelIndex& index ) const
 {
      QStyleOptionViewItemV4 opt = option; // Для обхода QTBUG-4310
      opt.state &= ~QStyle::State_HasFocus; // Чтобы не рисовался прямоугольник фокуса

      QBrush brush = opt.backgroundBrush;
      brush.setTexture( QPixmap( index.data( SORT_ROLE ).toBool()
           ? BACKGROUND_HIGH_PRIORITY
           : BACKGROUND_STANDARD ) );

      // FILL BACKGROUND     
      painter->save();
      painter->fillRect( opt.rect, brush );
      painter->restore();

      // DRAW ICON & TEXT
      QStyledItemDelegate::paint( painter, opt, index );

      // IF ( CHILD ) THEN PAINT OVER ONLY! BRANCH RECT
      bool isIndexParent = !index.parent().isValid();
      if( !isIndexParent )
      {
           QRect rect( 0, opt.rect.y(), 20, opt.rect.height() );

           if( opt.state & QStyle::State_Selected )
           {
                brush.setTexture( QPixmap( BACKGROUND_SELECTED ) );
           }

           painter->save();
           painter->fillRect( rect, brush );
           painter->restore();
      }
 }

結果のQTreeViewビュー:

ここに画像の説明を入力してください

良い1日を!:)

PS:アイコン、テキスト、選択を再描画する必要はありません...

于 2012-05-28T12:23:31.177 に答える
1

デリゲートのpaintメソッドはオールオアナッシングであるため、背景をデフォルトの実装と混合することはできません。

ただし、カスタムデリゲートの作成を検討するのに十分な能力がある場合は、背景に加えてアイコンとテキストを描画できるデリゲートを実装しても問題はありません。

于 2012-05-25T16:31:52.007 に答える