Dodawanie perspektywy

Jeśli aplikacja klienta pełnego używa klasy WorkbenchAdvisor jako podstawowego sposobu dostosowywania środowiska roboczego, musi dostarczyć perspektywę widoczną w jego oknie. Ta perspektywa musi zostać określona w klasie doradcy środowiska roboczego aplikacji. W klasie BrowserAdvisor określone zostały następujące elementy:

	public String getInitialWindowPerspectiveId() {
		return BrowserApp.BROWSER_PERSPECTIVE_ID; 
	}

Natomiast klasa BrowserApp definiuje:

	public static final String PLUGIN_ID = "org.eclipse.ui.examples.rcp.browser";
	public static final String BROWSER_PERSPECTIVE_ID = PLUGIN_ID + ".browserPerspective";

Odpowiednia perspektywa jest definiowana w pliku manifestu modułu dodatkowego przeglądarki:

      <extension
         point="org.eclipse.ui.perspectives">
      <perspective
            id="org.eclipse.ui.examples.rcp.browser.browserPerspective"
            name="%perspectives.browser.name"
            class="org.eclipse.ui.examples.rcp.browser.BrowserPerspectiveFactory"
            fixed="true"/>
    </extension>

Klasa BrowserPerspectiveFactory odpowiada za właściwe ułożenie widoków.

	public void createInitialLayout(IPageLayout layout) {
		layout.addView(BrowserApp.BROWSER_VIEW_ID, IPageLayout.RIGHT, .25f, IPageLayout.ID_EDITOR_AREA);
		layout.addPlaceholder(BrowserApp.HISTORY_VIEW_ID, IPageLayout.LEFT, .3f, IPageLayout.ID_EDITOR_AREA); 
		IViewLayout historyLayout = layout.getViewLayout(BrowserApp.HISTORY_VIEW_ID);
		historyLayout.setCloseable(true);
		layout.setEditorAreaVisible(false);
	}

Perspektywa przeglądarki definiuje dwa widoki (jeden widoczny, zawierający obiekt zastępczy dla drugiego) i ukrywa obszar edytora. Pełne omówienie perspektyw i ich odpowiedniego układu zawiera sekcja Perspektywy.