向类及其所有子类添加功能

Add functionality to class and all of it's subclasses

本文关键字:子类 添加 功能      更新时间:2023-10-16

我有3个类,它们继承自3个不同的类,这些类都继承自QWidget基类。例如:

  1. MyMainWindow : public QMainWindow : public QWidget
  2. MyPushButton : public QPushButton : public QWidget
  3. MyTextEdit : public QTextEdit : public QWidget

我最终会有更多这样的课程。我现在想做的是向我的所有类添加一个通用方法;这意味着它应该被添加到QWidget基类中,但我不能编辑它(我宁愿不为一个方法更改Qt源代码)。

这种行为可能吗?我已经尝试过使用这样的接口:

class MyTextEdit : public QTextEdit, IMyMethodContainer { ... };

但问题是,我需要在IMyMethodContainer中访问QObject::connect(sender, signal, this, slot);,而通过this,我试图访问MyTextEdit,而不是IMyMethodContainer,它不是QWidget的子类。

CRTP可能会有所帮助。

template<typename Derived, typename Base>
struct InjectMethod: Base {
  static_assert( std::is_base_of< InjectMethod<Derived,Base>, Derived >::value, "CRTP violation" );
  Derived* self() { return static_cast<Derived*>(this); }
  Derived const* self() const { return static_cast<Derived*>(this); }
  void my_method() {
    // use self() inside this method to access your Derived state
  }
};

然后:

class MyTextEdit: InjectMethod< MyTextEdit, QTextEdit > {
};
class MyPushButton: InjectMethod< MyPushButton, QPushButton > {
};

InjectMethod< MyTextEdit, QTextEdit >内部,您可以访问一个self()指针,该指针可以访问MyTextEdit内部和InjectMethod< MyPushButton, QPushButton >内部的所有内容。

您可能不需要Derived部分——如果您只使用QWidget功能,那么可能只有一个模板参数(您的基础)就足够了。

在Java中,您可以"扩展"QWidget并在那里添加自定义方法。

Class MyQWidgetExtension extends QWidget { ... }

您的其他类(QMainWindow、QpushButton、QtextEdit)只是从中扩展("inherit")。C++也有类似的东西吗?

Class MyQWidgetExtension : public QWidget { ... }