- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试创建一个支持项目内部移动的 QTreeView 以及一种检测移动源和目标的方法。使用 QTreeWidget 时,我可以覆盖 dropEvent 并执行如下操作:
void MyTreeWidget::dropEvent(QDropEvent* event)
{
QList<QStandardItem*> dragItems = selectedItems();
QTreeView::dropEvent(event);
// here dragItems have been moved to the new places so I can do whatever I want
}
我需要知道源位置和目标位置的原因是能够将命令推送到在底层数据结构中执行相同移动的撤消堆栈。
我现在已经切换到带有 QStandardItemModel 的 QTreeView(创建一个描述底层数据结构的自定义模型将需要太多工作),但它的工作方式似乎有点不同。在调用 QTreeView::dropEvent(...) 之后,它创建并添加了新项目但没有删除旧项目,所以我无法确定新索引,因为一旦删除旧项目它就会改变。我正在使用这个例子来调试它:
#include <QtDebug>
#include <QApplication>
#include <QTreeView>
#include <QtGui/QStandardItemModel>
class MyTreeView : public QTreeView
{
public:
MyTreeView(QWidget* parent=0)
: QTreeView(parent)
{}
void dropEvent(QDropEvent* event) {
qDebug() << "rows before:" << model()->rowCount();
QTreeView::dropEvent(event);
qDebug() << "rows after:" << model()->rowCount();
}
};
int main(int argc, char **argv)
{
QApplication app(argc, argv);
MyTreeView* tree = new MyTreeView();
QStandardItemModel model(3, 1);
for(int r = 0; r < model.rowCount(); r++)
model.setItem(r, 0, new QStandardItem(QString("%0").arg(r)));
tree->setDragEnabled(true);
tree->viewport()->setAcceptDrops(true);
tree->setDefaultDropAction(Qt::MoveAction);
tree->setDropIndicatorShown(true);
tree->setDragDropMode(QAbstractItemView::InternalMove);
tree->setModel(&model);
tree->show();
return app.exec();
}
当我在 Qt 5.4 (Windows 7) 上运行它并拖放一个项目时,我得到以下输出:
rows before: 3
rows after: 4
当使用 QTreeWidget 时,它会说:
rows before: 3
rows after: 3
关于如何解决这个问题有什么想法吗?
最佳答案
有一种更好的方法可以使用 QAbstractItemModel::rowsMoved
来获取移动的项目来自文档:
This signal is emitted after rows have been moved within the model. The items between sourceStart and sourceEnd inclusive, under the given sourceParent item have been moved to destinationParent starting at the row destinationRow.
此外,我还记得在 QQ 中阅读过在项目 View 中使用撤消/重做,我能找到的最佳链接是这个 cached page和一个 French version
关于c++ - 拖放移动后获取新旧 QStandardItem,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30334114/
这个问题在这里已经有了答案: Difference between Property and Field in C# 3.0+ (10 个答案) 关闭 10 年前。 我不明白静态属性之间的区别: p
当元素被拖放时,有没有办法从被拖动的元素中获取 id(或其他属性值)? 例如,在左侧,我有一堆 div,我可以将图像放入其中。右边有一个 div 用来保存图像。当我将图像从右侧拖动到左侧的 div 时
每当我更改其中一个类属性时,我想设置一个修改标志,如下所示 public bool Modified { get; set; } public bool Enabled { get; set { Mo
由于某种原因,我下面的代码曾经可以正常工作,但现在却引发了一个异常: public static async Task HttpPut(string inUrl, string inFilePath)
为什么将 ; 放在最佳实践中?在函数定义的末尾。 例如 var tony = function () { console.log("hello there"); }; 优于: var tony
我在容器内有一个位图。当我拖动容器时,光标变为编辑文本形状,图像也跳到光标的右下角(好像我从左上角拿着图像并拖动它)。 这是我的代码,所以你可以看到我有 RTFM: function createIc
这个问题已经有答案了: C# 3.0 auto-properties — useful or not? [closed] (17 个回答) 已关闭 6 年前。 当我让 Visual Studio 20
以类中的以下代码为例: public class Employee : IEntity { public string FirstName { get; set; } public s
我有 json 数据: { "products": [ { "productId" : 0, "productImg" : "../img/product-ph
这个问题在这里已经有了答案: What is the difference between a field and a property? (33 个答案) 关闭 9 年前。 我在一本书上找到这样声
我正在设置多个方法,想知道如何继续将一个变量(“顶部”变量)传递给不同的方法。 主要方法: public static void Main(string[] args) { i
我正在尝试使用 crontab 编写一个简单的任务,将一些文件从本地复制到 HDFS。我的代码是这样的: #!/bing/ksh ANIO=$(date +"%Y") MES=$(date +"%m"
有人可以告诉我如何使用这个解决方案来解决我的问题吗?我也想限制 id 中包含文本“not”的节点的拖/放。 jsTree drag and drop restrict folders by class
我的情况如下 - 我正在对可能包含链接行的表进行排序: row 1 row 2 row 3 row 4 row 5 我需要的是禁止在.linked-to-p
我想知道是否有人知道是否有一个预先制定的解决方案:我在 ASP.net 网站上有一个列表,我希望用户能够通过拖放对列表进行重新排序。此外,我希望有第二个列表,用户可以将第一个列表中的项目拖到其中。 到
我在理解似乎不一致的方案中的破坏性操作时遇到问题。即为什么下例中bar没有变化 (define foo '(a b)) (define bar foo) (set! foo '(c d)) foo >
我想知道是否有人知道是否有一个预先制定的解决方案:我在 ASP.net 网站上有一个列表,我希望用户能够通过拖放对列表进行重新排序。此外,我希望有第二个列表,用户可以将第一个列表中的项目拖到其中。 到
我在理解似乎不一致的方案中的破坏性操作时遇到问题。即为什么下例中bar没有变化 (define foo '(a b)) (define bar foo) (set! foo '(c d)) foo >
我在我的 Web 应用程序中使用 Ajax ControlToolkit 中的 ModalPopupExtender。我将其 Drag 属性设置为 true,但是当我拖动弹出面板并将其放到新位置时,它
所以,基于this answer ,我有一组可以拖放并卡入到位的 div。唯一的问题是,可拖动的 div 具有不同的高度,我需要它们始终捕捉到目标的底部,而不是顶部。 您可以在this JsFiddl
我是一名优秀的程序员,十分优秀!