$packageName$.$className$.java Source code

Java tutorial

Introduction

Here is the source code for $packageName$.$className$.java

Source

/*******************************************************************************
 * This file is protected by Copyright. 
 * Please refer to the COPYRIGHT file distributed with this source distribution.
 *
 * This file is part of REDHAWK IDE.
 *
 * 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
 *******************************************************************************/
package $packageName$;

    %if viewType=="treeViewer"

    import java.util.ArrayList;%endif

import org.eclipse.swt.widgets.Composite;
import org.eclipse.ui.part.*;
import org.eclipse.jface.viewers.*;
import org.eclipse.swt.graphics.Image;
import org.eclipse.jface.action.*;
import org.eclipse.jface.dialogs.MessageDialog;
import org.eclipse.ui.*;
import org.eclipse.swt.widgets.Menu;
    import org.eclipse.swt.SWT;%if viewType=="treeViewer"
import org.eclipse.core.runtime.IAdaptable;%endif

    /**
     * This sample class demonstrates how to plug-in a new
     * workbench view. The view shows data obtained from the
     * model. The sample creates a dummy model on the fly,
     * but a real implementation would connect to the model
     * available either in this or another plug-in (e.g. the workspace).
     * The view is connected to the model using a content provider.
     * <p>
     * The view uses a label provider to define how model
     * objects should be presented in the view. Each
     * view can present the same model objects using
     * different labels and icons, if needed. Alternatively,
     * a single label provider can be shared between views
     * in order to ensure that objects of the same type are
     * presented in the same way everywhere.
     * <p>
     */
    %Options in the template:%%packageName%className%viewName%viewCategoryId%viewCategoryName%viewType%filter%drillDown

    public class $className$ extends ViewPart {
        %if addViewID

   /**
    * The ID of the view as specified by the extension.
    */
   public static final String ID = "$packageName$.$className$";

        %endif%if viewType=="tableViewer"
        private TableViewer viewer;%else%if viewType=="treeViewer"
   private TreeViewer viewer;
        private DrillDownAdapter drillDownAdapter;%endif%endif
        private Action action1;
        private Action action2;
        private Action doubleClickAction;

        /*
         * The content provider class is responsible for
         * providing objects to the view. It can wrap
         * existing objects in adapters or simply return
         * objects as-is. These objects may be sensitive
         * to the current input of the view, or ignore
         * it and always show the same content 
         * (like Task List, for example).
         */

        %if viewType=="tableViewer"

        class ViewContentProvider implements IStructuredContentProvider {
      public void inputChanged(Viewer v, Object oldInput, Object newInput) {
      }

      public void dispose() {
      }

            public Object[] getElements(Object parent) {
                return new String[] { "One", "Two", "Three" };
            }
        }%else%if viewType=="treeViewer"

        class TreeObject implements IAdaptable {
            private String name;
            private TreeParent parent;

      public TreeObject(String name) {
         this.name = name;
      }

      public String getName() {
         return name;
      }

            public void setParent(TreeParent parent) {
                this.parent = parent;
            }

            public TreeParent getParent() {
                return parent;
            }

            public String toString() {
                return getName();
            }

            public Object getAdapter(Class key) {
                return null;
            }
        }

        class TreeParent extends TreeObject {
            private ArrayList children;

            public TreeParent(String name) {
                super(name);
                children = new ArrayList();
            }

            public void addChild(TreeObject child) {
                children.add(child);
                child.setParent(this);
            }

            public void removeChild(TreeObject child) {
                children.remove(child);
                child.setParent(null);
            }

            public TreeObject[] getChildren() {
                return (TreeObject[]) children.toArray(new TreeObject[children.size()]);
            }

            public boolean hasChildren() {
                return children.size() > 0;
            }
        }

   class ViewContentProvider implements IStructuredContentProvider, 
                                 ITreeContentProvider {
      private TreeParent invisibleRoot;

      public void inputChanged(Viewer v, Object oldInput, Object newInput) {
      }
      public void dispose() {
      }
      public Object[] getElements(Object parent) {
         if (parent.equals(getViewSite())) {
            if (invisibleRoot==null) initialize();
            return getChildren(invisibleRoot);
         }
         return getChildren(parent);
      }
      public Object getParent(Object child) {
         if (child instanceof TreeObject) {
            return ((TreeObject)child).getParent();
         }
         return null;
      }
      public Object [] getChildren(Object parent) {
         if (parent instanceof TreeParent) {
            return ((TreeParent)parent).getChildren();
         }
         return new Object[0];
      }
      public boolean hasChildren(Object parent) {
         if (parent instanceof TreeParent)
            return ((TreeParent)parent).hasChildren();
         return false;
      }
/*
 * We will set up a dummy model to initialize tree heararchy.
 * In a real code, you will connect to a real model and
 * expose its hierarchy.
 */
      private void initialize() {
         TreeObject to1 = new TreeObject("Leaf 1");
         TreeObject to2 = new TreeObject("Leaf 2");
         TreeObject to3 = new TreeObject("Leaf 3");
         TreeParent p1 = new TreeParent("Parent 1");
         p1.addChild(to1);
         p1.addChild(to2);
         p1.addChild(to3);
         
         TreeObject to4 = new TreeObject("Leaf 4");
         TreeParent p2 = new TreeParent("Parent 2");
         p2.addChild(to4);
         
         TreeParent root = new TreeParent("Root");
         root.addChild(p1);
         root.addChild(p2);
         
         invisibleRoot = new TreeParent("");
         invisibleRoot.addChild(root);
      }
   }%endif%endif%if viewType=="tableViewer"

        class ViewLabelProvider extends LabelProvider implements ITableLabelProvider {
      public String getColumnText(Object obj, int index) {
         return getText(obj);
      }

      public Image getColumnImage(Object obj, int index) {
         return getImage(obj);
      }

      public Image getImage(Object obj) {
         return PlatformUI.getWorkbench().
               getSharedImages().getImage(ISharedImages.IMG_OBJ_ELEMENT);
      }
        }%else

        class ViewLabelProvider extends LabelProvider {

      public String getText(Object obj) {
         return obj.toString();
      }

      public Image getImage(Object obj) {
         String imageKey = ISharedImages.IMG_OBJ_ELEMENT;
         if (obj instanceof TreeParent)
            imageKey = ISharedImages.IMG_OBJ_FOLDER;
         return PlatformUI.getWorkbench().getSharedImages().getImage(imageKey);
      }
        }%endif

   class NameSorter extends ViewerSorter {
   }

        /**
         * The constructor.
         */
        public $className$() {
        }

   /**
    * This is a callback that will allow us
    * to create the viewer and initialize it.
    */
   public void createPartControl(Composite parent) {
%if viewType =="tableViewer"
      viewer = new TableViewer(parent, SWT.MULTI | SWT.H_SCROLL | SWT.V_SCROLL);
%else
%  if viewType =="treeViewer"
      viewer = new TreeViewer(parent, SWT.MULTI | SWT.H_SCROLL | SWT.V_SCROLL);
      drillDownAdapter = new DrillDownAdapter(viewer);
%  endif
%endif
      viewer.setContentProvider(new ViewContentProvider());
      viewer.setLabelProvider(new ViewLabelProvider());
      viewer.setSorter(new NameSorter());
      viewer.setInput(getViewSite());
%if contextHelp

      // Create the help context id for the viewer's control
      PlatformUI.getWorkbench().getHelpSystem().setHelp(viewer.getControl(), "$pluginId$.viewer");
%endif
      makeActions();
      hookContextMenu();
      hookDoubleClickAction();
      contributeToActionBars();
   }

        private void hookContextMenu() {
            MenuManager menuMgr = new MenuManager("#PopupMenu");
            menuMgr.setRemoveAllWhenShown(true);
            menuMgr.addMenuListener(new IMenuListener() {
                public void menuAboutToShow(IMenuManager manager) {
                    $className$.this.fillContextMenu(manager);
                }
            });
            Menu menu = menuMgr.createContextMenu(viewer.getControl());
            viewer.getControl().setMenu(menu);
            getSite().registerContextMenu(menuMgr, viewer);
        }

        private void contributeToActionBars() {
            IActionBars bars = getViewSite().getActionBars();
            fillLocalPullDown(bars.getMenuManager());
            fillLocalToolBar(bars.getToolBarManager());
        }

        private void fillLocalPullDown(IMenuManager manager) {
            manager.add(action1);
            manager.add(new Separator());
            manager.add(action2);
        }

   private void fillContextMenu(IMenuManager manager) {
      manager.add(action1);
      manager.add(action2);
%   if viewType == "treeViewer"
      manager.add(new Separator());
      drillDownAdapter.addNavigationActions(manager);
%   endif
      // Other plug-ins can contribute there actions here
      manager.add(new Separator(IWorkbenchActionConstants.MB_ADDITIONS));
   }

   private void fillLocalToolBar(IToolBarManager manager) {
      manager.add(action1);
      manager.add(action2);
%   if viewType == "treeViewer"
      manager.add(new Separator());
      drillDownAdapter.addNavigationActions(manager);
%  endif
   }

        private void makeActions() {
            action1 = new Action() {
                public void run() {
                    showMessage("Action 1 executed");
                }
            };
            action1.setText("Action 1");
            action1.setToolTipText("Action 1 tooltip");
            action1.setImageDescriptor(
                    PlatformUI.getWorkbench().getSharedImages().getImageDescriptor(ISharedImages.IMG_OBJS_INFO_TSK));

            action2 = new Action() {
                public void run() {
                    showMessage("Action 2 executed");
                }
            };
            action2.setText("Action 2");
            action2.setToolTipText("Action 2 tooltip");
            action2.setImageDescriptor(
                    PlatformUI.getWorkbench().getSharedImages().getImageDescriptor(ISharedImages.IMG_OBJS_INFO_TSK));
            doubleClickAction = new Action() {
                public void run() {
                    ISelection selection = viewer.getSelection();
                    Object obj = ((IStructuredSelection) selection).getFirstElement();
                    showMessage("Double-click detected on " + obj.toString());
                }
            };
        }

        private void hookDoubleClickAction() {
            viewer.addDoubleClickListener(new IDoubleClickListener() {
                public void doubleClick(DoubleClickEvent event) {
                    doubleClickAction.run();
                }
            });
        }

        private void showMessage(String message) {
            MessageDialog.openInformation(viewer.getControl().getShell(), "$viewName$", message);
        }

        /**
         * Passing the focus request to the viewer's control.
         */
        public void setFocus() {
            viewer.getControl().setFocus();
        }
    }