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

com.mxgraph.swing.util.mxSwingConstants Maven / Gradle / Ivy

/**
 * Copyright (c) 2007-2012, JGraph Ltd
 */
package com.mxgraph.swing.util;

import java.awt.BasicStroke;
import java.awt.Color;
import java.awt.Component;
import java.awt.Graphics;
import java.awt.Graphics2D;
import java.awt.Stroke;
import java.awt.image.BufferedImage;
import java.util.logging.Level;
import java.util.logging.Logger;

import javax.swing.border.Border;
import javax.swing.border.LineBorder;

public class mxSwingConstants
{

	private static final Logger log = Logger.getLogger(mxSwingConstants.class.getName());

	/**
	 * Contains an empty image of size 1, 1.
	 */
	public static BufferedImage EMPTY_IMAGE;

	static
	{
		try
		{
			mxSwingConstants.EMPTY_IMAGE = new BufferedImage(1, 1,
					BufferedImage.TYPE_INT_RGB);
		}
		catch (Exception e)
		{
			log.log(Level.FINE, "Failed to initialize EMPTY_IMAGE", e);
			// Occurs when running on GAE, BufferedImage is a
			// blacklisted class
			mxSwingConstants.EMPTY_IMAGE = null;
		}
	}
	
	/**
	 * Defines the color to be used for shadows. Default is gray.
	 */
	public static Color SHADOW_COLOR;
	
	/**
	 * Specifies the default valid color. Default is green.
	 */
	public static Color DEFAULT_VALID_COLOR;

	/**
	 * Specifies the default invalid color. Default is red.
	 */
	public static Color DEFAULT_INVALID_COLOR;
	
	/**
	 * Defines the rubberband border color. 
	 */
	public static Color RUBBERBAND_BORDERCOLOR;

	/**
	 * Defines the rubberband fill color with an alpha of 80.
	 */
	public static Color RUBBERBAND_FILLCOLOR;
	
	/**
	 * Defines the handle border color. Default is black.
	 */
	public static Color HANDLE_BORDERCOLOR;

	/**
	 * Defines the handle fill color. Default is green.
	 */
	public static Color HANDLE_FILLCOLOR;

	/**
	 * Defines the label handle fill color. Default is yellow.
	 */
	public static Color LABEL_HANDLE_FILLCOLOR;

	/**
	 * Defines the connect handle fill color. Default is blue.
	 */
	public static Color CONNECT_HANDLE_FILLCOLOR;

	/**
	 * Defines the handle fill color for locked handles. Default is red.
	 */
	public static Color LOCKED_HANDLE_FILLCOLOR;
	
	/**
	 * Defines the selection color for edges. Default is green.
	 */
	public static Color EDGE_SELECTION_COLOR;

	/**
	 * Defines the selection color for vertices. Default is green.
	 */
	public static Color VERTEX_SELECTION_COLOR;
	
	static
	{
		try
		{
			mxSwingConstants.SHADOW_COLOR = Color.gray;
			mxSwingConstants.DEFAULT_VALID_COLOR = Color.GREEN;
			mxSwingConstants.DEFAULT_INVALID_COLOR = Color.RED;
			mxSwingConstants.RUBBERBAND_BORDERCOLOR = new Color(51, 153, 255);
			mxSwingConstants.RUBBERBAND_FILLCOLOR = new Color(51, 153, 255, 80);
			mxSwingConstants.HANDLE_BORDERCOLOR = Color.black;
			mxSwingConstants.HANDLE_FILLCOLOR = Color.green;
			mxSwingConstants.LABEL_HANDLE_FILLCOLOR = Color.yellow;
			mxSwingConstants.LOCKED_HANDLE_FILLCOLOR = Color.red;
			mxSwingConstants.CONNECT_HANDLE_FILLCOLOR = Color.blue;
			mxSwingConstants.EDGE_SELECTION_COLOR = Color.green;
			mxSwingConstants.VERTEX_SELECTION_COLOR = Color.green;
		}
		catch (Exception e)
		{
			log.log(Level.FINE, "Failed to initialize color constants", e);
			// Occurs when running on GAE, Color is a
			// blacklisted class
			mxSwingConstants.SHADOW_COLOR = null;
			mxSwingConstants.DEFAULT_VALID_COLOR = null;
			mxSwingConstants.DEFAULT_INVALID_COLOR = null;
			mxSwingConstants.RUBBERBAND_BORDERCOLOR = null;
			mxSwingConstants.RUBBERBAND_FILLCOLOR = null;
			mxSwingConstants.HANDLE_BORDERCOLOR = null;
			mxSwingConstants.HANDLE_FILLCOLOR = null;
			mxSwingConstants.LABEL_HANDLE_FILLCOLOR = null;
			mxSwingConstants.LOCKED_HANDLE_FILLCOLOR = null;
			mxSwingConstants.CONNECT_HANDLE_FILLCOLOR = null;
			mxSwingConstants.EDGE_SELECTION_COLOR = null;
			mxSwingConstants.VERTEX_SELECTION_COLOR = null;
		}
	}
	
	/**
	 * Defines the stroke used for painting selected edges. Default is a dashed
	 * line.
	 */
	public static Stroke EDGE_SELECTION_STROKE = new BasicStroke(1,
			BasicStroke.CAP_BUTT, BasicStroke.JOIN_MITER, 10.0f, new float[] {
					3, 3 }, 0.0f);

	/**
	 * Defines the stroke used for painting the border of selected vertices.
	 * Default is a dashed line.
	 */
	public static Stroke VERTEX_SELECTION_STROKE = new BasicStroke(1,
			BasicStroke.CAP_BUTT, BasicStroke.JOIN_MITER, 10.0f, new float[] {
					3, 3 }, 0.0f);

	/**
	 * Defines the stroke used for painting the preview for new and existing edges
	 * that are being changed. Default is a dashed line.
	 */
	public static Stroke PREVIEW_STROKE = new BasicStroke(1,
			BasicStroke.CAP_BUTT, BasicStroke.JOIN_MITER, 10.0f, new float[] {
					3, 3 }, 0.0f);

	/**
	 * Defines the border used for painting the preview when vertices are being
	 * resized, or cells and labels are being moved.
	 */
	public static Border PREVIEW_BORDER = new LineBorder(
			mxSwingConstants.HANDLE_BORDERCOLOR)
	{
		/**
		 * 
		 */
		private static final long serialVersionUID = 1348016511717964310L;

		public void paintBorder(Component c, Graphics g, int x, int y,
				int width, int height)
		{
			((Graphics2D) g).setStroke(VERTEX_SELECTION_STROKE);
			super.paintBorder(c, g, x, y, width, height);
		}
	};
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy