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

com.googlecode.blaisemath.graphics.core.DelegatingPrimitiveArrayGraphic Maven / Gradle / Ivy

There is a newer version: 3.0.16
Show newest version
/**
 * DelegatingPrimitiveArrayGraphic.java
 * Created Jul 31, 2014
 */

package com.googlecode.blaisemath.graphics.core;

/*
 * #%L
 * BlaiseGraphics
 * --
 * Copyright (C) 2009 - 2019 Elisha Peterson
 * --
 * 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.
 * #L%
 */


import com.googlecode.blaisemath.style.AttributeSet;
import com.googlecode.blaisemath.style.ObjectStyler;
import com.googlecode.blaisemath.style.Renderer;
import java.awt.geom.Point2D;
import java.util.Set;
import javax.swing.JPopupMenu;

/**
 * A graphic that maintains a source object and uses an {@link ObjectStyler}
 * delegate to retrieve its style set.
 * 
 * @param  type of source object
 * @param  type of primitive
 * @param  type of graphics canvas to render to
 * 
 * @author Elisha
 */
public class DelegatingPrimitiveArrayGraphic extends PrimitiveArrayGraphicSupport {
   
    /** The source object */
    protected S source;
    /** The style set for this graphic */
    protected ObjectStyler styler;

    public DelegatingPrimitiveArrayGraphic() {
    }

    public DelegatingPrimitiveArrayGraphic(S source, O[] primitive, ObjectStyler styler, Renderer renderer) {
        setPrimitive(primitive);
        setSourceObject(source);
        setObjectStyler(styler);
        setRenderer(renderer);
    }
    
    //
    //
    // PROPERTY PATTERNS
    //

    @Override
    public AttributeSet getStyle() {
        return styler.style(source);
    }

    public S getSourceObject() {
        return source;
    }

    public final void setSourceObject(S source) {
        this.source = source;
        sourceGraphicUpdated();
    }

    public ObjectStyler getObjectStyler() {
        return styler;
    }

    public final void setObjectStyler(ObjectStyler styler) {
        this.styler = styler;
        sourceGraphicUpdated();
    }
    
    //
    
    /**
     * Update the context menu initializer to use the source object for the focus, rather than the graphic.
     * @param menu context menu
     * @param src source for context menu
     * @param point mouse location
     * @param focus object of focus (overridden)
     * @param selection current selection (null's okay)
     */
    @Override
    public void initContextMenu(JPopupMenu menu, Graphic src, Point2D point, Object focus, Set selection) {
        super.initContextMenu(menu, src, point, source, selection);
    }
    
    /**
     * Hook method for updating the shape attributes after the source graphic or style has changed.
     * This version of the method updates the tooltip and notifies listeners that the
     * graphic has changed.
     */
    protected void sourceGraphicUpdated() {
        setDefaultTooltip(styler.tooltip(source, null));
        fireGraphicChanged();
    }
    
}