关于QT自定义控件 您所在的位置:网站首页 qt自定义model 关于QT自定义控件

关于QT自定义控件

#关于QT自定义控件| 来源: 网络整理| 查看: 265

作者:冯利美,华清远见嵌入式培训中心讲师。

Linux中I/O设备分为两类:块设备和字符设备。两种设备本身没有严格限制,但是,基于不同的功能进行了分类。

用户自定义的控件可以通过继承现有的 Qt 控件实现,也可以直接从 QWidget 继承。QT中的label控件,没有预定义的单击信号。有时需要单击一个label控件来执行某些动作。如下图:

要实现上图的效果,我们可以自定义自己的label控件,操作步骤如下:

1) 新建一个类,从现有的QLabel继承。

2) 在新类中,自定义一个单击信号,并重写mousePressEvent和mouseMoveEvent事件。代码示例如下:

class MyLabel : public QLabel         {                 Q_OBJECT         public:                 explicit MyLabel(QWidget *parent = 0);         protected:                 void mousePressEvent ( QMouseEvent * ev );                 void mouseMoveEvent ( QMouseEvent * ev );         signals:                 void clicked();         };

MyLabel::MyLabel(QWidget *parent) :                 QLabel(parent)         {                 this->setMouseTracking(true);         }         void MyLabel::mousePressEvent ( QMouseEvent * ev )         {                 this->setCursor(Qt::PointingHandCursor);                 emit this->clicked();         }         void MyLabel::mouseMoveEvent ( QMouseEvent * ev )         {                 this->setCursor(Qt::PointingHandCursor);         }

以上代码中,当鼠标按下时,发自定义信号,当鼠标经过label控件时,鼠标形状会有变化。关于如何使用自定义的控件,见下图:

选中label. Promote to MyLabel.即可。并在构造函数中关联自定义控件的单击信号:

MainWindow::MainWindow(QWidget *parent) :                 QMainWindow(parent),                 ui(new Ui::MainWindow)         {                 ui->setupUi(this);                 QObject::connect(ui->label, SIGNAL(clicked()),this, SLOT(fun()));         }         void MainWindow::fun()         {                 QMessageBox::information(this, "dd", "clicked test");         }

点击注册,弹出消息框。 嵌入式及3G相关资源及学习请点击:嵌入式开发视频 android开发视频 android培训 3G培训 QT培训 QT开发视频 物联网培训 物联网技术视频 嵌入式学习    



【本文地址】

公司简介

联系我们

今日新闻

    推荐新闻

    专题文章
      CopyRight 2018-2019 实验室设备网 版权所有