eclipse rcp :帮助创建自定义的 StyledText 小部件

发布于 2024-12-06 01:34:18 字数 74 浏览 1 评论 0原文

我想要一个定制的 StyledText 小部件,它可以接受关键字列表,然后突出显示这些关键字!

我发现自己很难实现它。

I want a customized StyledText widget which can accept a keyword list,then highlight these keywords!

I found it's very hard to implement it by myself.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

悲喜皆因你 2024-12-13 01:34:18

该死的!经过几个小时的网络搜索,我终于在The Definitive Guide to SWT and JFace一书中找到了一些示例代码,它非常简单:

主类:

package amarsoft.rcp.base.widgets.test;

import org.eclipse.jface.window.ApplicationWindow;
import org.eclipse.swt.SWT;
import org.eclipse.swt.layout.FillLayout;
import org.eclipse.swt.widgets.Composite;
import org.eclipse.swt.widgets.Display;
import org.eclipse.swt.widgets.Shell;

import amarsoft.rcp.base.widgets.SQLSegmentEditor;

public class PageDemo extends ApplicationWindow {

    public PageDemo(Shell parentShell) {
        super(parentShell);
        final Composite topComp = new Composite(parentShell, SWT.BORDER);
        FillLayout fl = new FillLayout();
        fl.marginWidth = 100;
        topComp.setLayout(fl);
        new SQLSegmentEditor(topComp);

    }

    /**
     * @param args
     */
    public static void main(String[] args) {
        Display display = new Display();
        Shell shell = new Shell(display);
        shell.setLayout(new FillLayout());

        new PageDemo(shell);
        shell.open();
        while (!shell.isDisposed()) {
            if (!display.readAndDispatch())
                display.sleep();
        }
        display.dispose();
    }
}

package amarsoft.rcp.base.widgets;

import org.eclipse.swt.SWT;
import org.eclipse.swt.custom.StyledText;
import org.eclipse.swt.layout.FillLayout;
import org.eclipse.swt.widgets.Composite;

/**
 * SQL语句/SQL语句片段编辑器,除了内容编辑之外,提供一个额外的功能——常用SQL语句关键字高亮显示。
 * @author ggfan@amarsoft
 *
 */
public class SQLSegmentEditor extends Composite{

    private StyledText st;

    public SQLSegmentEditor(Composite parent) {
        super(parent, SWT.NONE);
        this.setLayout(new FillLayout());
        st = new StyledText(this, SWT.WRAP);
        st.addLineStyleListener(new SQLSegmentLineStyleListener());
    }

}
package amarsoft.rcp.base.widgets;

import java.util.ArrayList;
import java.util.List;

import org.eclipse.swt.SWT;
import org.eclipse.swt.custom.LineStyleEvent;
import org.eclipse.swt.custom.LineStyleListener;
import org.eclipse.swt.custom.StyleRange;
import org.eclipse.swt.graphics.Color;
import org.eclipse.wb.swt.SWTResourceManager;

public class SQLSegmentLineStyleListener implements LineStyleListener {

    private static final Color KEYWORD_COLOR = SWTResourceManager
            .getColor(SWT.COLOR_BLUE);

    private List<String> keywords = new ArrayList<String>();

    public SQLSegmentLineStyleListener() {
        super();
        keywords.add("select");
        keywords.add("from");
        keywords.add("where");
    }

    @Override
    public void lineGetStyle(LineStyleEvent event) {
        List<StyleRange> styles = new ArrayList<StyleRange>();
        int start = 0;
        int length = event.lineText.length();
        System.out.println("current line length:" + event.lineText.length());
        while (start < length) {
            System.out.println("while lopp");
            if (Character.isLetter(event.lineText.charAt(start))) {
                StringBuffer buf = new StringBuffer();
                int i = start;
                for (; i < length
                        && Character.isLetter(event.lineText.charAt(i)); i++) {
                    buf.append(event.lineText.charAt(i));
                }
                if (keywords.contains(buf.toString())) {
                    styles.add(new StyleRange(event.lineOffset + start, i - start, KEYWORD_COLOR, null, SWT.BOLD));
                }
                start = i;
            }
            else{
                start ++;
            }
        }
        event.styles = (StyleRange[]) styles.toArray(new StyleRange[0]);
    }

}

God damned! after spent hours searching the web, I finally found some sample code from the book The Definitive Guide to SWT and JFace, it's quite simple :

Main class :

package amarsoft.rcp.base.widgets.test;

import org.eclipse.jface.window.ApplicationWindow;
import org.eclipse.swt.SWT;
import org.eclipse.swt.layout.FillLayout;
import org.eclipse.swt.widgets.Composite;
import org.eclipse.swt.widgets.Display;
import org.eclipse.swt.widgets.Shell;

import amarsoft.rcp.base.widgets.SQLSegmentEditor;

public class PageDemo extends ApplicationWindow {

    public PageDemo(Shell parentShell) {
        super(parentShell);
        final Composite topComp = new Composite(parentShell, SWT.BORDER);
        FillLayout fl = new FillLayout();
        fl.marginWidth = 100;
        topComp.setLayout(fl);
        new SQLSegmentEditor(topComp);

    }

    /**
     * @param args
     */
    public static void main(String[] args) {
        Display display = new Display();
        Shell shell = new Shell(display);
        shell.setLayout(new FillLayout());

        new PageDemo(shell);
        shell.open();
        while (!shell.isDisposed()) {
            if (!display.readAndDispatch())
                display.sleep();
        }
        display.dispose();
    }
}

package amarsoft.rcp.base.widgets;

import org.eclipse.swt.SWT;
import org.eclipse.swt.custom.StyledText;
import org.eclipse.swt.layout.FillLayout;
import org.eclipse.swt.widgets.Composite;

/**
 * SQL语句/SQL语句片段编辑器,除了内容编辑之外,提供一个额外的功能——常用SQL语句关键字高亮显示。
 * @author ggfan@amarsoft
 *
 */
public class SQLSegmentEditor extends Composite{

    private StyledText st;

    public SQLSegmentEditor(Composite parent) {
        super(parent, SWT.NONE);
        this.setLayout(new FillLayout());
        st = new StyledText(this, SWT.WRAP);
        st.addLineStyleListener(new SQLSegmentLineStyleListener());
    }

}
package amarsoft.rcp.base.widgets;

import java.util.ArrayList;
import java.util.List;

import org.eclipse.swt.SWT;
import org.eclipse.swt.custom.LineStyleEvent;
import org.eclipse.swt.custom.LineStyleListener;
import org.eclipse.swt.custom.StyleRange;
import org.eclipse.swt.graphics.Color;
import org.eclipse.wb.swt.SWTResourceManager;

public class SQLSegmentLineStyleListener implements LineStyleListener {

    private static final Color KEYWORD_COLOR = SWTResourceManager
            .getColor(SWT.COLOR_BLUE);

    private List<String> keywords = new ArrayList<String>();

    public SQLSegmentLineStyleListener() {
        super();
        keywords.add("select");
        keywords.add("from");
        keywords.add("where");
    }

    @Override
    public void lineGetStyle(LineStyleEvent event) {
        List<StyleRange> styles = new ArrayList<StyleRange>();
        int start = 0;
        int length = event.lineText.length();
        System.out.println("current line length:" + event.lineText.length());
        while (start < length) {
            System.out.println("while lopp");
            if (Character.isLetter(event.lineText.charAt(start))) {
                StringBuffer buf = new StringBuffer();
                int i = start;
                for (; i < length
                        && Character.isLetter(event.lineText.charAt(i)); i++) {
                    buf.append(event.lineText.charAt(i));
                }
                if (keywords.contains(buf.toString())) {
                    styles.add(new StyleRange(event.lineOffset + start, i - start, KEYWORD_COLOR, null, SWT.BOLD));
                }
                start = i;
            }
            else{
                start ++;
            }
        }
        event.styles = (StyleRange[]) styles.toArray(new StyleRange[0]);
    }

}
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文