QTableWidgetItem.itemAt(pos) 在 contextMenu 请求时总是返回 0

Posted

技术标签:

【中文标题】QTableWidgetItem.itemAt(pos) 在 contextMenu 请求时总是返回 0【英文标题】:QTableWidgetItem.itemAt(pos) always returns 0 on contextMenu request 【发布时间】:2011-08-23 13:14:03 【问题描述】:

我有一个插槽,它可以创建一个给定点的上下文菜单。但是,无论我使用哪种方法从该点返回位置,table->itemAt(pos) 始终返回 0。有没有办法打印出表格行/列的位置,以便我可以对一些偏移量进行逆向工程?

我尝试了所有可能的排列,并且总是执行“没有项目”....

void test::newContextMenu(const QPoint& point)

QPoint pos = table_->viewport()->mapFromGlobal(point); //also tried
//table_->mapFromGlobal(point), table_>viewport()->mapToGlobal(point)
//table_->mapToGlobal(point), and QCursor::pos()

QAction* action tableMenu_->exec(pos);
if(action == XX)

QTableWidgetItem* item = table_->itemAt(pos);
if(!item)

 ///no item

....

【问题讨论】:

【参考方案1】:

您对 itemAt() 的调用应该使用 point,它位于小部件的本地坐标中,而不是位于全局坐标中的 pos

【讨论】:

谢谢。这么简单的事情浪费了几个小时。我什至为 pos 迭代了一个 +/- 500 的偏移量,并且返回的项目仍然从未非零。 欢迎来到 SO @jim!如果您的问题得到解答,请确保通过单击检查将最佳答案标记为已接受。

以上是关于QTableWidgetItem.itemAt(pos) 在 contextMenu 请求时总是返回 0的主要内容,如果未能解决你的问题,请参考以下文章

Lua table直接索引VS缓存索引性能测试小示例

*p++(*p)++*++p++*p 的区别

++*p,(*p)++,*p++与*++p四者的区别

模运算

(*p)++和*(p++)和*p++的区别

*a=p和*a=&p的区别是啥呀 *a=p是否相当于a=&p