Follow Techotopia on Twitter

On-line Guides
All Guides
eBook Store
iOS / Android
Linux for Beginners
Office Productivity
Linux Installation
Linux Security
Linux Utilities
Linux Virtualization
Linux Kernel
System/Network Admin
Programming
Scripting Languages
Development Tools
Web Development
GUI Toolkits/Desktop
Databases
Mail Systems
openSolaris
Eclipse Documentation
Techotopia.com
Virtuatopia.com
Answertopia.com

How To Guides
Virtualization
General System Admin
Linux Security
Linux Filesystems
Web Servers
Graphics & Desktop
PC Hardware
Windows
Problem Solutions
Privacy Policy

  




 

 

Eclipse Plug-in Developer Guide
Previous Page Home Next Page

Perspective Extensions

Identifier:
org.eclipse.ui.perspectiveExtensions

Description:
This extension point is used to extend perspectives registered by other plug-ins. A perspective defines the initial contents of the window action bars (menu and toolbar) and the initial set of views and their layout within a workbench page. Other plug-ins may contribute actions or views to the perspective which appear when the perspective is selected. Optional additions by other plug-ins are appended to the initial definition.

Configuration Markup:

<!ELEMENT extension ( perspectiveExtension*)>

<!ATTLIST extension

point CDATA #REQUIRED

id    CDATA #IMPLIED

name  CDATA #IMPLIED

>

  • point - a fully qualified identifier of the target extension point
  • id - an optional identifier of the extension instance
  • name - an optional name of the extension instance

<!ELEMENT perspectiveExtension ( actionSet | viewShortcut | perspectiveShortcut | newWizardShortcut | view | showInPart | hiddenMenuItem | hiddenToolBarItem)*>

<!ATTLIST perspectiveExtension

targetID IDREF #REQUIRED

>

  • targetID - the unique identifier of the perspective (as specified in the registry) into which the contribution is made. If the value is set to "*" the extension is applied to all perspectives.

<!ELEMENT actionSet EMPTY>

<!ATTLIST actionSet

id IDREF #REQUIRED

>

  • id - the unique identifier of the action set which will be added to the perspective.

<!ELEMENT viewShortcut EMPTY>

<!ATTLIST viewShortcut

id IDREF #REQUIRED

>

  • id - the unique identifier of the view which will be added to the perspective's "Show View" submenu of the "Window" menu.

<!ELEMENT perspectiveShortcut EMPTY>

<!ATTLIST perspectiveShortcut

id IDREF #REQUIRED

>

  • id - the unique identifier of the perspective which will be added to the perspective's "Open Perspective" submenu of the "Window" menu.

<!ELEMENT newWizardShortcut EMPTY>

<!ATTLIST newWizardShortcut

id IDREF #REQUIRED

>

  • id - the unique identifier of the new wizard which will be added to the perspective's "New" submenu of the "File" menu.

<!ELEMENT showInPart EMPTY>

<!ATTLIST showInPart

id IDREF #IMPLIED

>

  • id - the unique identifier of the view which will be added to the perspective's "Show In..." prompter in the Navigate menu.

<!ELEMENT view EMPTY>

<!ATTLIST view

id           IDREF #REQUIRED

relative     IDREF #IMPLIED

relationship (stack|left|right|top|bottom|fast)

ratio        CDATA #IMPLIED

visible      (true | false)

closeable    (true | false)

moveable     (true | false)

standalone   (true | false)

showTitle    (true | false)

minimized    (true | false) "false"

>

  • id - the unique identifier of the view which will be added to the perspective layout.
  • relative - the unique identifier of a view which already exists in the perspective. This will be used as a reference point for placement of the view. The relationship between these two views is defined by relationship. Ignored if relationship is "fast".
  • relationship - specifies the relationship between id and relative. The following values are supported:
      fast - the view extension will be created as a fast view.
      stack - the view extension will be stacked with the relative view in a folder.
      left, right, top, bottom - the view extension will be placed beside the relative view. In this case a ratio must also be defined.
  • ratio - the percentage of area within the relative view which will be donated to the view extension. If the view extension is a fast view, the ratio is the percentage of the workbench the fast view will cover when active. This must be defined as a floating point value and lie between 0.05 and 0.95.
  • visible - whether the view is initially visible when the perspective is opened. This attribute should have a value of "true" or "false" if used. If this attribute is not used, the view will be initially visible by default.
  • closeable - whether the view is closeable in the target perspective. This attribute should have a value of "true" or "false" if used. If this attribute is not used, the view will be closeable, unless the perspective itself is marked as fixed.
  • moveable - whether the view is moveable. A non-moveable view cannot be moved either within the same folder, or moved between folders in the perspective. This attribute should have a value of "true" or "false" if used. If this attribute is not used, the view will be moveable, unless the perspective itself is marked as fixed.
  • standalone - whether the view is a standalone view. A standalone view cannot be docked together with others in the same folder. This attribute should have a value of "true" or "false" if used. This attribute is ignored if the relationship attribute is "fast" or "stacked". If this attribute is not used, the view will be a regular view, not a standalone view (default is "false").
  • showTitle - whether the view's title is shown. This attribute should have a value of "true" or "false" if used. This attribute only applies to standalone views. If this attribute is not used, the view's title will be shown (default is "true").
  • minimized - If the perspective extension will result in a new view stack being created (i.e. the 'relationship' attribute is one of left, right, top or bottom) this field determines the new stack's initial display state.

<!ELEMENT hiddenMenuItem EMPTY>

<!ATTLIST hiddenMenuItem

id CDATA #REQUIRED

>

  • id - The unique identifier of the Command which is to be removed from the menu. WARNING: This is considered to be a 'Product level' extension and should not be used in consumable plugins without great care.

<!ELEMENT hiddenToolBarItem EMPTY>

<!ATTLIST hiddenToolBarItem

id CDATA #REQUIRED

>

  • id - The unique identifier of the Command which is to be removed from thetoolbar. WARNING: This is considered to be a 'Product level' extension and should not be used in consumable plugins without great care.

Examples:
The following is an example of a perspective extension (note the subelements and the way attributes are used):


    <extension point=
"org.eclipse.ui.perspectiveExtensions"
> 
        <perspectiveExtension 
            targetID=
"org.eclipse.ui.resourcePerspective"
> 
            <actionSet id=
"org.eclipse.jdt.ui.JavaActionSet"
/> 
            <viewShortcut id=
"org.eclipse.jdt.ui.PackageExplorer"
/> 
            <newWizardShortcut id=
"org.eclipse.jdt.ui.wizards.NewProjectCreationWizard"
/> 
            <perspectiveShortcut id=
"org.eclipse.jdt.ui.JavaPerspective"
/> 
            <view id=
"org.eclipse.jdt.ui.PackageExplorer"
 
                relative=
"org.eclipse.ui.views.ResourceNavigator"
 
                relationship=
"stack"
/> 
            <view id=
"org.eclipse.jdt.ui.TypeHierarchy"
 
                relative=
"org.eclipse.ui.views.ResourceNavigator"
 
                relationship=
"left"
 
                ratio=
"0.50"
/> 
        </perspectiveExtension> 
    </extension> 

In the example above, an action set, view shortcut, new wizard shortcut, and perspective shortcut are contributed to the initial contents of the Resource Perspective. In addition, the Package Explorer view is stacked on the Resource Navigator and the Type Hierarchy View is added beside the Resource Navigator.


Copyright (c) 2002, 2007 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 https://www.eclipse.org/legal/epl-v10.html


 
 
  Published under the terms of the Eclipse Public License Version 1.0 ("EPL") Design by Interspire