[心缘地方]同学录
首页 | 功能说明 | 站长通知 | 最近更新 | 编码查看转换 | 代码下载 | 常见问题及讨论 | 《深入解析ASP核心技术》 | 王小鸭自动发工资条VBA版
登录系统:用户名: 密码: 如果要讨论问题,请先注册。

[备忘]rcp开发,简单快速调用Wizard的方法~~

上一篇:[备忘]SWT的多行文本框,不自动换行的问题~~~
下一篇:[转帖]jQuery常用的元素查找方法总结

添加日期:2012/6/21 10:13:48 快速返回   返回列表 阅读9545次
很简单,如下几行即可。

import org.eclipse.core.runtime.CoreException;
import org.eclipse.jdt.ui.actions.AbstractOpenWizardAction;
import org.eclipse.ui.INewWizard;
import org.eclipse.ui.wizards.newresource.BasicNewProjectResourceWizard;

/**
 * xxxxAction类.
 */
public class xxxxAction extends AbstractOpenWizardAction {

    @Override
    protected INewWizard createWizard() throws CoreException {
        return new xxxxxxxxxxxxWizard();
    }

}



AbstractOpenWizardAction 类的源代码如下:


/*******************************************************************************
  * Copyright (c) 2000, 2011 IBM Corporation and others.
  * All rights reserved. This program and the accompanying materials
  * are made available under the terms of the Eclipse Public License v1.0
  * which accompanies this distribution, and is available at
  * http://www.eclipse.org/legal/epl-v10.html
  *
  * Contributors:
  *     IBM Corporation - initial API and implementation
  *******************************************************************************/
 package org.eclipse.jdt.ui.actions;
 
 import org.eclipse.swt.widgets.Shell;
 
 import org.eclipse.core.runtime.CoreException;
 
 import org.eclipse.core.resources.IWorkspaceRoot;
 import org.eclipse.core.resources.ResourcesPlugin;
 
 import org.eclipse.jface.action.Action;
 import org.eclipse.jface.dialogs.MessageDialog;
 import org.eclipse.jface.layout.PixelConverter;
 import org.eclipse.jface.resource.JFaceResources;
 import org.eclipse.jface.viewers.ISelection;
 import org.eclipse.jface.viewers.IStructuredSelection;
 import org.eclipse.jface.viewers.StructuredSelection;
 import org.eclipse.jface.window.Window;
 import org.eclipse.jface.wizard.WizardDialog;
 
 import org.eclipse.ui.INewWizard;
 import org.eclipse.ui.IWorkbenchWindow;
 import org.eclipse.ui.PlatformUI;
 import org.eclipse.ui.actions.NewProjectAction;
 
 import org.eclipse.jdt.core.IJavaElement;
 
 import org.eclipse.jdt.internal.ui.JavaPlugin;
 import org.eclipse.jdt.internal.ui.util.ExceptionHandler;
 import org.eclipse.jdt.internal.ui.wizards.NewElementWizard;
 import org.eclipse.jdt.internal.ui.wizards.NewWizardMessages;
 
 
 /**
  * <p>Abstract base classed used for the open wizard actions.</p>
  *
  * <p>
  * Note: This class is for internal use only. Clients should not use this class.
  * </p>
  * @since 3.2
  *
  * @noextend This class is not intended to be subclassed by clients.
  */
 public abstract class AbstractOpenWizardAction extends Action {
 
     private Shell fShell;
     private IStructuredSelection fSelection;
     private IJavaElement fCreatedElement;
 
     /**
      * Creates the action.
      */
     protected AbstractOpenWizardAction() {
         fShell= null;
         fSelection= null;
         fCreatedElement= null;
     }
 
     /* (non-Javadoc)
      * @see org.eclipse.jface.action.Action#run()
      */
     @Override
     public void run() {
         Shell shell= getShell();
         if (!doCreateProjectFirstOnEmptyWorkspace(shell)) {
             return;
         }
         try {
             INewWizard wizard= createWizard();
             wizard.init(PlatformUI.getWorkbench(), getSelection());
 
             WizardDialog dialog= new WizardDialog(shell, wizard);
             PixelConverter converter= new PixelConverter(JFaceResources.getDialogFont());
             dialog.setMinimumPageSize(converter.convertWidthInCharsToPixels(70), converter.convertHeightInCharsToPixels(20));
             dialog.create();
             int res= dialog.open();
             if (res == Window.OK && wizard instanceof NewElementWizard) {
                 fCreatedElement= ((NewElementWizard)wizard).getCreatedElement();
             }
 
             notifyResult(res == Window.OK);
         } catch (CoreException e) {
             String title= NewWizardMessages.AbstractOpenWizardAction_createerror_title;
             String message= NewWizardMessages.AbstractOpenWizardAction_createerror_message;
             ExceptionHandler.handle(e, shell, title, message);
         }
     }
 
     /**
      * Creates and configures the wizard. This method should only be called once.
     * @return returns the created wizard.
     * @throws CoreException exception is thrown when the creation was not successful.
     */
    abstract protected INewWizard createWizard() throws CoreException;

    /**
     * Returns the configured selection. If no selection has been configured using {@link #setSelection(IStructuredSelection)},
     * the currently selected element of the active workbench is returned.
     * @return the configured selection
     */
    protected IStructuredSelection getSelection() {
        if (fSelection == null) {
            return evaluateCurrentSelection();
        }
        return fSelection;
    }

    private IStructuredSelection evaluateCurrentSelection() {
        IWorkbenchWindow window= JavaPlugin.getActiveWorkbenchWindow();
        if (window != null) {
            ISelection selection= window.getSelectionService().getSelection();
            if (selection instanceof IStructuredSelection) {
                return (IStructuredSelection) selection;
            }
        }
        return StructuredSelection.EMPTY;
    }

    /**
     * Configures the selection to be used as initial selection of the wizard.
     * @param selection the selection to be set or <code>null</code> to use the selection of the active workbench window
     */
    public void setSelection(IStructuredSelection selection) {
        fSelection= selection;
    }

    /**
     * Returns the configured shell. If no shell has been configured using {@link #setShell(Shell)},
     *     the shell of the currently active workbench is returned.
     * @return the configured shell
     */
    protected Shell getShell() {
        if (fShell == null) {
            return JavaPlugin.getActiveWorkbenchShell();
        }
        return fShell;
    }

    /**
     * Configures the shell to be used as parent shell by the wizard.
     * @param shell the shell to be set or <code>null</code> to use the shell of the active workbench window
     */
    public void setShell(Shell shell) {
        fShell= shell;
    }

    /**
     * Opens the new project dialog if the workspace is empty. This method is called on {@link #run()}.
     * @param shell the shell to use
     * @return returns <code>true</code> when a project has been created, or <code>false</code> when the
     * new project has been canceled.
     */
    protected boolean doCreateProjectFirstOnEmptyWorkspace(Shell shell) {
        IWorkspaceRoot workspaceRoot= ResourcesPlugin.getWorkspace().getRoot();
        if (workspaceRoot.getProjects().length == 0) {
            String title= NewWizardMessages.AbstractOpenWizardAction_noproject_title;
            String message= NewWizardMessages.AbstractOpenWizardAction_noproject_message;
            if (MessageDialog.openQuestion(shell, title, message)) {
                new NewProjectAction().run();
                return workspaceRoot.getProjects().length != 0;
            }
            return false;
        }
        return true;
    }

    /**
     * Returns the created element or <code>null</code> if the wizard has not run or was canceled.
     * @return the created element or <code>null</code>
     */
    public IJavaElement getCreatedElement() {
        return fCreatedElement;
    }

 

评论 COMMENTS
guest121223331
2014/5/31 4:30:25
?action=ok

添加评论 Add new comment.
昵称 Name:
评论内容 Comment:
验证码(不区分大小写)
Validation Code:
(not case sensitive)
看不清?点这里换一张!(Change it here!)
 
评论由管理员查看后才能显示。the comment will be showed after it is checked by admin.
CopyRight © 心缘地方 2005-2999. All Rights Reserved