SWT应用程序近乎实时地显示更新的显示

时间:2013-01-12 11:28:33

标签: java swt

问题:

  

您能否展示SWT显示部件(更新窗口/外壳)的任何简单示例或说明?或者您认为哪些网站最适合SWT应用程序开发?

背景

  

我是SWT应用程序的新手,目前正在构建运行某些测试的应用程序。

     

它有一个主显示shell类,文本区域在用户点击运行按钮后不断更新。

     

运行按钮启动另一个线程进程,该进程更新StartView类中的公共静态对象,如AtomicCounter。

当前阶段

  

该程序似乎运行良好,但是,它不会实时更新文本区域。   好吧,我不能说实时,但它显示了一点延迟的信息。(我可以说它延迟了,因为我也在控制台上打印出来)

     

似乎我不明白SWT的概念是否足以做我想做的任何事情。

目标

  

一个。主显示类,无论B运行与否,都会启动和停止C

     

B中。使用A

的公共静态对象更新A类的文本区域的线程进程      

℃。执行其工作并更新A

的公共静态对象的线程进程

示例代码(工作代码)

public class UnitTest {

    public static Display display;
    private Shell shell;
    public static AtomicInteger counter = new AtomicInteger(0);
    public static Text text;
    private TestThread test1 = null, test2 = null;

    public UnitTest()
    {
        display = Display.getDefault();
        this.shell = new Shell(display, SWT.CLOSE);
        this.shell.setSize(226, 120);

        text = new Text(shell, SWT.BORDER);
        text.setBounds(10, 10, 199, 19);

        Button btnStart = new Button(shell, SWT.NONE);
        btnStart.addSelectionListener(new SelectionAdapter() {
            @Override
            public void widgetSelected(SelectionEvent arg0) {
                test1 = new TestThread();
                test1.start();
                test2 = new TestThread();
                test2.start();
            }
        });
        btnStart.setBounds(10, 54, 94, 28);
        btnStart.setText("Start");

        Button btnStop = new Button(shell, SWT.NONE);
        btnStop.addSelectionListener(new SelectionAdapter() {
            @Override
            public void widgetSelected(SelectionEvent arg0) {
                test1.interrupt();
                test2.interrupt();
                counter.set(0);
            }
        });
        btnStop.setBounds(115, 54, 94, 28);
        btnStop.setText("Stop");

        this.shell.open();
        this.shell.layout();

        this.shell.addListener(SWT.Close, new Listener(){
            public void handleEvent(Event event)
            {
                shell.dispose();
            }
        });

        while(!this.shell.isDisposed())
        {
            if(!display.readAndDispatch())
            {
                //text.setText(""+counter.get());
                display.sleep();
            }
        }
    }

    public static void main(String[] args)
    {
        new UnitTest();
    }
}

class TestThread extends Thread
{   
    public void run()
    {
        try
        {
            int i = 0;
            while(i++ < 1000 && !this.isInterrupted() )
            {
                UnitTest.counter.getAndIncrement();
                try {
                    TestThread.sleep(2000);
                } catch (InterruptedException e) {
                    // TODO Auto-generated catch block
                    e.printStackTrace();
                    break;
                }

                if(UnitTest.display.isDisposed())
                    return;

                UnitTest.display.asyncExec(new Runnable() {
                    public void run() {
                      if (UnitTest.text.isDisposed())
                        return;
                      UnitTest.text.setText(""+UnitTest.counter.get());
                    }
                  });

            }
        }
        catch(Exception e)
        {
            e.printStackTrace();
        }
        finally
        {
            System.out.println("Existing thread...");
        }

    }
}

1 个答案:

答案 0 :(得分:1)

您应该仔细使用来自不同线程的UI更新。请阅读:

http://goo.gl/At8hC