/*
Copyright 2008-2010 Gephi
Authors : Jeremy Subtil <jeremy.subtil@gephi.org>
Website : http://www.gephi.org
This file is part of Gephi.
Gephi is free software: you can redistribute it and/or modify
it under the terms of the GNU Affero General Public License as
published by the Free Software Foundation, either version 3 of the
License, or (at your option) any later version.
Gephi is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Affero General Public License for more details.
You should have received a copy of the GNU Affero General Public License
along with Gephi. If not, see <http://www.gnu.org/licenses/>.
*/
package org.gephi.preview.updaters;
import org.gephi.preview.api.Color;
import org.gephi.preview.api.ColorizerClient;
import org.gephi.preview.api.EdgeChildColorizer;
import org.gephi.preview.api.EdgeChildColorizerClient;
import org.gephi.preview.api.EdgeColorizer;
import org.gephi.preview.api.EdgeColorizerClient;
import org.gephi.preview.api.GenericColorizer;
import org.gephi.preview.api.NodeChildColorizer;
import org.gephi.preview.api.NodeChildColorizerClient;
import org.gephi.preview.api.NodeColorizer;
import org.gephi.preview.api.NodeColorizerClient;
import org.gephi.preview.util.color.SimpleColor;
/**
* This color mode colors its clients using a custom color.
*
* @author Jérémy Subtil <jeremy.subtil@gephi.org>
*/
public class CustomColorMode
implements GenericColorizer, NodeColorizer, NodeChildColorizer, EdgeColorizer, EdgeChildColorizer {
private static final String IDENTIFIER = "custom";
private final Color color;
/**
* Constructor.
*
* @param r the red color component
* @param g the green color component
* @param b the blue color component
*/
public CustomColorMode(int r, int g, int b) {
color = new SimpleColor(r, g, b);
}
/**
* Colors the given client.
*
* @param client the client to color
*/
private void doColor(ColorizerClient client) {
client.setColor(color);
}
/**
* Colors the given client.
*
* @param client the client to color
*/
public void color(ColorizerClient client) {
doColor(client);
}
/**
* Colors the given client.
*
* @param client the client to color
*/
public void color(NodeColorizerClient client) {
doColor(client);
}
/**
* Colors the given client.
*
* @param client the client to color
*/
public void color(NodeChildColorizerClient client) {
doColor(client);
}
/**
* Colors the given client.
*
* @param client the client to color
*/
public void color(EdgeChildColorizerClient client) {
doColor(client);
}
/**
* Colors the given client.
*
* @param client the client to color
*/
public void color(EdgeColorizerClient client) {
doColor(client);
}
/**
* Formats the colorizer as a string.
*
* @return the colorizer formatted as a string
*/
@Override
public String toString() {
return String.format(
"%s [%d,%d,%d]",
IDENTIFIER,
color.getRed(),
color.getGreen(),
color.getBlue());
}
/**
* Returns the colorizer's identifier.
*
* @return the colorizer's identifier
*/
public static String getIdentifier() {
return IDENTIFIER;
}
/**
* Returns the colorizer's reference color.
*
* @return the colorizer's reference color
*/
public Color getColor() {
return color;
}
/**
* Returns the colorizer's reference color as an AWT Color object.
*
* @return the colorizer's reference color
*/
public java.awt.Color getAwtColor() {
return new java.awt.Color(color.getRed(), color.getGreen(), color.getBlue());
}
}