2

2つのボタンを作成する方法があります。これらのボタンは、[OK]、[閉じる] ボタンとは異なります。クリックすると、さまざまなアクションが実行されます。2 つのボタンを並べて、ベース コンポジットの上部に配置します。GridLayoutを使用しています。ボタンを並べて配置できるようにしたい。

これが、メソッドを追加する createDialogArea です。

  protected Control createDialogArea(Composite parent) {
  final Composite area = new Composite(parent, SWT.NONE);
  final GridLayout gridLayout = new GridLayout();
  gridLayout.marginWidth = 15;
  gridLayout.marginHeight = 10;
  area.setLayout(gridLayout);
  createTopButtons(area);
  createTableViewer(area);
  return area;
}

これがボタンメソッドです。

 protected void createTopButtons(Composite parent) {
   Button pdfButton = new Button(parent, SWT.PUSH);
   pdfButton.setText("Create PDF");
   pdfButton.addSelectionListener(new SelectionAdapter() {
     public void widgetSelected(SelectionEvent e) {
        close();
     }
   }); 

   Button plotButton = new Button(parent, SWT.PUSH);
   plotButton.setText("Plot");
   plotButton.addSelectionListener(new SelectionAdapter() {
     public void widgetSelected(SelectionEvent e) {
        close();
     }
   });  
 }

createTopButtons に Gridlayout を追加する必要がありますか?
もしそうなら、どうすればそれらを上下に並べるのではなく、並べて表示できますか。

また、createDialogArea で、gridLayout を使用してコンポーネントを配置できますか?

例 - createTopButtons を左上に配置し、次に createTableViewer を中央に配置します

createTopButtons のように作成しているコンポジット内のレイアウトを使用して、アイテム/ボタン/ラベルを配置しますか。次に、createDialogArea のレイアウトを使用して、メソッドによって作成されたコンポジットを配置しますか?

4

1 に答える 1

6

質疑応答

createTopButtons に Gridlayout を追加する必要がありますか?

ボタンを別のコンポジットに配置する必要はありません。この子コンポジットには、2 つの列を持つグリッドレイアウトが必要です。

また、createDialogArea で、gridLayout を使用してコンポーネントを配置できますか? 例 - createTopButtons を左上に配置し、次に createTableViewer を中央に配置します

もちろん。ただし、 と呼ばれるものも必要GridDataで、 のように設定しarea.setLayoutData(gridData);ます。何かをセンタリングするために、グリッドデータは次のようになりますgridData = new GridData(SWT.CENTER, SWT.CENTER, true, false);

createTopButtons のように作成しているコンポジット内のレイアウトを使用して、アイテム/ボタン/ラベルを配置しますか。次に、createDialogArea のレイアウトを使用して、メソッドによって作成されたコンポジットを配置しますか?

はい。後半はわからないけどcomposite created by the methods

コード

import org.eclipse.swt.SWT;
import org.eclipse.swt.events.SelectionAdapter;
import org.eclipse.swt.events.SelectionEvent;
import org.eclipse.swt.layout.GridData;
import org.eclipse.swt.layout.GridLayout;
import org.eclipse.swt.widgets.Button;
import org.eclipse.swt.widgets.Composite;
import org.eclipse.swt.widgets.Control;
import org.eclipse.swt.widgets.Display;
import org.eclipse.swt.widgets.Shell;
import org.eclipse.swt.widgets.Table;
import org.eclipse.swt.widgets.TableColumn;

public class SideBySide {
    public static void main(String[] args) {
        new SideBySide().start();
    }

    private Shell shell;

    public void start()
    {
        Display display = new Display();
        shell = new Shell(display);
        shell.setLayout(new GridLayout(1, true));

        GridData gridData = new GridData(SWT.FILL, SWT.FILL, true, true);
        shell.setLayoutData(gridData);

        shell.setText("Side By Side");

        createDialogArea(shell);

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

    protected Control createDialogArea(Composite parent) 
    {
        final Composite area = new Composite(parent, SWT.NONE);
        final GridLayout gridLayout = new GridLayout();
        gridLayout.marginWidth = 15;
        gridLayout.marginHeight = 10;
        area.setLayout(gridLayout);

        GridData gridData = new GridData(SWT.FILL, SWT.FILL, true, true);
        shell.setLayoutData(gridData);
        area.setLayoutData(gridData);

        createTopButtons(area);
        createTableViewer(area);
        return area;
    }

    private void createTableViewer(Composite area)
    {
        Table table = new Table(area, SWT.BORDER|SWT.V_SCROLL|SWT.FULL_SELECTION);
        GridData gridData = new GridData(SWT.FILL, SWT.FILL, true, true);
        table.setLayoutData(gridData);

        table.setLinesVisible(true);
        table.setHeaderVisible(true);

        TableColumn column = new TableColumn(table, SWT.LEFT);
        column.setWidth(320);
        column.setText("Column 1");

        column = new TableColumn(table, SWT.LEFT);
        column.setWidth(320);
        column.setText("Column 2");
    }

    protected void createTopButtons(Composite parent) 
    {

        Composite composite = new Composite(parent, SWT.NONE);
        GridLayout gridLayout = new GridLayout(2, false);
        gridLayout.marginWidth = 0;
        gridLayout.marginHeight = 0;
        gridLayout.verticalSpacing = 0;
        gridLayout.horizontalSpacing = 0;
        composite.setLayout(gridLayout);

        GridData gridData = new GridData(SWT.FILL, SWT.FILL, true, false);
        composite.setLayoutData(gridData);

        gridData = new GridData(SWT.DEFAULT, SWT.FILL, false, false);

        Button pdfButton = new Button(composite, SWT.PUSH);
        pdfButton.setText("Create PDF");
        pdfButton.addSelectionListener(new SelectionAdapter() {
            public void widgetSelected(SelectionEvent e) {
                shell.close();
            }
        }); 

        pdfButton.setLayoutData(gridData);

        Button plotButton = new Button(composite, SWT.PUSH);
        plotButton.setText("Plot");
        plotButton.addSelectionListener(new SelectionAdapter() {
            public void widgetSelected(SelectionEvent e) {
                shell.close();
            }
        });  
        plotButton.setLayoutData(gridData);
    }
}

コード出力

ここに画像の説明を入力

参考文献

これは、SWT のレイアウトを理解するための優れた記事です。

于 2012-08-29T05:29:58.290 に答える