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

org.openbp.cockpit.modeler.figures.VisualElement Maven / Gradle / Ivy

The newest version!
/*
 *   Licensed under the Apache License, Version 2.0 (the "License");
 *   you may not use this file except in compliance with the License.
 *   You may obtain a copy of the License at
 *
 *       http://www.apache.org/licenses/LICENSE-2.0
 *
 *   Unless required by applicable law or agreed to in writing, software
 *   distributed under the License is distributed on an "AS IS" BASIS,
 *   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 *   See the License for the specific language governing permissions and
 *   limitations under the License.
 */
package org.openbp.cockpit.modeler.figures;

import org.openbp.cockpit.modeler.drawing.ProcessDrawing;
import org.openbp.jaspira.gui.interaction.InteractionClient;

import CH.ifa.draw.framework.Figure;

/**
 * A visual element represents a figure of a process drawing.
 * It supports visual status changes, element hierarchies, drag and drop and custom cursors/tools.
 *
 * @author Heiko Erhardt
 */
public interface VisualElement
	extends Figure, InteractionClient
{
	/** Visual element is currently visible */
	public static final int VISUAL_VISIBLE = (1 << 0);

	/** Visual element is currently a drop target */
	public static final int VISUAL_DND_PARTICIPANT = (1 << 1);

	/** Display the entire content of the visual element */
	public static final int VISUAL_DISPLAY_ALL = (1 << 2);

	/**
	 * Sets the drawing the element is a part of.
	 */
	public void setDrawing(ProcessDrawing processDrawing);

	/**
	 * Gets the drawing the element is a part of.
	 */
	public ProcessDrawing getDrawing();

	/**
	 * Gets parent element of this element, if any.
	 */
	public VisualElement getParentElement();

	/**
	 * Gets the presentation figure of this element.
	 *
	 * @return The presentation figure
* Note that this can be the visual element itself if it does not have a separate presentation figure */ public Figure getPresentationFigure(); /** * Updates (reinitializes) the presentation figure. */ public void updatePresentationFigure(); /** * Gets the flag if the element is currently visible. */ public boolean isVisible(); /** * Sets the flag if the element is currently visible. */ public void setVisible(boolean visible); /** * Handler method that is called for handling events. * Events can be cursor events, selection events etc. * * @param event Event that desribes the event * @return * true: The event was handled by the element.
* false: No special handling, perform the default handling. */ public boolean handleEvent(VisualElementEvent event); }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy