All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.eclipse.jface.action.ControlContribution Maven / Gradle / Ivy

The newest version!
/*******************************************************************************
 * Copyright (c) 2000, 2019 IBM Corporation and others.
 *
 * This program and the accompanying materials
 * are made available under the terms of the Eclipse Public License 2.0
 * which accompanies this distribution, and is available at
 * https://www.eclipse.org/legal/epl-2.0/
 *
 * SPDX-License-Identifier: EPL-2.0
 *
 * Contributors:
 *     IBM Corporation - initial API and implementation
 *     Christoph Läubrich - Bug 551587
 *******************************************************************************/
package org.eclipse.jface.action;

import org.eclipse.core.runtime.Assert;
import org.eclipse.jface.util.Policy;
import org.eclipse.swt.SWT;
import org.eclipse.swt.widgets.Composite;
import org.eclipse.swt.widgets.Control;
import org.eclipse.swt.widgets.Menu;
import org.eclipse.swt.widgets.ToolBar;
import org.eclipse.swt.widgets.ToolItem;

/**
 * An abstract contribution item implementation for adding an arbitrary
 * SWT control to a tool bar.
 * Note, however, that these items cannot be contributed to menu bars.
 * 

* The createControl framework method must be implemented * by concrete subclasses. *

*/ public abstract class ControlContribution extends ContributionItem { private ToolItem ti; /** * Creates a control contribution item with the given id. * * @param id the contribution item id */ protected ControlContribution(String id) { super(id); } /** * Computes the width of the given control which is being added * to a tool bar. This is needed to determine the width of the tool bar item * containing the given control. *

* The default implementation of this framework method returns * control.computeSize(SWT.DEFAULT, SWT.DEFAULT, true).x. * Subclasses may override if required. *

* * @param control the control being added * @return the width of the control */ protected int computeWidth(Control control) { return control.computeSize(SWT.DEFAULT, SWT.DEFAULT, true).x; } /** * Creates and returns the control for this contribution item * under the given parent composite. *

* This framework method must be implemented by concrete * subclasses. *

* * @param parent the parent composite * @return the new control, must not be null */ protected abstract Control createControl(Composite parent); /** * The control item implementation of this IContributionItem * method calls the createControl framework method. * Subclasses must implement createControl rather than * overriding this method. */ @Override public final void fill(Composite parent) { createControl(parent); } /** * The control item implementation of this IContributionItem * method throws an exception since controls cannot be added to menus. */ @Override public final void fill(Menu parent, int index) { Assert.isTrue(false, "Can't add a control to a menu");//$NON-NLS-1$ } /** * The control item implementation of this IContributionItem * method calls the createControl framework method to * create a control under the given parent, and then creates * a new tool item to hold it. * Subclasses must implement createControl rather than * overriding this method. */ @Override public final void fill(ToolBar parent, int index) { Control control = createControl(parent); if (control == null) { Policy.logException(new IllegalStateException( "createControl(Composite) of " + getClass() //$NON-NLS-1$ + " returned null, cannot fill toolbar")); //$NON-NLS-1$ } else { ti = new ToolItem(parent, SWT.SEPARATOR, index); ti.setControl(control); ti.setWidth(computeWidth(control)); ti.setData(this); } } @Override public void setVisible(boolean visible) { super.setVisible(visible); IContributionManager parent = getParent(); if (parent instanceof SubToolBarManager) { SubToolBarManager subManager = (SubToolBarManager) parent; IContributionItem item = subManager.getParent().find(getId()); if (item instanceof SubContributionItem) { item.setVisible(visible); } } } @Override public void update() { if (ti != null && !ti.isDisposed()) { Control control = ti.getControl(); if (control != null && !control.isDisposed()) { ti.setWidth(computeWidth(control)); } } } @Override public void update(String id) { update(); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy