Проблема с открытием SWT FileDialog

Мне нужно открыть FileDialog, чтобы открыть файл с помощью SWT в Windows 7 Home с использованием Java 7. Мне нужно, чтобы этот FileDialog открывался при нажатии кнопки BrowseBtn1 (SWT). Я использую для этого addSelectionListener. Это правильный подход? Если да, то почему мой диалог не открывается, если он не встречает ошибок во время выполнения. Я вообще не использую AWT, использую только SWT.

import org.eclipse.swt.*;
import org.eclipse.swt.widgets.*;
import org.eclipse.swt.widgets.FileDialog;
import org.eclipse.swt.events.*;
import org.eclipse.swt.graphics.FontData;
import org.eclipse.swt.layout.*;

public class MySwtApp {
    public static Display display;
    public static Shell shell;

    public static void main(String[] args) {

        display = new Display ();
        shell = new Shell (display);
        shell.setText("MY TITLE");
        GridLayout gridLayout = new GridLayout (3, false);
        shell.setLayout (gridLayout);

        Label Label1 = new Label (shell, SWT.NONE);
        Label1.setText ("Select Message ");
        GridData data = new GridData (200, SWT.DEFAULT);
        Label1.setLayoutData (data);

        Combo Combo1 = new Combo (shell, SWT.NONE);
        Combo1.setItems (new String [] {"Option A", 
                "Option B"});
        // CaseStudyCombo.setText ("CaseStudyCombo");
        data = new GridData (200, SWT.DEFAULT);
        Combo1.setLayoutData (data);
        Combo1.addListener (SWT.DefaultSelection, new Listener () {
            public void handleEvent (Event e) {
                System.out.println (e.widget + " - Default Selection");
            }
        });

        Label emptyLabel = new Label (shell, SWT.NONE);
        emptyLabel.setText ("");
        data = new GridData (50, SWT.DEFAULT);
        emptyLabel.setLayoutData (data);

        Label Label2 = new Label (shell, SWT.NONE);
        Label2.setText ("Next Message: ");
        data = new GridData (200, SWT.DEFAULT);
        Label2.setLayoutData (data);

        final Text text4 = new Text (shell, SWT.BORDER);
        text4.setText ("");
        data = new GridData (215, SWT.DEFAULT);
        text4.setLayoutData (data);

        Button BrowseBtn1 = new Button (shell, SWT.PUSH);
        BrowseBtn1.setText ("Browse");
        data = new GridData (80, SWT.DEFAULT);
        BrowseBtn1.setLayoutData (data);
        BrowseBtn1.addSelectionListener(new SelectionAdapter() {
            String result = "";
            public void WidgetSelected(SelectionEvent e) {
                FileDialog dialog = new FileDialog (shell, SWT.OPEN);
                dialog.setFilterExtensions(new String [] {"*.html"});
                //dialog.setFilterPath("c:\\temp");
                result = dialog.open();
                text4.setText(result);
            }
        });

        Label Label3 = new Label (shell, SWT.NONE);
        Label3.setText ("Message Label 3: ");
        data = new GridData (200, SWT.DEFAULT);
        Label3.setLayoutData (data);

        Text text5 = new Text (shell, SWT.BORDER);
        text5.setText ("");
        data = new GridData (215, SWT.DEFAULT);
        text5.setLayoutData (data);

        Button BrowseBtn2 = new Button (shell, SWT.PUSH);
        BrowseBtn2.setText ("Browse");
        data = new GridData (80, SWT.DEFAULT);
        BrowseBtn2.setLayoutData (data);

        Label Label4 = new Label (shell, SWT.NONE);
        Label4.setText ("Message Label 4: ");
        data = new GridData (200, SWT.DEFAULT);
        Label4.setLayoutData (data);

        Combo Combo2 = new Combo (shell, SWT.NONE);
        Combo2.setText ("Options");
        data = new GridData (200, SWT.DEFAULT);
        Combo2.setLayoutData (data);

        Button searchBtn1 = new Button (shell, SWT.PUSH);
        searchBtn1.setText ("Search");
        data = new GridData (80, SWT.DEFAULT);
        searchBtn1.setLayoutData (data);

        Combo Combo3 = new Combo (shell, SWT.NONE);
        // CaseStudyCombo.setItems (new String [] {"Item 1", "Item 2", "Item 2"});
        Combo3.setText ("Options:");
        data = new GridData (200, SWT.DEFAULT);
        Combo3.setLayoutData (data);

        Combo Combo4 = new Combo (shell, SWT.NONE);
        Combo4.setText ("Options:");
        data = new GridData (200, SWT.DEFAULT);
        Combo4.setLayoutData (data);

        Button showDetailsBtn = new Button (shell, SWT.PUSH);
        showDetailsBtn.setText ("Show Details");
        data = new GridData (80, SWT.DEFAULT);
        showDetailsBtn.setLayoutData (data);

        shell.pack ();
        shell.open ();

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

Пожалуйста, помогите решить эту проблему.


person user1766875    schedule 13.11.2012    source источник
comment
Небольшой совет: соблюдайте соглашения об именах переменных Java.   -  person Baz    schedule 14.11.2012


Ответы (1)


проблемная строка такова:

public void WidgetSelected(SelectionEvent e)

обратите внимание на заглавную букву «W». В настоящее время вы определяете новый метод (вместо переопределения существующего метода widgetSelected(...)) в этом анонимном классе. Если вы измените это на строчную букву «w», как это, это будет работать:

public void widgetSelected(SelectionEvent e)

Это хорошая практика (на самом деле больше, чем рекомендуется) использовать аннотацию @Override. Если бы вы использовали это, компилятор отметил бы вас ошибкой (см., например, Джошуа Блох Эффективная Java, 2-е издание, пункт 36: последовательно используйте аннотацию Override)

person Bela Vizer    schedule 13.11.2012