FormEditor编辑器变脏处理

 对于多页的FormEditor编辑器 ,MULTIPAGEEDITRO中包含FRMPAGE,FROMPAGE中包含的有PAGEFORM.

首先,在判断编辑器是否为脏。FormEditor的isDirty方法会判断编辑器是否变脏:

  1. public boolean isDirty() {
  2. if (pages != null) {
  3. for (int i = 0; i < pages.size(); i++) { //对每一页的状态判断
  4. Object page = pages.get(i);
  5. if (page instanceof IFormPage) {
  6. IFormPage fpage = (IFormPage) page;
  7. if (fpage.isDirty())
  8. return true;
  9. }
  10. }
  11. }
  12. return super.isDirty();
  13. }

FormPage的isDirty()方法:

  1. public boolean isDirty() {
  2. return mform != null ? mform.isDirty() : false;
  3. }

MultiPageEditor的isDirty状态是遍历Editor中每个FormPage的FormPart对象的isDirty状态得到的。

编辑器变脏后,是如何通知Workbench.
对于GEF编辑器,是通过CommandStack来通知Workbench,编辑器变脏的事件,但对于FormEditor没有默认的CommandStack,因此,通过调用PageForm的editorDirtyStateChanged()方法来通知编辑器变脏的事件。


    要实现多页编辑器变脏,在PageForm的FormPart中,当做了修改后,设置FormPart的脏状态,也就是使ISDIRTY返回的为TRUE,并调用PageForm的editorDirtyStateChanged() 做通知。(this.getManagedForm().dirtyStateChanged(); )

在编辑器变脏或者是保存以后,都需要调用this.getManagedForm().dirtyStateChanged() 来更新编辑器状态。(标题处的*是标志)。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,下面是一个简单的示例代码,用于演示如何使用 Qt 插件机制在 Visual Studio 2022 编译器上实现一个简易计算器: 首先是 `CalculatorWidget` 类,用于实现计算器界面和逻辑: ```cpp #ifndef CALCULATORWIDGET_H #define CALCULATORWIDGET_H #include <QWidget> #include <QLineEdit> #include <QPushButton> class CalculatorWidget : public QWidget { Q_OBJECT public: explicit CalculatorWidget(QWidget *parent = nullptr); private slots: void onDigitClicked(); void onOperatorClicked(); void onEqualClicked(); void onClearClicked(); private: QLineEdit *m_display; QPushButton *m_digitButtons[10]; QPushButton *m_operatorButtons[4]; QString m_currentNumber; QString m_pendingOperator; double m_pendingOperand; bool m_waitingForOperand; }; #endif // CALCULATORWIDGET_H ``` 接下来是 `CalculatorPlugin` 类,用于实现 Qt 插件接口: ```cpp #ifndef CALCULATORPLUGIN_H #define CALCULATORPLUGIN_H #include <QObject> #include <QtDesigner/QDesignerCustomWidgetInterface> class CalculatorPlugin : public QObject, public QDesignerCustomWidgetInterface { Q_OBJECT Q_PLUGIN_METADATA(IID "org.qt-project.Qt.QDesignerCustomWidgetInterface") Q_INTERFACES(QDesignerCustomWidgetInterface) public: explicit CalculatorPlugin(QObject *parent = nullptr); QString name() const override; QString group() const override; QString toolTip() const override; QString whatsThis() const override; QIcon icon() const override; bool isContainer() const override; QWidget *createWidget(QWidget *parent) override; void initialize(QDesignerFormEditorInterface *formEditor) override; bool isInitialized() const override; void uninitialize() override; private: bool m_initialized; }; #endif // CALCULATORPLUGIN_H ``` 最后是 `CalculatorPlugin` 类的实现: ```cpp #include "calculatorplugin.h" #include "calculatorwidget.h" #include <QtPlugin> CalculatorPlugin::CalculatorPlugin(QObject *parent) : QObject(parent) { m_initialized = false; } QString CalculatorPlugin::name() const { return QStringLiteral("CalculatorWidget"); } QString CalculatorPlugin::group() const { return QStringLiteral("Custom Widgets"); } QString CalculatorPlugin::toolTip() const { return QStringLiteral("A simple calculator widget"); } QString CalculatorPlugin::whatsThis() const { return QStringLiteral("A simple calculator widget"); } QIcon CalculatorPlugin::icon() const { return QIcon(); } bool CalculatorPlugin::isContainer() const { return false; } QWidget *CalculatorPlugin::createWidget(QWidget *parent) { return new CalculatorWidget(parent); } void CalculatorPlugin::initialize(QDesignerFormEditorInterface *formEditor) { if (m_initialized) return; m_initialized = true; } bool CalculatorPlugin::isInitialized() const { return m_initialized; } void CalculatorPlugin::uninitialize() { if (!m_initialized) return; m_initialized = false; } Q_EXPORT_PLUGIN2(calculatorplugin, CalculatorPlugin) ``` 这些代码只是一个简单的示例,实现了一个基本的计算器功能。如果你需要更详细的代码实现,可以参考 Qt 的官方文档和示例代码。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值