13

2 番目のページのコンテンツが最初のページの選択に依存するウィザードが必要です。最初のページでは、作成するフィルターの「種類」をユーザーに尋ね、2 番目のページでは、選択した「種類」のフィルター インスタンスを 1 つ作成するようユーザーに求めます。

JFace のウィザード ページのコンテンツ (createControl(...) メソッド) はすべて、特定のページが表示されたときではなく、ウィザードが開いたときに作成されます (これにより、JFace はウィザードのサイズを推測できます ??)。

このため、ウィザードを開く前に 2 番目のページのコンテンツを作成する必要がありますが、2 番目のページのコンテンツは最初のページの選択に依存するため作成できません。

今のところ、私が見つけたよりクリーンなソリューションは、ウィザードが (コンテンツとともに) 開く前にすべての (秒) ページを作成し、最初のページの実装で getNextPage() メソッドをオーバーライドすることです。

このソリューションの主な欠点は、作成する 2 番目のページが多数ある場合にコストが高くなる可能性があることです。

その解決策についてどう思いますか? ウィザードのページをどのように管理していますか? 私が見逃したよりクリーンなソリューションはありますか?

4

4 に答える 4

9

あなたが他のいくつかのページである場合、アプローチは正しいです

  • 一つ一つ全く違う
  • 前のページで行われた以前の選択に依存します

次に、次のページを動的に追加できます(ここでも説明されています) 。

ただし、動的コンテンツを含む次のページがある場合は、メソッドでそのコンテンツを作成できるはずですonEnterPage()

public void createControl(Composite parent)
{
    //
    // create the composite to hold the widgets
    //
    this.composite = new Composite(parent, SWT.NONE);

    //
    // create the desired layout for this wizard page
    //
    GridLayout layout = new GridLayout();
    layout.numColumns = 4;
    this.composite.setLayout(layout);

    // set the composite as the control for this page
    setControl(this.composite);
}

void onEnterPage()
{
    final MacroModel model = ((MacroWizard) getWizard()).model;
    String selectedKey = model.selectedKey;
    String[] attrs = (String[]) model.macroMap.get(selectedKey);

    for (int i = 0; i < attrs.length; i++)
    {
        String attr = attrs[i];
        Label label = new Label(this.composite, SWT.NONE);
        label.setText(attr + ":");

        new Text(this.composite, SWT.NONE);
    }
    pack();
}

日食コーナーの記事「JFace ウィザードの作成」に示されているように:

任意のウィザード ページの getNextPage メソッドを上書きすることで、ウィザード ページの順序を変更できます。ページを離れる前に、ユーザーが選択した値をモデルに保存します。この例では、旅行の選択に応じて、ユーザーは次にフライトのページまたは車での旅行のページのいずれかを表示します。

public IWizardPage getNextPage(){
   saveDataToModel();       
   if (planeButton.getSelection()) {
       PlanePage page = ((HolidayWizard)getWizard()).planePage;
     page.onEnterPage();
       return page;
   }
   // Returns the next page depending on the selected button
   if (carButton.getSelection()) { 
    return ((HolidayWizard)getWizard()).carPage;
   }
   return null;
}

に対してこの初期化を行うメソッドPlanePageonEnterPage()PlanePagegetNextPage()を定義し、最初のページのメソッドにあるに移動するときにこのメソッドを呼び出します。

于 2009-06-05T06:44:48.903 に答える
5

最初のページでの選択に基づいて新しいウィザードを開始する場合は、JFace基本クラスorg.eclipse.jface.wizard.WizardSelectionPageを使用できます。

以下の例は、拡張ポイントによって定義された使用可能なウィザードのリストを示しています。[次へ]を押すと、選択したウィザードが開始されます。

public class ModelSetupWizardSelectionPage extends WizardSelectionPage {

private ComboViewer providerViewer;
private IConfigurationElement selectedProvider;

public ModelSetupWizardSelectionPage(String pageName) {
    super(pageName);
}

private class WizardNode implements IWizardNode {
    private IWizard wizard = null;
    private IConfigurationElement configurationElement;

    public WizardNode(IConfigurationElement c) {
        this.configurationElement = c;
    }

    @Override
    public void dispose() {

    }

    @Override
    public Point getExtent() {
        return new Point(-1, -1);
    }

    @Override
    public IWizard getWizard() {
        if (wizard == null) {
            try {
                wizard = (IWizard) configurationElement
                        .createExecutableExtension("wizardClass");
            } catch (CoreException e) {

            }
        }
        return wizard;
    }

    @Override
    public boolean isContentCreated() {
        // TODO Auto-generated method stub
        return wizard != null;
    }

}

@Override
public void createControl(Composite parent) {
    setTitle("Select model provider");
    Composite main = new Composite(parent, SWT.NONE);
    GridLayout gd = new GridLayout(2, false);
    main.setLayout(gd);
    new Label(main, SWT.NONE).setText("Model provider");
    Combo providerList = new Combo(main, SWT.NONE);
    providerViewer = new ComboViewer(providerList);
    providerViewer.setLabelProvider(new LabelProvider() {
        @Override
        public String getText(Object element) {
            if (element instanceof IConfigurationElement) {
                IConfigurationElement c = (IConfigurationElement) element;
                String result = c.getAttribute("name");
                if (result == null || result.length() == 0) {
                    result = c.getAttribute("class");
                }
                return result;
            }
            return super.getText(element);
        }

    });
    providerViewer
            .addSelectionChangedListener(new ISelectionChangedListener() {
                @Override
                public void selectionChanged(SelectionChangedEvent event) {
                    ISelection selection = event.getSelection();
                    if (!selection.isEmpty()
                            && selection instanceof IStructuredSelection) {
                        Object o = ((IStructuredSelection) selection)
                                .getFirstElement();
                        if (o instanceof IConfigurationElement) {
                            selectedProvider = (IConfigurationElement) o;
                            setMessage(selectedProvider.getAttribute("description"));
                            setSelectedNode(new WizardNode(selectedProvider));
                        }
                    }

                }
            });
    providerViewer.setContentProvider(new ArrayContentProvider());
    List<IConfigurationElement> providers = new ArrayList<IConfigurationElement>();
    IExtensionRegistry registry = Platform.getExtensionRegistry();
    IExtensionPoint extensionPoint = registry
            .getExtensionPoint(<your extension point namespace>,<extension point name>);
    if (extensionPoint != null) {
        IExtension extensions[] = extensionPoint.getExtensions();
        for (IExtension extension : extensions) {
            IConfigurationElement configurationElements[] = extension
                    .getConfigurationElements();
            for (IConfigurationElement c : configurationElements) {
                providers.add(c);
            }
        }
    }
    providerViewer.setInput(providers);
    setControl(main);

}

対応するウィザードクラスは次のようになります。

 public class ModelSetupWizard extends Wizard {

private ModelSetupWizardSelectionPage wizardSelectionPage;

public ModelSetupWizard() {
    setForcePreviousAndNextButtons(true);
}

@Override
public boolean performFinish() {
            // Do what you have to do to finish the wizard
    return true;
}

@Override
public void addPages() {
    wizardSelectionPage = new ModelSetupWizardSelectionPage("Select a wizard");
    addPage(wizardSelectionPage);

}
}
于 2009-06-05T07:41:09.490 に答える
0

別の解決策があります。

ページがページ 1 の結果に依存する場合は、変数を作成して最初のページに渡します。そのウィザード ページにユーザーからのオプションがある場合、ページを閉じる前の最後の作業は、変数を必要な値に設定することです。 .

次に、この変数をウィザードに渡し、次のウィザード ページに渡します。次に、単純な if ステートメントを実行すると、両方の選択肢がまとめられます。

ほとんどのコードでは、ユーザー オプションにわずかな違いしかないことに注意してください。そのため、コードの複製に行き詰まらないようにしてください。

于 2013-05-10T09:39:08.440 に答える