在 QstandardItemModel 中添加可点击的 Qlabel

Adding a clickable Qlabel in QstandardItemModel

本文关键字:Qlabel QstandardItemModel 添加      更新时间:2023-10-16

我目前有一个附加到QstandardItemModel的QtableView。我想在每行的最后一列插入一个可点击的 Qlabel。最初我想使用QPushButton,但事实证明它需要额外的开销,所以现在我计划使用可点击的Qlabel。关于我该怎么做的任何建议?如果有人可以使用QStandardItemModel模拟TableView中的单击事件,我将不胜感激

connect(ui.tableView,SIGNAL(clicked(const QModelIndex& ) ), 
    this,SLOT( itemClicked(const QModelIndex& ) ) );
slot:
    void itemClicked( const QModelIndex& idx) {
      int row = idx.row();
      int column = idx.column();
    }

如果您确实只需要一个可点击的标签,您可以创建从 QLabel 派生的类并添加自定义信号来处理点击事件:

class CustomWidget : public QLabel {
Q_OBJECT
public:
explicit CustomWidget(const QString& text, QWidget *parent = 0);
signals:
void released(void);
void clicked(void);
protected:
void mousePressEvent(QMouseEvent* e);
void mouseReleaseEvent(QMouseEvent* e);
private:
bool mousePressed;
};
CustomWidget::CustomWidget(const QString& text, QWidget* parent)
: QLabel(text, parent), mousePressed(false) {
}
void CustomWidget::mousePressEvent(QMouseEvent* e) {
mousePressed = true;
}
void CustomWidget::mouseReleaseEvent(QMouseEvent* e) {
emit released();
if(mousePressed) {
emit clicked();
mousePressed = false;
}
}

完整代码片段:

http://www.qtcentre.org/archive/index.php/t-42296.html?s=e9f0fd408147a1cd1048f252967895a0