- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我创建了一个自定义 QListWidget,其中添加了自定义列表小部件(在本例中只是 QPushButton 小部件),所有设置都添加到它的 QListWidgetItems 中,以便我可以从 QPushButton 拖放,以向 QListWidget 添加另一个按钮。在第一个列表小部件中,您会注意到两个列表小部件项目之间有一条虚线,表示您可以在两个现有小部件之间拖动并插入小部件。然而,通过我的自定义列表,我失去了这种行为。我仍然可以将它们放在现有的小部件之间,但是没有像以前那样向用户提供视觉指示,即两个小部件之间将插入的水平条。有谁知道我会怎么做?您可以在下图中看到,第一个列表中的行是在两个列表之间插入项目的默认指示符。红色箭头指向我想要创建的那种自定义插入指示器。
其次,当我从自定义 QPushButton 中拖放时,它会突出显示为黑色,但再也不会返回到正常的灰色,如上图所示。我怎样才能让这个按钮恢复到默认状态?
from inspect import isclass
from shiboken2 import wrapInstance
from PySide2 import QtCore, QtGui, QtWidgets
from maya import OpenMayaUI as omui
def show_ui():
main_win_obj = omui.MQtUtil.mainWindow()
main_win = wrapInstance(long(main_win_obj), QtWidgets.QWidget)
win = Test(parent=main_win)
win.show()
class DragButton(QtWidgets.QPushButton):
def __init__(self, parent=None, text=''):
super(DragButton, self).__init__()
self.setText(text)
def mouseMoveEvent(self, event):
if event.buttons() != QtCore.Qt.LeftButton:
super(DragButton, self).mouseMoveEvent(event)
return
btn_img = self.grab()
painter = QtGui.QPainter(btn_img)
painter.setCompositionMode(
painter.CompositionMode_DestinationIn
)
painter.fillRect(btn_img.rect(), QtGui.QColor(0, 0, 0, 127))
painter.end()
data = QtCore.QMimeData()
data.setText('ReorderListAdd()')
drag = QtGui.QDrag(self)
drag.setMimeData(data)
drag.setPixmap(btn_img)
drag.setHotSpot(event.pos())
drag.exec_(QtCore.Qt.CopyAction)
super(DragButton, self).mouseMoveEvent(event)
def mouseReleaseEvent(self, event):
data = QtCore.QMimeData()
data.setText('my text')
drag = QtGui.QDrag(self)
drag.setMimeData(data)
drag.exec_()
super(DragButton, self).mouseReleaseEvent(event)
class ReorderList(QtWidgets.QListWidget):
def __init__(self, parent=None):
super(ReorderList, self).__init__(parent)
self.setDragDropMode(
QtWidgets.QAbstractItemView.InternalMove
)
self.setAcceptDrops(True)
self.setAlternatingRowColors(True)
self.setSelectionMode(
QtWidgets.QAbstractItemView.SingleSelection
)
self.setDragDropMode(
QtWidgets.QAbstractItemView.InternalMove
)
def add_btn(self, text='', index=-1):
widget = QtWidgets.QWidget()
if not text:
text = 'item {0}'.format(self.count() + 1)
btn = QtWidgets.QPushButton(text)
layout = QtWidgets.QVBoxLayout(widget)
layout.setContentsMargins(2, 2, 2, 2)
layout.setSpacing(2)
layout.addWidget(btn)
item = QtWidgets.QListWidgetItem()
item.setSizeHint(widget.sizeHint())
if index < 0:
self.addItem(item)
else:
self.insertItem(index, item)
self.setItemWidget(item, widget)
def dropEvent(self, event):
drop_index = self.indexAt(event.pos()).row()
self.add_btn(index=drop_index)
super(ReorderList, self).dropEvent(event)
def dragEnterEvent(self, event):
event.accept()
def dragMoveEvent(self, event):
event.accept()
def onClick(self):
print self.sender().text()
class Test(QtWidgets.QMainWindow):
def __init__(self, *args, **kwargs):
super(Test, self).__init__(*args, **kwargs)
self.list1 = QtWidgets.QListWidget()
self.list1.setDragDropMode(
QtWidgets.QAbstractItemView.DragDrop
)
self.list1.setSelectionMode(
QtWidgets.QAbstractItemView.SingleSelection
)
self.list1.setDragDropMode(
QtWidgets.QAbstractItemView.InternalMove
)
self.list1.setMaximumHeight(60)
self.list2 = ReorderList()
self.list2.setMaximumHeight(120)
for name in ('item 1', 'item 2', 'item 3'):
item = QtWidgets.QListWidgetItem(name)
self.list1.addItem(item)
self.list2.add_btn(text=name)
self.btn = DragButton(text='Add list button')
self.btn.clicked.connect(self.list2.add_btn)
self.widget = QtWidgets.QWidget()
self.setCentralWidget(self.widget)
self.layout = QtWidgets.QVBoxLayout(self.widget)
for item in (self.list1, self.list2, self.btn):
self.layout.addWidget(item)
if __name__ == '__main__':
app = QtWidgets.QApplication(sys.argv)
win = Test()
win.show()
sys.exit(app.exec_())
我希望在 QListWidget 中插入小部件时能够有一个水平条,并使已药物的按钮返回到默认颜色。
以下是我可以找到的一些类似链接,帮助我做到这一点:
最佳答案
由于拖放是自定义的,因此您必须进行绘制,因此您必须在 DragMoveEvent 方法中使用 QModelIndex 检测项目的矩形。然后进行绘画,但由于小部件的大小,它不会被看到,所以我看了一下,我创建了一个修改编辑器几何形状的委托(delegate)。
class Delegate(QtWidgets.QStyledItemDelegate):
def updateEditorGeometry(self, editor, option, index):
super(Delegate, self).updateEditorGeometry(editor, option, index)
geo = editor.geometry().adjusted(0, 4, 0, 0)
editor.setGeometry(geo)
class ReorderList(QtWidgets.QListWidget):
def __init__(self, parent=None):
super(ReorderList, self).__init__(parent)
delegate = Delegate(self)
self.setItemDelegate(delegate)
self.dropIndicatorRect = QtCore.QRect()
self.setDragDropMode(
QtWidgets.QAbstractItemView.InternalMove
)
self.setAcceptDrops(True)
self.setAlternatingRowColors(True)
self.setSelectionMode(
QtWidgets.QAbstractItemView.SingleSelection
)
self.setDragDropMode(
QtWidgets.QAbstractItemView.InternalMove
)
def add_btn(self, text='', index=-1):
widget = QtWidgets.QWidget()
if not text:
text = 'item {0}'.format(self.count() + 1)
btn = QtWidgets.QPushButton(text)
item = QtWidgets.QListWidgetItem()
item.setSizeHint(btn.sizeHint())
if index < 0:
self.addItem(item)
else:
self.insertItem(index, item)
self.setItemWidget(item, btn)
def dropEvent(self, event):
drop_index = self.indexAt(event.pos()).row()
self.add_btn(index=drop_index)
self.dropIndicatorRect = QtCore.QRect()
self.viewport().update()
super(ReorderList, self).dropEvent(event)
def dragEnterEvent(self, event):
event.accept()
def dragLeaveEvent(self, event):
self.dropIndicatorRect = QtCore.QRect()
self.viewport().update()
super(ReorderList, self).dragLeaveEvent(event)
def dragMoveEvent(self, event):
event.accept()
def onClick(self):
print(self.sender().text())
def dragMoveEvent(self, event):
index = self.indexAt(event.pos())
if index.isValid():
rect = self.visualRect(index)
if self.dropIndicatorPosition() == QtWidgets.QAbstractItemView.OnItem:
self.dropIndicatorRect = rect
else:
self.dropIndicatorRect = QtCore.QRect()
else:
self.dropIndicatorRect = QtCore.QRect()
self.viewport().update()
super(ReorderList, self).dragMoveEvent(event)
def paintEvent(self, event):
super(ReorderList, self).paintEvent(event)
if not self.dropIndicatorRect.isNull() and self.showDropIndicator():
painter = QtGui.QPainter(self.viewport())
p = QtGui.QPen(painter.pen())
p.setWidthF(1.5)
painter.setPen(p)
r = self.dropIndicatorRect
painter.drawLine(r.topLeft(), r.topRight())
关于python - QListWidget:如何拖放插入带有图标的自定义小部件?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54684840/
好的,所以我编辑了以下... 只需将以下内容放入我的 custom.css #rt-utility .rt-block {CODE HERE} 但是当我尝试改变... 与 #rt-sideslid
在表格 View 中,我有一个自定义单元格(在界面生成器中高度为 500)。在该单元格中,我有一个 Collection View ,我按 (10,10,10,10) 固定到边缘。但是在 tablev
对于我的无能,我很抱歉,但总的来说,我对 Cocoa、Swift 和面向对象编程还很陌生。我的主要来源是《Cocoa Programming for OS X》(第 5 版),以及 Apple 的充满
我正在使用 meta-tegra 为我的 NVIDIA Jetson Nano 构建自定义图像。我需要 PyTorch,但没有它的配方。我在设备上构建了 PyTorch,并将其打包到设备上的轮子中。现
在 jquery 中使用 $.POST 和 $.GET 时,有没有办法将自定义变量添加到 URL 并发送它们?我尝试了以下方法: $.ajax({type:"POST", url:"file.php?
Traefik 已经默认实现了很多中间件,可以满足大部分我们日常的需求,但是在实际工作中,用户仍然还是有自定义中间件的需求,为解决这个问题,官方推出了一个 Traefik Pilot[1] 的功
我想让我的 CustomTextInputLayout 将 Widget.MaterialComponents.TextInputLayout.OutlinedBox 作为默认样式,无需在 XML 中
我在 ~/.emacs 中有以下自定义函数: (defun xi-rgrep (term) (grep-compute-defaults) (interactive "sSearch Te
我有下表: 考虑到每个月的权重,我的目标是在 5 个月内分散 10,000 个单位。与 10,000 相邻的行是我最好的尝试(我在这上面花了几个小时)。黄色是我所追求的。 我试图用来计算的逻辑如下:计
我的表单中有一个字段,它是文件类型。当用户点击保存图标时,我想自然地将文件上传到服务器并将文件名保存在数据库中。我尝试通过回显文件名来测试它,但它似乎不起作用。另外,如何将文件名添加到数据库中?是在模
我有一个 python 脚本来发送电子邮件,它工作得很好,但问题是当我检查我的电子邮件收件箱时。 我希望该用户名是自定义用户名,而不是整个电子邮件地址。 最佳答案 发件人地址应该使用的格式是: You
我想减小 ggcorrplot 中标记的大小,并减少文本和绘图之间的空间。 library(ggcorrplot) data(mtcars) corr <- round(cor(mtcars), 1)
GTK+ noob 问题在这里: 是否可以自定义 GtkFileChooserButton 或 GtkFileChooserDialog 以删除“位置”部分(左侧)和顶部的“位置”输入框? 我实际上要
我正在尝试在主页上使用 ajax 在 magento 中使用 ajax 显示流行的产品列表,我可以为 5 或“N”个产品执行此操作,但我想要的是将分页工具栏与结果集一起添加. 这是我添加的以显示流行产
我正在尝试使用 PasswordResetForm 内置函数。 由于我想要自定义表单字段,因此我编写了自己的表单: class FpasswordForm(PasswordResetForm):
据我了解,新的 Angular 7 提供了拖放功能。我搜索了有关 DnD 的 Tree 组件,但没有找到与树相关的内容。 我在 Stackblitz 上找到的一个工作示例.对比drag'ndrop功能
我必须开发一个自定义选项卡控件并决定使用 WPF/XAML 创建它,因为我无论如何都打算学习它。完成后应该是这样的: 到目前为止,我取得了很好的进展,但还有两个问题: 只有第一个/最后一个标签项应该有
我要定制xtable用于导出到 LaTeX。我知道有些问题是关于 xtable在这里,但我找不到我要找的具体东西。 以下是我的表的外观示例: my.table <- data.frame(Specif
用ejs在这里显示日期 它给我结果 Tue Feb 02 2016 16:02:24 GMT+0530 (IST) 但是我需要表现为 19th January, 2016 如何在ejs中执行此操作?
我想问在 JavaFX 中使用自定义对象制作 ListView 的最佳方法,我想要一个每个项目如下所示的列表: 我搜了一下,发现大部分人都是用细胞工厂的方法来做的。有没有其他办法?例如使用客户 fxm
我是一名优秀的程序员,十分优秀!