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

com.googlecode.blaisemath.graphics.AttributeGraphicUpdater Maven / Gradle / Ivy

package com.googlecode.blaisemath.graphics;

/*
 * #%L
 * BlaiseGraphics
 * --
 * Copyright (C) 2009 - 2024 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.util.swing.ContextMenuInitializer;
import org.checkerframework.checker.nullness.qual.Nullable;

import java.awt.geom.Rectangle2D;
import java.util.function.Function;

/**
 * A graphic updater that operates on a per-item basis, and provides built in
 * functions for setting graphic styles, and for initializing graphic context menus.
 * @param  type of object being updated
 * @param  graphics canvas
 * @author Elisha Peterson
 */
public abstract class AttributeGraphicUpdater implements GraphicUpdater {

    /** Generates attributes from base object. */
    private @Nullable Function attributeMap;
    /** Initializes context menus */
    private ContextMenuInitializer menu;

    //region PROPERTIES

    public @Nullable Function getAttributeMap() {
        return attributeMap;
    }

    public void setAttributeMap(@Nullable Function attr) {
        this.attributeMap = attr;
    }

    public ContextMenuInitializer getMenuInitializer() {
        return menu;
    }

    public void setMenuInitializer(ContextMenuInitializer menu) {
        this.menu = menu;
    }
        
    //endregion
    
    /**
     * Create a new graphic for the given object. The {@link #update(Object, Rectangle2D, Graphic)}
     * method will first create an {@link AttributeSet} associated with the object,
     * provided to this method as the {@code style} parameter, and after creating
     * the graphic will register a {@link ContextMenuInitializer} if set.
     * @param e the object represented by the graphic
     * @param attr attributes for the graphic, as created by the attribute function
     * @param bounds desired bounding box for the graphic
     * @return graphic
     */
    public abstract Graphic create(E e, AttributeSet attr, Rectangle2D bounds);
    
    /**
     * Update an existing graphic for the given object.
     * @param e the object represented by the graphic
     * @param attr attributes for the graphic, as created by the attribute function
     * @param bounds desired bounding box for the graphic
     * @param existing the existing graphic (guaranteed to be non-null)
     */
    public abstract void update(E e, AttributeSet attr, Rectangle2D bounds, Graphic existing);

    @Override
    public Graphic update(E e, Rectangle2D bounds, Graphic existing) {
        AttributeSet as = attributeMap == null ? new AttributeSet() : attributeMap.apply(e);
        if (existing == null) {
            Graphic gfc = create(e, as, bounds);
            if (menu != null) {
                gfc.addContextMenuInitializer(menu);
            }
            return gfc;
        } else {
            update(e, as, bounds, existing);
            return existing;
        }
    }
    
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy