Eclipse-Rcp创建首选项

Eclipse-Rcp创建首选项

1. 通过e4xmi创建首选项界面

创建顶级窗口

创建窗口中视图

java 复制代码
package com.flx.studnetmanager;

import org.eclipse.core.runtime.preferences.InstanceScope;
import org.eclipse.e4.core.di.annotations.Optional;
import org.eclipse.swt.SWT;
import org.eclipse.swt.layout.GridLayout;
import org.eclipse.swt.widgets.Button;
import org.eclipse.swt.widgets.Composite;
import org.eclipse.swt.widgets.Label;
import org.eclipse.swt.widgets.Text;
import org.osgi.service.prefs.Preferences;

import jakarta.annotation.PostConstruct;
import jakarta.inject.Inject;
import jakarta.inject.Named;

public class SettingPage {
    private Text textField;
    private Button checkBox;

    @Inject
    @Optional
    @Named("preferences.node") // 上下文中的首选项节点标识
    private Preferences preferences;

    @PostConstruct
    public void createUI(Composite parent) {
        parent.setLayout(new GridLayout(2, false));

        // 初始化默认值(防止 NPE)
        if (preferences == null) {
            preferences = InstanceScope.INSTANCE.getNode("com.flx.studnetmanager");
        }

        // 文本框
        new Label(parent, SWT.NONE).setText("Username:");
        textField = new Text(parent, SWT.BORDER);
        textField.setText(preferences.get("username", "admin"));

        // 复选框
        new Label(parent, SWT.NONE).setText("Enable Feature:");
        checkBox = new Button(parent, SWT.CHECK);
        checkBox.setSelection(preferences.getBoolean("feature_enabled", false));

        // 保存按钮
        Button saveButton = new Button(parent, SWT.PUSH);
        saveButton.setText("Save");
        saveButton.addListener(SWT.Selection, e -> savePreferences());
    }

    private void savePreferences() {
        preferences.put("username", textField.getText());
        preferences.putBoolean("feature_enabled", checkBox.getSelection());
        try {
            preferences.flush(); // 持久化保存
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

2. 绑定菜单打开首选项界面

java 复制代码
package com.flx.studnetmanager;

import org.eclipse.core.runtime.preferences.InstanceScope;
import org.eclipse.e4.core.contexts.IEclipseContext;
import org.eclipse.e4.core.di.annotations.Execute;
import org.eclipse.e4.ui.model.application.MApplication;
import org.eclipse.e4.ui.model.application.ui.basic.MTrimmedWindow;
import org.eclipse.e4.ui.workbench.modeling.EModelService;
import org.eclipse.e4.ui.workbench.modeling.EPartService;
import org.eclipse.e4.ui.workbench.modeling.EPartService.PartState;
import org.osgi.service.prefs.Preferences;

public class Setting {

    @Execute
    public void execute(EModelService modelService, MApplication application, EPartService partService , IEclipseContext context) {
        // 获取用户级首选项节点
        Preferences prefsNode = InstanceScope.INSTANCE.getNode("com.flx.studnetmanager");

        // 将节点绑定到上下文
        context.set("preferences.node", prefsNode);
        // 查找 TrimmedWindow
        MTrimmedWindow window = (MTrimmedWindow) modelService.find("copy.trimmedwindow.011", application);
        if (window != null) {
            // 激活窗口
            window.setToBeRendered(true);
            window.setVisible(true);
            partService.showPart("copy.part.022", PartState.ACTIVATE);
        }
    }

}

3. 在打开时候设置默认值

java 复制代码
@PostContextCreate
void postContextCreate(IEclipseContext workbenchContext) {
    Preferences prefs = InstanceScope.INSTANCE.getNode("com.flx.studnetmanager");
    prefs.put("username", "admin");
    prefs.putBoolean("feature_enabled", false);
}

4. 效果图

相关推荐
半生过往23 分钟前
2025 前端动效实战指南:Vue Bits & React Bits 深度拆解(功能 / 复用 / 高频问题处理)
前端·vue.js·react.js
程序员包打听26 分钟前
Vitest 4.0 重磅发布:Browser Mode 正式稳定,前端测试进入新纪元
前端
BumBle27 分钟前
UniApp 多页面编译优化:编译时间从10分钟到1分钟
前端
星链引擎30 分钟前
大语言模型的技术突破与稳定 API 生态的构建
前端
还是大剑师兰特30 分钟前
TypeScript 面试题及详细答案 100题 (71-80)-- 模块与命名空间
前端·javascript·typescript
BumBle31 分钟前
使用 SortableJS 实现vue3 + Element Plus 表格拖拽排序
前端·vue.js·element
玉宇夕落31 分钟前
HTML5 音乐敲击乐静态界面
前端
海在掘金6112731 分钟前
告别"拼写错误":TS如何让你的代码"字字精准"
前端
用户479492835691532 分钟前
什么是XSS攻击,怎么预防,一篇文章带你搞清楚
前端·javascript·安全
摸着石头过河的石头33 分钟前
深入理解JavaScript事件流:从DOM0到DOM3的演进之路
前端·javascript·性能优化