問題タブ [qstyleditemdelegate]

For questions regarding programming in ECMAScript (JavaScript/JS) and its various dialects/implementations (excluding ActionScript). Note JavaScript is NOT the same as Java! Please include all relevant tags on your question; e.g., [node.js], [jquery], [json], [reactjs], [angular], [ember.js], [vue.js], [typescript], [svelte], etc.

0 投票する
1 に答える
582 参照

python - QTableView セルに調整可能なテキストを描画する

QTableView の QStyledItemDelegate をサブクラス化する必要があります。具体的には、特定の列の表示を変更する必要があります。通常、この列のセルにはテキストが含まれています。これは私のカスタム QStyledItemDelegate クラスの一部です:

しかし、このように表示しようとすると、少し問題があります。

期待される:

期待される

現実:

現実

期待どおりの画像を得るには、StyledItemDelegate のこの列で何もする必要はありません。それと同じことをする必要がありますが、関数 drawText を使用します。

何か考えはありますか?

0 投票する
1 に答える
669 参照

c++ - QStyledItemDelegate で QStandardItem の選択動作を調整する

QStyledItemDelegateのアイテムのスタイルを設定するために使用していQTreeViewます。

私のツリービューのルートは装飾されていません。以下のような関係を持つ単純なツリーです。

親と子のスタイルが異なり、親の選択が無効になっています。

子ノードの選択動作をカスタマイズして、子の周りの選択長方形がテキストの子だけではなく行全体をカバーするようにしたいと考えています。

現在の動作:

ここに画像の説明を入力

望ましい動作:

ここに画像の説明を入力

を使用して、このように選択長方形を拡張する方法はありますQStyledItemDelegateか? adjustingrectinQStyleOptionViewItemパラメータを試してみましたQStyledItemDelegate::paint。しかし、それは子ノードのテキストを左に移動しました。テキストノードを同じ場所に保持したいのですが、選択長方形だけを左に調整する必要があります。したがって、ペイント メソッドでテキストとピックスマップを描画するのと同じように、選択長方形も描画する方法があります (既定の選択長方形の色を使用)。

私の StyledItemDelegate のペイント方法は次のとおりです。

QStyledItemDelegate::paint メソッドで次のコードを使用しています。

0 投票する
2 に答える
616 参照

qt - customdelegate の QWidget(Combobox) へのアクセスポインタ

からクラスを派生させましたQStyledItemDelegateQComboBoxこのデリゲートでa を使用しています。このデリゲートは で使用されQTableViewます。

私の質問は、デリゲートのコンボボックスのインデックスをプログラムで変更するにはどうすればよいですか。つまり、デリゲート クラスの外でそのウィジェットへのポインタにアクセスする方法です。CreateEditorコンボボックスをクリックするとSetEditorDataSetModelData関数 (のQStyledItemDelegate) が自動的に呼び出され、モデル内のデータを操作するために手動で呼び出すことはできないことを確認しました。

0 投票する
1 に答える
1241 参照

qt - カスタム QStyledItemDelegate のような背景を描画します

テーブルがあり、qt ドキュメントの例に従ってカスタム デリゲートを追加しようとしています。ただし、行が選択されている場合、背景色は正しいように見えますが、オーバーレイが表示されていないように見えます (評価セルと行の残りの部分との間の青色の背景を持つ列の違いに注意してください)。標準デリゲートのように背景を描画する最も簡単な方法は何ですか?

QItemDelegateがあるようですが、 にはそのdrawBackgroundような機能はありませんQStyledItemDelegate。残念ながらdrawBackground、左のセルに表示されるわずかに明るい長方形 (背景よりも上下が 1 ピクセル小さい) も省略されています。

ここに画像の説明を入力

0 投票する
1 に答える
1668 参照

c++ - dataChanged シグナルが ComboBoxDelegate で機能しない

私の問題は次のとおりです。

このように使用されるaQTableViewと aがあります。QStandardItemModel

およびコンボボックスデリゲート:

テーブルのセルの値が(コンボボックスによって)変更されるたびに、新しい値と変更されたセルのインデックスをキャッチする必要がありますdataChaged。モデルに関連付けられた信号を次のように使用しています。

GetChangedValueコンボボックスの値が変更されても、メソッドを呼び出すことはありません。ステップをスキップしていますか?

のコードの下にComboBoxDelegate

}

0 投票する
3 に答える
3630 参照

qt - QTableView セルの中央に QPixmap を描画する

私は非常にうまく機能する QTableView を持っています。最初の列にはいくつかのサムネイルが保持されています。この列の各セルでは、サムネイルは垂直方向の中央にありますが、水平方向の中央にはありません。

本当にデリゲートを使用する必要がありますか? はいの場合、QStyledItemDelegate を使用してそれらを水平方向に中央揃えにする方法は?

0 投票する
1 に答える
436 参照

qt - QTableWidgetItem での描画線のレンダリングの問題

中に線を引きたいQTableWidgetItem。線を引くために、QStyledItemDelegate::paintメソッドを再実装しました。

しかし、スクロールしたり、QTableWidget. 一部のアイテムの描画効果が失われます。

これが私のペイントの実装です:

TableWidget init 関数で、デリゲート項目を次のように設定します

注:各アイテムの色名は として保存していQt::UserDataます。

テーブルの初期化では、線がうまく描画されています。バグは、テーブルで遊んでいるときです。

ここにいくつかのスクリーンショットがあります

スクロール前

スクロール後

行選択後

助言がありますか ?

0 投票する
1 に答える
1356 参照

python - QStyledItemDelegate (PySide/PyQt/Qt) の createEditor の親は何ですか?

私は の を持っていQTreeViewますQStandardItemModel。カスタムデリゲートを使用してデータをペイント/編集しています。createEditorメソッド内でparent.window()、アプリケーション全体のメイン ウィンドウにアクセスするために使用します (別の質問のコードへのリンクについては、以下を参照してください)。

createEditor質問:デリゲートの親は何ですか? 次のパラメータで定義されます。

紛らわしいのは、QStyledItemDelegateが初期化されたときです。そのtype(parent)ために出力すると、ツリーが返されます (このデリゲートを表示するようにしたツリー)。これは私が期待するものです。ただし、メソッドの実装内で同じことを実行して出力すると、単に が返されます。ここから得た提案である実行時に同じ結果が得られます。type(parent)createEditorQWidgetparent.metaObject().className()

QT : オブジェクトのクラス名を取得する

ツリー ビューで定義した属性 ( などparent.rootItem) を取得しようとすると、属性エラーが発生します。それで、ここで何が起こっているのですか?エディタの親は何ですか?

PyQtのドキュメントにはあまり助けがありません:

親引数は、None でない場合、self が PyQt ではなく Qt によって所有されるようにします。QAbstractItemDelegate.createEditor() から再実装されました。index で指定されたアイテムを編集するために使用されるウィジェットを返します。親ウィジェットとスタイル オプションは、エディター ウィジェットの表示方法を制御するために使用されます

これはすべて、ここのソリューションへのコメントで説明されている別の問題のソリューションによって開始されたことに注意してください。

https://stackoverflow.com/a/32928091/1886357