将QLabel与QListWidget选择连接起来

时间:2017-12-29 08:49:02

标签: python python-3.x pyqt qlistwidget qlabel

(我是绝对的PyQt初学者。)

每当用户使用箭头键向下滚动QListWidget中显示的很长选项列表或点击QListWidget中的选项时,我想用软件选项的描述更新QLabel。我已经设法连接点击选项来做我想做的事情,但我无法弄清楚如何检测箭头按键。

这是我到目前为止所做的:

main.ui

<?xml version="1.0" encoding="UTF-8"?>
<ui version="4.0">
 <class>Dialog</class>
 <widget class="QDialog" name="Dialog">
  <property name="geometry">
   <rect>
    <x>0</x>
    <y>0</y>
    <width>341</width>
    <height>244</height>
   </rect>
  </property>
  <property name="windowTitle">
   <string>Dialog</string>
  </property>
  <widget class="QWidget" name="verticalLayoutWidget">
   <property name="geometry">
    <rect>
     <x>10</x>
     <y>10</y>
     <width>321</width>
     <height>231</height>
    </rect>
   </property>
   <layout class="QVBoxLayout" name="verticalLayout">
    <item>
     <widget class="QListWidget" name="lwOptions"/>
    </item>
    <item>
     <widget class="QLabel" name="lbDescription">
      <property name="text">
       <string>TextLabel</string>
      </property>
     </widget>
    </item>
    <item>
     <widget class="QDialogButtonBox" name="buttonBox">
      <property name="standardButtons">
       <set>QDialogButtonBox::Cancel|QDialogButtonBox::Ok</set>
      </property>
     </widget>
    </item>
   </layout>
  </widget>
 </widget>
 <resources/>
 <connections>
  <connection>
   <sender>buttonBox</sender>
   <signal>accepted()</signal>
   <receiver>Dialog</receiver>
   <slot>accept()</slot>
   <hints>
    <hint type="sourcelabel">
     <x>170</x>
     <y>228</y>
    </hint>
    <hint type="destinationlabel">
     <x>170</x>
     <y>121</y>
    </hint>
   </hints>
  </connection>
 </connections>
</ui>

test.py

#!/usr/bin/env python
# -*- coding: utf-8 -*-
import sys
from PyQt5 import uic, QtWidgets
from PyQt5.Qt import QMessageBox

class GUI(QtWidgets.QDialog):
    listOptions = []
    dicDescriptions = {}
    for x in range(0, 100):
        option = 'Option ' + str(x)
        description = 'Description for ' + option
        listOptions.append(option)
        dicDescriptions[option] = description

    def __init__(self):
        super(GUI, self).__init__()
        uic.loadUi('C:/Users/User/Desktop/main.ui', self)
        self.accepted.connect(self.ReadValue)
        self.lwOptions.addItems(self.listOptions)
        self.lwOptions.itemClicked.connect(self.UpdateDescription)
        self.lbDescription.setText(self.dicDescriptions[self.listOptions[0]])

    def UpdateDescription(self):
        currentItem = self.lwOptions.currentItem().text()
        self.lbDescription.setText(self.dicDescriptions[currentItem])

    def ReadValue(self):
        currentItem = self.lwOptions.currentItem().text()
        QMessageBox.information(self, "Selection", "You've selected: " + currentItem)

app = QtWidgets.QApplication(sys.argv)
window = GUI()
window.show()
sys.exit(app.exec_())
  1. 如何检测箭头键并按下并更新QLabel。
  2. 如何将 uic.loadUi 与相对路径一起使用?我试过 uic.loadUi('main.ui',self) uic.loadUi('。/ main.ui',self),但它没有'即使两个文件都在同一个文件夹中,也能正常工作。

1 个答案:

答案 0 :(得分:1)

如果您想获取当前项目,则无需使用itemClicked(),您必须使用每次选择新项目时发出的信号itemSelectionChanged()。导致路径问题是因为路径取决于您执行脚本的位置,它不依赖于脚本的位置,对于这些情况,值得注意的是代码识别文件的完整路径。实施如下:

import os
import sys
from PyQt5 import uic, QtWidgets
from PyQt5.Qt import QMessageBox

class GUI(QtWidgets.QDialog):
    listOptions = []
    dicDescriptions = {}
    for x in range(0, 100):
        option = 'Option ' + str(x)
        description = 'Description for ' + option
        listOptions.append(option)
        dicDescriptions[option] = description

    def __init__(self):
        super(GUI, self).__init__()
        dirname = os.path.dirname(os.path.abspath(__file__))
        uic.loadUi(os.path.join(dirname,'main.ui'), self)
        self.accepted.connect(self.read_value)
        self.lwOptions.addItems(self.listOptions)
        self.lbDescription.setText(self.dicDescriptions[self.listOptions[0]])
        self.lwOptions.itemSelectionChanged.connect(self.update_description)

    def update_description(self):
        currentItem = self.lwOptions.currentItem().text()
        self.lbDescription.setText(self.dicDescriptions[currentItem])

    def read_value(self):
        currentItem = self.lwOptions.currentItem().text()
        QMessageBox.information(self, "Selection", "You've selected: " + currentItem)

if __name__ == '__main__':
    app = QtWidgets.QApplication(sys.argv)
    window = GUI()
    window.show()
    sys.exit(app.exec_())