5. Radio Button
今回は「Radio Button」を中心に使い方などを解説していきます。
だだし作業手順などはこれまでの講座を参考にして下さい。
Python で GUI アプリケーション
また、今回利用する素材などは、次の zip ファイルに纏めてあります。
なお、アイコンなどは「ICOOON MONO」から利用させて頂きました。
Radio Button とは?
Radio Button は複数の選択から1つを選択する事が可能なボタンの事を言います。
data:image/s3,"s3://crabby-images/9f47c/9f47cd488fa9b09d5ef5ce3b35cacf620568dcb1" alt=""
しかしそのためにはグルーピングを行う必要があり、そのために「Group Box」を用います。
data:image/s3,"s3://crabby-images/2ba07/2ba0762f2ac65ef8262d185bbd543ebb8fa44c7f" alt=""
従って、Radio Button を設置するためには、先ず Group Box の配置から行う必要があります。
この時、Group Box 内に配置された Radio Button は自動的に1つしか選択できなくなります。
また、Group Box 内を右クリックする事により、レイアウトを適用する事も可能です。
また、Group Box にはラベルが付属していますので、何に対する選択なのかを記述しておくのが良いでしょう。(ここでは「フルーツ」としています)
data:image/s3,"s3://crabby-images/fd9c4/fd9c4c8adea5f62d6a2ecb63b2ea31dda708ed70" alt=""
Radio Button のグループが作成できた場合は、1つの Radio Button だけをチェックしておく必要があります。
data:image/s3,"s3://crabby-images/397fa/397faacf41e2bca9fae874c414c54eb503b05fc9" alt=""
この例では、リンゴの Radio Button をチェックしてあります。
ダイアログ
Radio Button の動作を確認するために、次のようなダイアログを作成しました。
data:image/s3,"s3://crabby-images/6cfae/6cfae574d1dcec638b8477dfe6d23641768d7d92" alt=""
オブジェクトは以下のような構造です。(画像は QLabel で作成しています)
data:image/s3,"s3://crabby-images/7920d/7920ddd4d0b0546dd50a5fc0d71f3f31c5cc738e" alt=""
シグナル/スロットは次の様に設定しています。
data:image/s3,"s3://crabby-images/ccd3d/ccd3d40f0053ec2bf6397e28ccbb6ccf7c42a3f5" alt=""
プロジェクト
プロジェクトは次のとおりです。
data:image/s3,"s3://crabby-images/a87e7/a87e7fcc63224f5b1a6a331e1d6eb5a50c8b5a95" alt=""
ソース
ソースは次のとおりです。 今回のポイントはバナナと桃の画像を非表示にしている事です。
#!/usr/bin/env python # This Python file uses the following encoding: utf-8 import sys from PySide6.QtWidgets import QApplication from PySide6.QtUiTools import loadUiType if __name__ == "__main__": # アプリケーションの開始 app = QApplication(sys.argv) # ダイアログファイルを読み込み専用でオープンし、ダイアログデータの読み込み generated_class, base_class = loadUiType("dialog.ui") window = base_class() form = generated_class() form.setupUi(window) #バナナと桃の画像の非表示 form.my_bananaLabel.hide() form.my_peachLabel.hide() # ダイアログの表示 window.show() # イベントループの実行 sys.exit(app.exec())
実行
data:image/s3,"s3://crabby-images/1cbe4/1cbe482efc56fa577a3cad3a77e5ca3b81e3bad9" alt=""
data:image/s3,"s3://crabby-images/72f20/72f20a9be000f9faf9fce5271c29cb7c0ca1ecd6" alt=""
data:image/s3,"s3://crabby-images/9b5b1/9b5b16792ed2acbb5ca2273293f6aa47fd6caace" alt=""
その他
Radio Button に関する詳しい資料。QGroupBox, QRadioButton
次回
data:image/s3,"s3://crabby-images/5b087/5b087b78cc5dcb3dde0f1d6a87138cea8cb5576d" alt="Follow us on Facebook Facebook"
data:image/s3,"s3://crabby-images/6478e/6478e79173566f3036f08d7e315165fe4d9dcfda" alt="Follow us on Twitter twitter"
data:image/s3,"s3://crabby-images/8701e/8701ef7f8d945bdb748f5600f9b43d43ef76d040" alt="Check out our foursquare feed foursquare"
[…] 5. Radio Button […]