2013-12-01 00:03:40 -05:00
|
|
|
package mekanism.api;
|
2013-11-30 00:28:02 -05:00
|
|
|
|
2013-12-01 00:15:52 -05:00
|
|
|
import net.minecraft.util.StatCollector;
|
2013-11-30 00:28:02 -05:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Simple color enum for adding colors to in-game GUI strings of text.
|
|
|
|
* @author AidanBrady
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
public enum EnumColor
|
|
|
|
{
|
2013-12-22 00:42:46 -05:00
|
|
|
BLACK("\u00a70", "black", new int[] {0, 0, 0}, 0),
|
|
|
|
DARK_BLUE("\u00a71", "darkBlue", new int[] {0, 0, 170}, 4),
|
|
|
|
DARK_GREEN("\u00a72", "darkGreen", new int[] {0, 170, 0}, 2),
|
|
|
|
DARK_AQUA("\u00a73", "darkAqua", new int[] {0, 170, 170}, 6),
|
|
|
|
DARK_RED("\u00a74", "darkRed", new int[] {170, 0, 0}, 1),
|
|
|
|
PURPLE("\u00a75", "purple", new int[] {170, 0, 170}, 5),
|
|
|
|
ORANGE("\u00a76", "orange", new int[] {255, 170, 0}, 14),
|
|
|
|
GREY("\u00a77", "grey", new int[] {170, 170, 170}, 7),
|
|
|
|
DARK_GREY("\u00a78", "darkGrey", new int[] {85, 85, 85}, 8),
|
|
|
|
INDIGO("\u00a79", "indigo", new int[] {85, 85, 255}, 12),
|
|
|
|
BRIGHT_GREEN("\u00a7a", "brightGreen", new int[] {85, 255, 85}, 10),
|
|
|
|
AQUA("\u00a7b", "aqua", new int[] {85, 255, 255}, -1),
|
|
|
|
RED("\u00a7c", "red", new int[] {255, 85, 85}, 13),
|
|
|
|
PINK("\u00a7d", "pink", new int[] {255, 85, 255}, 9),
|
|
|
|
YELLOW("\u00a7e", "yellow", new int[] {255, 255, 85}, 11),
|
|
|
|
WHITE("\u00a7f", "white", new int[] {255, 255, 255}, 15);
|
|
|
|
|
|
|
|
public static EnumColor[] DYES = new EnumColor[] {BLACK, DARK_RED, DARK_GREEN, null, DARK_BLUE, PURPLE, DARK_AQUA, GREY, DARK_GREY, PINK, BRIGHT_GREEN, YELLOW, INDIGO, RED, ORANGE, WHITE};
|
2013-11-30 00:28:02 -05:00
|
|
|
|
|
|
|
/** The color code that will be displayed */
|
|
|
|
public final String code;
|
|
|
|
|
|
|
|
public final int[] rgbCode;
|
|
|
|
|
2013-12-22 00:42:46 -05:00
|
|
|
public final int mcMeta;
|
|
|
|
|
2013-11-30 00:28:02 -05:00
|
|
|
/** A friendly name of the color. */
|
|
|
|
public String unlocalizedName;
|
|
|
|
|
2013-12-22 00:42:46 -05:00
|
|
|
private EnumColor(String s, String n, int[] rgb, int meta)
|
2013-11-30 00:28:02 -05:00
|
|
|
{
|
|
|
|
code = s;
|
|
|
|
unlocalizedName = n;
|
|
|
|
rgbCode = rgb;
|
2013-12-22 00:42:46 -05:00
|
|
|
mcMeta = meta;
|
2013-11-30 00:28:02 -05:00
|
|
|
}
|
|
|
|
|
2013-12-23 17:06:22 -05:00
|
|
|
/**
|
|
|
|
* Gets the localized name of this color by translating the unlocalized name.
|
|
|
|
* @return localized name
|
|
|
|
*/
|
2013-11-30 00:28:02 -05:00
|
|
|
public String getLocalizedName()
|
|
|
|
{
|
2013-12-01 00:15:52 -05:00
|
|
|
return StatCollector.translateToLocal("color." + unlocalizedName);
|
2013-11-30 00:28:02 -05:00
|
|
|
}
|
|
|
|
|
2013-12-23 17:06:22 -05:00
|
|
|
/**
|
|
|
|
* Gets the name of this color with it's color prefix code.
|
|
|
|
* @return the color's name and color prefix
|
|
|
|
*/
|
2013-11-30 00:28:02 -05:00
|
|
|
public String getName()
|
|
|
|
{
|
|
|
|
return code + getLocalizedName();
|
|
|
|
}
|
|
|
|
|
2013-12-23 17:06:22 -05:00
|
|
|
/**
|
|
|
|
* Gets the 0-1 of this color's RGB value by dividing by 255 (used for OpenGL coloring).
|
|
|
|
* @param index - R:0, G:1, B:2
|
|
|
|
* @return the color value
|
|
|
|
*/
|
2013-11-30 00:28:02 -05:00
|
|
|
public float getColor(int index)
|
|
|
|
{
|
|
|
|
return (float)rgbCode[index]/255F;
|
|
|
|
}
|
|
|
|
|
2013-12-23 17:06:22 -05:00
|
|
|
/**
|
|
|
|
* Gets the value of this color mapped to MC in-game item colors present in dyes and wool.
|
|
|
|
* @return mc meta value
|
|
|
|
*/
|
2013-12-22 00:42:46 -05:00
|
|
|
public int getMetaValue()
|
|
|
|
{
|
|
|
|
return mcMeta;
|
|
|
|
}
|
|
|
|
|
2013-11-30 00:28:02 -05:00
|
|
|
@Override
|
|
|
|
public String toString()
|
|
|
|
{
|
|
|
|
return code;
|
|
|
|
}
|
|
|
|
}
|