1.QObject类

 

简述

QObject类是所有Qt对象的基类。

QObject是Qt对象模型的核心。 该模型的核心特征是称为信号和槽的对象通信机制。 您可以使用connect()将信号连接到槽,并用disconnect()终止该连接。为了避免信号死循环,你可以调用blockSignals()去终止该对象的信号发射。 保护类型函数connectNotify()和disconnectNotify()可以跟踪连接。
 
QObjects对象在树结构中组织起来。当你创建一个QObject对象,以另一个对象作为父对象时,该对象将自动添加到父对象的children()列表中。父类对象拥有子类对象的所有权,即它将在析构函数中自动删除子类对象。你可以通过findChild()或者findChildren()函数由名称或者类型查找对象。
 
每个对象都有一个objectName(),对象的类名也可以通过metaObject::className()获得。你可以用inherits()函数来判断对象是否继承自另外一个类。
 
当一个对象被删除时,它会发出一个destroy()信号。 您可以捕获此信号,以避免对空指针的引用。
 
QObjects可以通过event()接收事件,也可以过滤其他对象的事件。 有关详细信息,请参阅installEventFilter()和eventFilter()。
 
事件在创建对象的线程中传递。请注意,对于没有线程亲和性(thread()返回零)的QObject,完全不执行事件处理。使用moveToThread()函数来更改对象及其子对象的线程亲和性(如果对象具有父对象则不能被移动)。
 
请注意,对于实现信号和槽机制或动态对象属性,Q_OBJECT宏是必需的。你需要在源文件上运行元对象编译器。我们强烈建议在QObject的所有子类中使用此宏。无论是否使用了信号和槽机制,这样做避免一些奇怪的行为。
 
所有Qt Widget都继承QObject。一个方便的函数isWidgetType()返回一个对象是否是一个Widget。它比qobject_cast <QWidget *>(obj)或obj->inherits("")快很多。
 
 
私有属性
  objectName : QString
  这个属性表示对象的名称,可以用过 objectName()获取和setObjectName()设置对象的名称。
 
信号
  void QObject::destroyed(QObject *obj = 0) [signal]
  这个信号在对象被销毁之前发射,并且不能被阻塞。当这个对象销毁时,其子类对象也跟着销毁。
 
  void QObject::deleteLater() [slot]
  安排对象的销毁。
  当程序返回到创建该对象的消息循环时,删除该对象。如果调用该函数时,消息循环未运行(例如在 QCoreApplication::exec() 之前对对象调用deleteLater()),则在消息循环启动之后,该对象被删除。如果在主消息循环结束之后调用deleteLater()函数,则不会删除该对象。自从Qt4.8,没有消息循环的线程中的对象调用deleteLater(), 则在线
程结束后,该对象被销毁。
  请注意,进入和离开新的消息循环(例如,打开一个模态对话框),将不执行延迟删除。对于要删除的对象,程序必须返回到调用deleteLater()的消息循环。
  注意:多次调用该函数是安全的,因为当第一个延迟删除函数触发时,该对象的挂起事件都要从消息队列中删除。
 
函数
A.static function
  1.bool QObejct::connect(const QObejct* sender, const  char* signal, const QObject* receiver, const char* method, Qt::ConnectionType type =
Qt::AutoConnection) [static]
  这个是我们最常见的用来连接信号和槽的函数。如果连接成功返回true,连接失败返回false。
  2.bool QObject::connect(const QObejct* sender, const  QMetaMethod & signal, const QObject* receiver, const QMetaMethod & method, Qt::ConnectionType type = Qt::AutoConnection) [static]
  Qt中QMetaMethod,元方法类,告诉我们这个方法的很多元信息(比如signature(),parameterTypes(),parameterNames())。判断一个方法是否是元方法
a:元对象系统中(声明了Q_Obejct宏),一个类中的信号或者槽函数都是元函数。
b: 用Q_INVOKABLE宏声明,构造函数也用Q_INVOKABLE宏注册。
  3.bool QObject::disconnect(const QObejct* sender, const  char* signal, const QObject* receiver, const char* method)
  如果信号和槽断开返回true,否则返回false。
  4.bool QObject::disconnect(const QObejct* sender, const  QMetaMethod & signal, const QObject* receiver, const QMetaMethod & method)
  如果信号和槽断开返回true,否则返回false。
  5.const QMeteObject QObject::staticMetaObject
  静态变量储存了这个类的元对象。
  举例 QPushButton::staticMetaObject.className()  // return  "QPushButton"
  6.QString QObject::tr(const char *sourceText,  const char *disambiguation = 0, int n = -1) [static]
 
B.protected function
  1.void QObject::childEvent(QChildEvent *event) [virtual protected]
  这个事件处理函数能在子类重写,来接收子类的事件。参数就是当前事件。
  在添加和删除子类对象时,QEvent::ChildAdded和QEvent::ChildRemoved事件发送给对象(QEvent::ChildAdded和QEvent::ChildRemoved都是QEvent::Type类型,表示一个事件)。在这两种情况下,你只能指望子类对象是QObject或者QWidgt类型(因为ChildAdded时,子类对象并未完全构造。在ChildRemoved时,子类对象已经被破坏)。
  QEvent::ChildPolished事件发送给窗口,当子类对象被抛光或者抛光的子类对象被添加时。当你接收到抛光事件时,子类对象一般是完全构造好了的,但是这也不能确定。
因为在子类对象构造时,你可能接受到很多的抛光事件。
  对于child widget,你总是能接收到一个ChildAdded事件,零个或多个ChildPolished事件,一个ChildRemoved事件。
  ChildPolished事件被忽略,当一个对象添加后马上删除。如果一个子类对象在构造和析构时,被抛光几次。你可能接收到同一个子类对象几次的抛光事件。
 
  2.void QObject::connectNotify(const char * signal) [virtual protected]
  对象中的信号,连接到某东西时。该函数被调用。
  如果你想比较函数中的参数和一个实际信号。使用QLatin1String()函数和SIGNAL()宏。
  if(QLatin1String(signal) == SIGNAL(valueChanged(int)))  比较参数是否是valueChanged(int)信号?
  如果信号包含多个参数或者空格参数,在SIGNAL()宏的结果上调用QMetaObject::normalizedSignature()函数。
 
  3.void QObject::customEvent(QEvent *event) [virtual protected]
  该事件处理程序能在子类中重写,来接收自定义事件。自定义的事件要大于QEvent::User(QEvent::User值是1000)。事件被作为参数随函数传递。
 
  4.void QObject::disconnectNotify(const char * signal) [virtual protected]
  当信号连接到的某个槽断开时,调用该虚函数。
  
  5.int QObject::receivers(const char * signal) const [protected]
  返回信号的连接数。
 
  6.QObject * QObject::sender() const [protected]
  返回对象的指针。信号连接到槽,在槽中调用该函数,返回发射信号的对象的指针。注意:只有在槽中该函数才有用,其他情况下,返回值是0。
 
  7.int QObject::senderSignalIndex() const [protected]
  返回信号这个函数的原函数索引。只有在槽中调用才返回正常值,在其他地方调用返回-1。
  无论信号是否有参数,该函数总返回带参数的信号索引。当你对信号重载时,该方法明显不适用。
 
  8.void QObject::timerEvent(QTimerEvent *event) [virtual protected]
  这个事件处理函数能在子类重写,以接收子类的定时器事件。
  QTimer类提供了更高的接口。定时器事件作为参数传递

关于 QObject 类的更多相关文章

  1. Qt::QObject类

    QObject 类是Qt 所有类的基类. QObject是Qt对象模型的核心.这个模型的中心要素就是一种强大的叫做信号与槽无缝对象沟通机制.你可以用 connect()函数来把一个信号连接到槽,也可以 ...

  2. 1.QObject类

    简述 QObject类是所有Qt对象的基类. QObject是Qt对象模型的核心. 该模型的核心特征是称为信号和槽的对象通信机制. 您可以使用connect()将信号连接到槽,并用disconnect ...

  3. 关于QObject类的一些理解

    QRunnable并没有继承自QObject,所以它和其他QObject组件的通信不能使用传统的信号和槽,要是用信号和槽我们必须将其继承自QObject自动的添加 QThread的退出最好用exit( ...

  4. 8、QObject类 moc处理后代码

    QObject在QT中是所有类的基类,经过MOC处理后代码如下 之所以贴出这段代码,是因为很多流程追踪到最后一些关键性函数都是出自这个类 源码 4.8.6 MOC版本 63 1 /********** ...

  5. QObject类 moc处理后代码

    QObject在QT中是所有类的基类,经过MOC处理后代码如下 之所以贴出这段代码,是因为很多流程追踪到最后一些关键性函数都是出自这个类 源码 4.8.6 MOC版本 63 /************ ...

  6. 查漏补缺:QObject类介绍

    QObject是Qt对象模型的中心.这个模型的核心特征就是一种用于无缝对象间通信的被叫做信号和槽的非常强大的机制,可以使用connect()把信号和槽连接起来,也可以通过disconnect()来破坏 ...

  7. Qt:QObject translate

    qobject类是qt所有对象的基类. QObject是Qt的核心对象模型.中心在这个模型是一个非常强大的无缝沟通对象称为信号与槽机制.你可以连接一个信号槽连接()和破坏的连接与断开连接().为了避免 ...

  8. Qt QObject

    [1]Qt的QObject 1.测试代码如下: #include<QApplication> #include<QPushButton> #include<QDebug& ...

  9. 深入了解Qt(一)之QObject

    深入了解Qt主要内容来源于Inside Qt系列,本文做了部分删改,以便于理解.在此向原作者表示感谢! QObject这个 class 是 QT 对象模型的核心,关于对象模型可以阅读C++对象模型详解 ...

随机推荐

  1. 不能支持C++11的特性~,升级到4.8.2

    一.简易安装 操作环境 CentOS6.5 64bit,原版本4.4.7,不能支持C++11的特性~,希望升级到4.8.2 不能通过yum的方法升级,需要自己手动下载安装包并编译 1.1 获取安装包并 ...

  2. Java读入优化

    之前被软院校赛卡了一波T,很亏啊.以下抄袭自Codeforces的神仙Petr. 可能得系统研究Java怎么写了?缺点是不能使用hasNext(),可能需要在main()中解决. import jav ...

  3. 基于ndk_r7_windows编译实现ndk项目,不需要cygwin

    下面就介绍下Android NDK的入门学习过程: 入门的最好办法就是学习Android自带的例子, 这里就通过学习Android的NDK自带的demo程序:hello-jni来达到这个目的. 一. ...

  4. 3DMAX 4角色蒙皮

    1 角色建模 略,以后补充 2 骨骼绑定 一般不用骨骼直接拉,Biped足够,以后适当补充骨骼直接拉的操作 1 将Biped骨骼和模型对齐 1 创建biped之后,第一步一要先选择,然后再对位骨骼到模 ...

  5. [Xcode 实际操作]一、博主领进门-(8)应用代理文件(AppDelegate.swift)详解

    目录:[Swift]Xcode实际操作 本文将演示使用iOS模拟器,演示程序的生命周期. 在项目导航区,打开应用代理文件[AppDelegate.swift] 应用代理文件时系统运行本应用的委托,里面 ...

  6. 受保护的封装 protected

    补充内容:封装 私有化封装 private受保护的封装 protected公共的封装 public 注意:python目前不支持设定受保护的成员,但是开发者由约定的使用方式 受保护的封装:在成员名称前 ...

  7. iOS 更改状态栏、导航栏颜色的几种方法

    ios上状态栏 就是指的最上面的20像素高的部分状态栏分前后两部分,要分清这两个概念,后面会用到: 前景部分:就是指的显示电池.时间等部分:背景部分:就是显示黑色或者图片的背景部分: (一)设置sta ...

  8. [JSOI2015]染色游戏

    Description 棋盘是一个n×m的矩形,分成n行m列共n*m个小方格. 现在萌萌和南南有C种不同颜色的颜料,他们希望把棋盘用这些颜料染色,并满足以下规定: 1.棋盘的每一个小方格既可以染色(染 ...

  9. 利用Common-BeanUtils封装请求参数

    一.BeanUtils介绍 commons-beanutils是利用反射机制对JavaBean的属性进行处理,提供了对于JavaBean的各种处理方法.众所周知,一个JavaBean通常包含了大量的属 ...

  10. Springboot日志配置探索(主要看logback)(一)

    这篇博客是springboot日志配置探索的第一篇,主要讲默认配置下springboot的logback日志框架的配置(即直接使用是怎样的) 首先,是一个SpringBoot的有关日志的说明文档:ht ...