Pygtk-combobox-class
PyGTK-ComboBoxクラス
ComboBoxは、あらゆるGUIツールキットの強力で人気のあるウィジェットです。 ユーザーが選択できるアイテムのドロップダウンリストを提供します。 gtk.ComboBoxウィジェットはCellLayoutインターフェースを実装し、アイテムの表示を管理するための多くのメソッドを提供します。
gtk.ComboBoxクラスのオブジェクトはListSoreに関連付けられています。ListSoreは、アイテムのコレクションを表示するウィジェットで使用できるリストモデルです。 アイテムはappend()メソッドでListStoreに追加されます。 さらに、CellRendererTextオブジェクトが作成され、コンボボックスにパックされます。
以下の手順に従って、コンボボックスをセットアップします。
PyGTKは便利なメソッドを提供します—リストストアを使用する代わりにコンボボックスを作成する* gtk.combo_box_new_text()*。 関連する便利なメソッドappend_text()、prepend_text()、insert_text()およびremove_text()は、コンボボックスのコンテンツを管理するために使用されます。
gtk.ComboBoxクラスには次のメソッドがあります-
S.NO | Methods and Description |
---|---|
1 |
set_wrap_width() ポップアップテーブルレイアウトに表示される列の数を設定します |
2 |
get_active() 現在アクティブなアイテムのモデルのインデックスである「アクティブ」プロパティの値を返します |
3 |
set_active() combo_boxのアクティブアイテムを、指定されたモデルインデックスを持つアイテムに設定します。 |
4 |
set_model() コンボボックスで使用されるモデルを設定します |
5 |
append_text() テキストで指定された文字列を、コンボボックスリストストアに保存されている文字列のリストに追加します。 |
6 |
Insert_text() コンボボックスgtk.ListStoreのテキストで指定された文字列を、位置で指定されたインデックスに挿入します |
7 |
prepend_text() テキストで指定された文字列を、リストストアに格納されている文字列のリストの先頭に追加します |
8 |
remove_text() 関連付けられたリストストアの位置で指定されたインデックスの文字列を削除します |
9 |
get_active_text() 現在アクティブな文字列を返します |
ComboBoxウィジェットは次の信号を発します-
changed | This is emitted when a new item in the combo box is selected |
move_active | This is a keybinding signal which gets emitted to move the active selection. |
Popdown | This is a keybinding signal which gets emitted to popdown the combo box list. The default bindings for this signal are Alt+Up and Escape |
Popup | This is a keybinding signal which gets emitted to popup the combo box list. The default bindings for this signal are Alt+Down. |
ComboBoxのデモ用の2つのサンプルコードを以下に示します。
例1
この例では、ListStoreに一般的なPython GUIツールキットの名前が入力され、ComboBoxウィジェットに関連付けられています。 ユーザーが選択すると、変更された信号が出力されます。 ユーザーの選択を表示するコールバック関数に接続されています。
実行すると、プログラムは次の出力を表示します-
例2
プログラムの2番目のバージョンは、コンボボックスとappend_text()関数を作成して文字列を追加するために、便利なメソッド* combo_box_new_text()を使用します。 どちらのプログラムでも、 get_active_text()*メソッドを使用してユーザーの選択を取得し、ウィンドウのラベルに表示します。
このプログラムの出力は、前のプログラムの出力に似ています。