學無止境  
          日歷
          <2025年6月>
          25262728293031
          1234567
          891011121314
          15161718192021
          22232425262728
          293012345
          統計
          • 隨筆 - 9
          • 文章 - 0
          • 評論 - 2
          • 引用 - 0

          導航

          常用鏈接

          留言簿(2)

          隨筆分類

          隨筆檔案

          搜索

          •  

          最新評論

          閱讀排行榜

          評論排行榜

           

          2005年10月25日

          You have implemented your own graphical editor as a new eclipse plugin. You are looking for a way to add zoom functions into the graphical editor. It is very easy!
          1. Add the action into the toolbar:
          ...in Class: ActionBarContributor...
              ...in Method: contributeToToolBar...
                  toolBarManager.add(getAction(GEFActionConstants.ZOOM_IN));
                  toolBarManager.add(getAction(GEFActionConstants.ZOOM_OUT));
                  toolBarManager.add(new ZoomComboContributionItem(getPage()));

          2. Connect the Zoom Manager with your edit part:
          ...in Class: YourEditor...
              ...in Method: configureGraphicalViewer...
                  ScalableFreeformRootEditPart rootEditPart= new ScalableFreeformRootEditPart();
                  getGraphicalViewer().setRootEditPart(rootEditPart);

                  ZoomManager manager = rootEditPart.getZoomManager();
                  IAction action = new ZoomInAction(manager);
                  getActionRegistry().registerAction(action);
                  action = new ZoomOutAction(manager);
                  getActionRegistry().registerAction(action);

                  //define the zoom possibilities
                  double[] zoomLevels = new double[] {0.25,0.5,0.75,1.0,1.5,2.0,2.5,3.0,4.0};
                  manager.setZoomLevels(zoomLevels);
             ...in Method: getAdapter...
                  if (type == ZoomManager.class)
                        return ((ScalableFreeformRootEditPart) getGraphicalViewer().
                                  getRootEditPart()).getZoomManager();

          That's all! Now you have two buttons to zoom in and zoom out. And you can see the zoom level in percent.  With the example here you  can change  zoom level from 25% to 400%.

          posted @ 2005-10-25 23:38 lucia 閱讀(1378) | 評論 (0)編輯 收藏

          2005年10月17日

          There is an example of creating linked resources in code.
          IProject project = workspace.getProject("Project");//assume this exists
          IFolder link = project.getFolder("Link");
          IPath location = new Path("C:\TEMP\folder");
          if (workspace.validateLinkLocation(location).isOK()) {
          link.createLink(location, IResource.NONE, null);
          } else {
          //invalid location, throw an exception or warn user
          }

          This example will create a linked folder called "Link" that is located at "c:\temp\folder".

          link.getFullPath() => "/Project/Link"
          link.getLocation() => "c:\temp\folder"
          link.getRawLocation() => "temp/folder"
          link.isLinked() => "true"
          IFile child = link.getFile("abc.txt");
          child.create(...);
          child.getFullPath() => "/Project/Link/abc.txt"
          child.getLocation() => "c:\temp\folder\abc.txt"
          child.getRawLocation() => "c:\temp\folder\abc.txt"
          child.isLinked() => "false"

          posted @ 2005-10-17 05:25 lucia 閱讀(843) | 評論 (0)編輯 收藏

          2005年9月21日

          Recently I had a problem in converting java.io.File to IFile for external files. The external files sind the files which are not located in the eclipse workspace. So they are not eclipse "resources" and can not be converted into IFile instances. With the following code you can solve this problem:

                           IEditorInput input= createEditorInput(selectedFile);
                           String editorId= getEditorId(selectedFile);
                           IWorkbenchPage page= fWindow.getActivePage();
                           try {
                               page.openEditor(input, editorId);
                           } catch (PartInitException e) {
                               //EditorsPlugin.log(e.getStatus());
                           }

          This idea comes from org.eclipse.ui.internal.editors.text.OpenExternalFileAction. In this class you can also find the implementation for the methods "createEditorInput" and "getEditorId".
          posted @ 2005-09-21 17:50 lucia 閱讀(586) | 評論 (0)編輯 收藏

          2005年9月14日

          In JDK 1.4 System.getenv() is deprecated. (In JDK 1.5 it is un-deprected again.) The getProperty method is now the correspoding method to get the variables. For example: System.getProperty("java.class.path",""). But it doesn't work for user defined environment variable. This problem can be solved by using the following code:
          import java.io.BufferedReader;
          import java.io.InputStreamReader;

          /**
          * Environment class simulates the System.getenv() method which is deprecated
          * on java 1.4.2
          *
          * @author v-josp
          *
          */
          public class TestRoot
          {
          //result of all enviornment variables
          private static BufferedReader commandResult;

          static
          {
          String cmd = null;
          String os = null;

          //getting the OS name
          os = System.getProperty("os.name").toLowerCase();

          // according to OS set the command to execute
          if(os.startsWith("windows"))
          {
          cmd = "cmd /c SET";
          }
          else
          {
          cmd="env";
          }

          try
          {
          //execute the command and get the result in the form of InputStream
          Process p = Runtime.getRuntime().exec(cmd);

          //parse the InputStream data
          InputStreamReader isr = new InputStreamReader(p.getInputStream());
          commandResult= new BufferedReader(isr);
          }
          catch (Exception e)
          {
          System.out.println("OSEnvironment.class error: " + cmd + ":" + e);
          }
          }

          /**
          * This method is used to get the path of the given enviornment variable. This
          * method tries to simulates the System.getenv() which is deprecated on java 1.4.2
          *
          * @param String - name of the environment variable
          * @param String - default value
          * @return
          */
          public static String getenv(String envName,String defaultValue)
          {
          String line = null;
          try
          {
          while ((line = commandResult.readLine()) != null)
          {
          if(line.indexOf(envName)>-1)
          {
          return line.substring(line.indexOf(envName)+envName.length()+1);
          }
          }
          return defaultValue;
          }
          catch (Exception e)
          {
          return defaultValue;
          }
          }

          public static void main(String args[])
          {
          System.out.println(TestRoot.getenv("CLASSPATH",""));
          }
          }

          Output
          _____
          F:\software\javaws-1_2-dev\jnlp.jar;
          posted @ 2005-09-14 02:36 lucia 閱讀(668) | 評論 (0)編輯 收藏

          2005年9月10日

          try {
          File currDir = new File (".");
          System.out.println("Dir: " + currDir.getCanonicalPath());
          }
          catch (IOException ex){
          //
          }


          posted @ 2005-09-10 22:12 lucia 閱讀(325) | 評論 (0)編輯 收藏

          2005年9月7日

          I will use one simple example to explain how to add context menu into editor dynamically. "Dynamically" means the menu items will change according to the selected object.
          There are three steps:

          1. Define the action. Please read the following example code:

          /**
           *  What I want to realize is to provide a "copy" menu item in popup menu
           *  whenever the user selects the object "Example".
           */

          public class CopyExampleAction extends org.eclipse.gef.ui.actions.SelectionAction
          {
              private static final String
                  COPY_REQUEST = "COPY";  //$NON-NLS-1$
              public static final String
                  COPY = "COPY";   //$NON-NLS-1$

              Request request;

              public CopyExampleAction(IWorkbenchPart part) {
                  super(part);
                  request = new Request(COPY_REQUEST);
                  setText("copy Example");
                  setId(COPY);
                  setImageDescriptor(
                      ImageDescriptor.createFromFile(ExamplePlugin.class,"icons/copy.gif")); //$NON-NLS-1$
                  setHoverImageDescriptor(getImageDescriptor());
              }

              protected boolean calculateEnabled() {
                  return canPerformAction();
              }

              private boolean canPerformAction() {
                  if (getSelectedObjects().isEmpty())
                      return false;
                  List parts = getSelectedObjects();
                  for (int i=0; i<parts.size(); i++){
                      Object o = parts.get(i);
                      if (!(o instanceof EditPart))
                          return false;
                      EditPart part = (EditPart)o;
                     // This menu item will only be activated if an object of Typ "Example" is selected.
                      if (!(part.getModel() instanceof Example))
                          return false;
                      }
                  }
                  return true;
              }

          // What happened for this action is defined by the edit part of this object.
              private Command getCommand() {
                  List editparts = getSelectedObjects();
                  CompoundCommand cc = new CompoundCommand();
                  cc.setDebugLabel("Copy Example");//$NON-NLS-1$
                  for (int i=0; i < editparts.size(); i++) {
                      EditPart part = (EditPart)editparts.get(i);
                      cc.add(part.getCommand(request));
                  }
                  return cc;
              }

              public void run() {
                  execute(getCommand());
              }
              }

          2. Implement the action. In this step you will decide what will exactly happen after the user clicked this menu item. As you have already seen from the code in the step 1, the command for this action is defined in edit part for the object "Example".
          So the next you will do is to complete the ExampleEditPolicy for ExampleEditPart.

          public class ExampleEditPolicy extends ComponentEditPolicy{
            
              private static final String
              COPY_REQUEST = "COPY",  //$NON-NLS-1$

          public Command getCommand(Request request) {
              if (COPY_REQUEST.equals(request.getType()))
                  return getCopyExampleCommand();
              return super.getCommand(request);
          }

          protected Command getCopyExampleCommand(){
           // The implementation of CopyExampleCommand is simple, will not be explained here.
              CopyExampleCommand command = new CopyExampleCommand();
              command.setCopyObject((Example)getHost().getModel());
              return command;
          }
          }

          3. Add the action into Context Menu.
          There is always a class to provider the context menu, the next step is to add this defined action into the context menu.

          public class ExampleContextMenuProvider extends ContextMenuProvider {
            
              private ActionRegistry actionRegistry;
             
              public ExampleContextMenuProvider(EditPartViewer viewer, ActionRegistry registry) {
                  super(viewer);
                  setActionRegistry(registry);
              }

              public void buildContextMenu(IMenuManager manager) {
                  GEFActionConstants.addStandardActionGroups(manager);
                  IAction action;
                  action = getActionRegistry().getAction(CopyExampleAction.COPY);
                  if (action.isEnabled())
                      manager.appendToGroup(GEFActionConstants.GROUP_REST, action);
              }   

              private ActionRegistry getActionRegistry() {
                  return actionRegistry;
              }

              private void setActionRegistry(ActionRegistry registry) {
                  actionRegistry = registry;
              }
          }

          4. Add the action into editor. There is a method "createActions" in editor. Add the action in it. That's all.

          protected void createActions() {
            super.createActions();
            ActionRegistry registry = getActionRegistry();
            IAction action;

            action = new CopyExampleAction(this);
            registry.registerAction(action);
            getSelectionActions().add(action.getId());
          }

          posted @ 2005-09-07 17:07 lucia 閱讀(687) | 評論 (0)編輯 收藏

          2005年9月2日

          Display.getCurrent().getSystemColor(SWT.COLOR_WHITE)
          posted @ 2005-09-02 20:31 lucia 閱讀(228) | 評論 (0)編輯 收藏

          2005年8月29日

          In this section I want to show the steps to define your own documentation plug-in to integrate your online documentation with Eclipse.
          1. Create the help content as HTML files and store them in your plug-in directory. Normally we use doc in the name. If there are too many files, you can creat a ZIP file named doc.zip.
          2. Decliare the HELP Table of Contents in your plug-in using the org.eclipse.help.toc extension point and specify the table of content files.

          Example:
          <extension point = "org.eclipse.help.toc">
              <toc     file ="DialogTOC.xml"/>
              <toc     file ="MoreTOC.xml"/>
              <toc     file ="TestTOC.xml"
                          primary = "true"
                          extradir = "lab">   
              </toc>
          </extension>

          The table of the contents will be described by one or more XML files. In this example, TestTOC.xml is the primary table of contents file, which describes the structure and order of the other files by linking them together.

          Example: TestTOC.xml
          <?xml version="1.0" encoding="UTF-8"?>
          <?NLS TYPE="org.eclipse.help.toc"?>
          <toc label="JDG2E: Help Example TOC">
              <link toc="DialogTOC.xml" />
              <anchor id="moreLabs" />
          </toc>

          3. Create the table of contents files by linking the topic together.

          Example: MoreTOC.xml
          <?xml version="1.0" encoding="UTF-8"?>
          <?NLS TYPE="org.eclipse.help.toc"?>
          <toc link_to="TestToc.xml#moreLabs"
            label="More interesting labs">
            <topic label="JDT Main Topic"  href="html/maintopic.html">
               <topic label="JDT Sub Topic" href="html/subtopic.html"/>
            </topic>
            <topic label="Extra Topic"  href="lab/doc1/info1.html">
              <topic label="Using the extradir attrib" href="lab/doc2/info2.html"/>
            </topic>
          </toc>

          In addition, you can invove the Eclipse Help system form any Java program indenpendent from Eclipse. This is called "standalone" mode. To do that, you simply use the Platform Runtime Binary version of Eclipse as opposed to the SDK and inovke the main methode in the class org.eclipse.help.internal.standalone.StandaloneHelp. Of course you should pass the location of the plugins directory,which includes the online contents, as a paramter.

          (The example used is taken from the book "The JavaTM Developer's Guide to Eclipse".)
          posted @ 2005-08-29 21:28 lucia 閱讀(393) | 評論 (0)編輯 收藏
           
               摘要: To create a viewer in SWT is not a simple task. These are steps that will be described: 1. Identify the input. 2. Create the viewer. 3. Create a content provider. 4. Create a label provide...  閱讀全文
          posted @ 2005-08-29 16:39 lucia 閱讀(3258) | 評論 (2)編輯 收藏
           
          Copyright © lucia Powered by: 博客園 模板提供:滬江博客
          主站蜘蛛池模板: 清丰县| 清远市| 奉新县| 阿鲁科尔沁旗| 凤冈县| 邳州市| 弥渡县| 宝应县| 叶城县| 秦安县| 绥中县| 民县| 来宾市| 佛山市| 民和| 大邑县| 忻城县| 金山区| 静乐县| 元氏县| 澄城县| 凤冈县| 来安县| 清水河县| 桂阳县| 石河子市| 甘洛县| 敦化市| 洛扎县| 白山市| 普定县| 富宁县| 台安县| 万州区| 裕民县| 明星| 五大连池市| 房产| 乐业县| 阳山县| 株洲县|