- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我的问题是我有 4 个 QListWidget,我希望能够使用 del 键删除每个列表中的选定项目。因此,当我将 del 键连接到一个列表时,它工作正常,但一旦我将它连接到第二个或更多,它就不再工作了。到目前为止,当您只处理一个 QListWidget 时,我只找到示例和解释。有谁知道我在这里做错了什么?
import sys, os
from PySide import QtGui, QtCore
# List item to drag and drop files from windows explorer
class List(QtGui.QListWidget):
def __init__(self, parent):
super(List, self).__init__(parent)
self.setAcceptDrops(True)
self.setSelectionMode(QtGui.QAbstractItemView.MultiSelection)
def dragEnterEvent(self, event):
if event.mimeData().hasUrls:
event.accept()
else:
event.ignore()
def dragMoveEvent(self, event):
if event.mimeData().hasUrls:
event.setDropAction(QtCore.Qt.CopyAction)
event.accept()
else:
event.ignore()
def dropEvent(self, event):
all_items = []
for i in xrange(self.count()):
all_items.append(self.item(i))
url = event.mimeData().urls()
if all_items == []:
for strUrl in url:
self.addItem(strUrl.path()[1:])
else:
for strUrl in url:
if any(item.text() in strUrl.path()[1:] for item in all_items):
continue
else:
self.addItem(strUrl.path()[1:])
def _del_item(self):
for item in self.selectedItems():
self.takeItem(self.row(item))
class MainWindow(QtGui.QWidget):
def __init__(self):
super(MainWindow, self).__init__()
self.init_ui()
def init_ui(self):
folder_list = [' ', 'Concept Art', 'Scripts', 'Storyboard', 'Directors Input', 'Look Dev', 'Corrections',
'References', 'Still References', 'Video References', 'Sound', 'Sound References']
self.box_one = QtGui.QComboBox(parent=self)
self.box_two = QtGui.QComboBox(parent=self)
self.box_three = QtGui.QComboBox(parent=self)
self.box_four = QtGui.QComboBox(parent=self)
for i in folder_list:
self.box_one.addItems([i])
self.box_two.addItems([i])
self.box_three.addItems([i])
self.box_four.addItems([i])
self.list_one = List(self)
self.list_one.setGeometry(0, 0, 500, 100)
self.list_two = List(self)
self.list_two.setGeometry(0, 0, 500, 100)
self.list_three = List(self)
self.list_three.setGeometry(0, 0, 500, 100)
self.list_four = List(self)
self.list_four.setGeometry(0, 0, 500, 100)
# connect del key to lists
del_one = QtGui.QShortcut(QtGui.QKeySequence(QtCore.Qt.Key_Delete), self.list_one)
del_two = QtGui.QShortcut(QtGui.QKeySequence(QtCore.Qt.Key_Delete), self.list_two)
del_three = QtGui.QShortcut(QtGui.QKeySequence(QtCore.Qt.Key_Delete), self.list_three)
del_four = QtGui.QShortcut(QtGui.QKeySequence(QtCore.Qt.Key_Delete), self.list_four)
self.connect(del_one, QtCore.SIGNAL('activated()'), self.list_one._del_item)
self.connect(del_two, QtCore.SIGNAL('activated()'), self.list_two._del_item)
self.connect(del_three, QtCore.SIGNAL('activated()'), self.list_three._del_item)
self.connect(del_four, QtCore.SIGNAL('activated()'), self.list_four._del_item)
v_box = QtGui.QVBoxLayout()
v_box.setSpacing(10)
v_box.addWidget(self.box_one)
v_box.addWidget(self.list_one)
v_box.addWidget(self.box_two)
v_box.addWidget(self.list_two)
v_box.addWidget(self.box_three)
v_box.addWidget(self.list_three)
v_box.addWidget(self.box_four)
v_box.addWidget(self.list_four)
self.setLayout(v_box)
self.setGeometry(100, 100, 500, 190)
self.setWindowTitle('Arx Submitter')
self.show()
def main():
app = QtGui.QApplication(sys.argv)
main_win = MainWindow()
sys.exit(app.exec_())
if __name__ == '__main__':
main()
最佳答案
我将 keyPressEvent
添加到 List
类,在这个事件中我检查按下的键是否是 del 键,如果是,调用 _del_item
方法。我还向 mainWindow
添加了 addItems
方法,以将一些项目添加到 listWidgets。这很好用。我为 del key 注释掉了你的连接。
只需复制并粘贴此代码,运行它并尝试删除项目;)
import sys, os
from PySide import QtGui, QtCore
from PySide.QtCore import Qt
# List item to drag and drop files from windows explorer
class List(QtGui.QListWidget):
def __init__(self, parent):
super(List, self).__init__(parent)
self.setAcceptDrops(True)
self.setSelectionMode(QtGui.QAbstractItemView.MultiSelection)
def dragEnterEvent(self, event):
if event.mimeData().hasUrls:
event.accept()
else:
event.ignore()
def dragMoveEvent(self, event):
if event.mimeData().hasUrls:
event.setDropAction(QtCore.Qt.CopyAction)
event.accept()
else:
event.ignore()
def dropEvent(self, event):
all_items = []
for i in xrange(self.count()):
all_items.append(self.item(i))
url = event.mimeData().urls()
if all_items == []:
for strUrl in url:
self.addItem(strUrl.path()[1:])
else:
for strUrl in url:
if any(item.text() in strUrl.path()[1:] for item in all_items):
continue
else:
self.addItem(strUrl.path()[1:])
def keyPressEvent(self, event):
if event.key() == Qt.Key_Delete:
self._del_item()
def _del_item(self):
for item in self.selectedItems():
self.takeItem(self.row(item))
class MainWindow(QtGui.QWidget):
def __init__(self):
super(MainWindow, self).__init__()
self.init_ui()
def init_ui(self):
folder_list = [' ', 'Concept Art', 'Scripts', 'Storyboard', 'Directors Input', 'Look Dev', 'Corrections',
'References', 'Still References', 'Video References', 'Sound', 'Sound References']
self.box_one = QtGui.QComboBox(parent=self)
self.box_two = QtGui.QComboBox(parent=self)
self.box_three = QtGui.QComboBox(parent=self)
self.box_four = QtGui.QComboBox(parent=self)
for i in folder_list:
self.box_one.addItems([i])
self.box_two.addItems([i])
self.box_three.addItems([i])
self.box_four.addItems([i])
self.list_one = List(self)
self.addItems(self.list_one)
self.list_one.setGeometry(0, 0, 500, 100)
self.list_two = List(self)
self.addItems(self.list_two)
self.list_two.setGeometry(0, 0, 500, 100)
self.list_three = List(self)
self.addItems(self.list_three)
self.list_three.setGeometry(0, 0, 500, 100)
self.list_four = List(self)
self.addItems(self.list_four)
self.list_four.setGeometry(0, 0, 500, 100)
# connect del key to lists
#del_one = QtGui.QShortcut(QtGui.QKeySequence(QtCore.Qt.Key_Delete), self.list_one)
#del_two = QtGui.QShortcut(QtGui.QKeySequence(QtCore.Qt.Key_Delete), self.list_two)
#del_three = QtGui.QShortcut(QtGui.QKeySequence(QtCore.Qt.Key_Delete), self.list_three)
#del_four = QtGui.QShortcut(QtGui.QKeySequence(QtCore.Qt.Key_Delete), self.list_four)
#self.connect(del_one, QtCore.SIGNAL('activated()'), self.list_one._del_item)
#self.connect(del_two, QtCore.SIGNAL('activated()'), self.list_two._del_item)
#self.connect(del_three, QtCore.SIGNAL('activated()'), self.list_three._del_item)
#self.connect(del_four, QtCore.SIGNAL('activated()'), self.list_four._del_item)
v_box = QtGui.QVBoxLayout()
v_box.setSpacing(10)
v_box.addWidget(self.box_one)
v_box.addWidget(self.list_one)
v_box.addWidget(self.box_two)
v_box.addWidget(self.list_two)
v_box.addWidget(self.box_three)
v_box.addWidget(self.list_three)
v_box.addWidget(self.box_four)
v_box.addWidget(self.list_four)
self.setLayout(v_box)
self.setGeometry(100, 100, 500, 190)
self.setWindowTitle('Arx Submitter')
self.show()
def addItems(self, widget):
for i in range(10):
widget.addItem("Item "+ str(i))
def main():
app = QtGui.QApplication(sys.argv)
main_win = MainWindow()
sys.exit(app.exec_())
if __name__ == '__main__':
main()
关于python - Pyside PyQt,如何将 Key_Delete 连接到 4 个不同的 QListWidget,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21958535/
我正在通过单击 ui 上的按钮更改 QListWidgetItem 标题(QListWidgetItem 文本),在此之下我还调用了 repaint() 和 update(),但标题不会更改(刷新),
我有课 class MyClass { public: QString name; int age; }; ... MyClass* itm1= new MyClass(); itm1
我的应用程序 (Qt 4.6) 要求我在列表中显示某些消息,该列表在添加新行时总是向下滚动(因此最近的行始终可见)。 由于我在包括显示这些单行消息在内的整个过程中遇到性能问题,所以我运行了一些测试并发
我有一个 QListWidget,里面有一些小部件: QListWidgetItem* w = new QListWidgetItem(ui->listWidget); ui->listWidget-
是否可以根据其内容调整 QListWidget 的高度和宽度? sizeHint() 始终返回 256, 192,无论其内容是什么。 QListWidgetItem 的 sizeHint() 返回 -
我用一些项目创建了 QListWidget。 QHBoxLayout* h_layout = new QHBoxLayout; h_layout->setMargin( 0 ); me
我正在 Qt 中创建一个可排序列表。该代码对于向下滚动效果非常好,但是当我在向下滚动列表后获取可拖动项目时遇到一些问题。我添加了一些测试用例屏幕截图以便更好地理解 这是测试用例代码 #incl
我是 Qt 框架的新手。在新应用程序中,我想创建包含自定义项目的列表。这些项目非常简单,必须包含标题标签、缩略图和描述标签 (picture here) 现在我不想玩自定义绘图和所有这些东西,因为我认
我创建了一个自定义 QListWidget,其中添加了自定义列表小部件(在本例中只是 QPushButton 小部件),所有设置都添加到它的 QListWidgetItems 中,以便我可以从 QPu
我有一个带有一系列 QListWidget 的 GUI,第一个 QListWidget 应该有文本项和图标项,图标的标签位于侧面。其他 QListWidget 的项目应与第一个 QListWidget
我在 PySide2 中有一个 QListWidget,我希望所选项目具有不同的颜色。这可能吗?我将附上两张图片来演示。 我目前拥有的: 这就是我想要的: 最佳答案 您必须使用委托(delegate)
我想创建一个包含许多这些项目的 QListView 或 QListWidget。我研究过创建委托(delegate)并使用 setItemWidget 来设置小部件。我在这两方面都遇到困难。 下面是在
我需要在“.ui”文件中的 QListWidget 提出的不同选项中包含文本和希腊符号(用于简单的数学方程)(我以前使用 Qt Designer,如果重要的话我喜欢 python)。我希望选项显示如下
删除QListWidget中的一项后,我在更新它时遇到了一些问题。 这是代码的一部分: class Window(QMainWindow): list_1 = [] #The items are
我想写一个“无限滚动”的列表小部件。滚动应该根据计时器自动发生。不会有任何用户交互。例如,该列表包含项目 0-100。如果滚动区域达到第 100 项,则显示的下一个项目应该是第 1 项,依此类推(如滚
在 Qt 4.6.1 上,当我连接来自 QListWidget 的 itemChanged 信号时,我没有看到每次编辑时的连续发射行为,如中所述 Qt - signal for when QListW
我问这个问题是因为我不知道如何用谷歌搜索它,我找不到合适的关键字。 我有一个包含字符串的QListWidget。字符串很长,如果我禁用水平滚动,这正是我想要的,那么文本以...结尾,因为它太长了。 我
在我的 QMainWindow 构造函数中,我读取了一个数据库并用项目填充了我的 QListWidget。显然没有选择任何项目,所以我必须自己做。我还有一个插槽,当我单击列表中的项目时将调用它。 我试
我有一个包含多个项目的 QListWidget,每个项目都像一个按钮,在单击时做出响应。我遇到了一个问题,如果您单击一个项目并将鼠标拖动到屏幕上除您单击的项目之外的任何其他位置,那么程序将导致段错误并
如何使我的 QListWidget 高度与我的主窗口相同? 因此,如果我更改主窗口,它必须调整大小,如果无法在小部件中查看所有列表,则使滚动条可见,等等。 最佳答案 Qt 有一个叫做 layouts
我是一名优秀的程序员,十分优秀!