/*\r
* Jalview - A Sequence Alignment Editor and Viewer\r
- * Copyright (C) 2005 AM Waterhouse, J Procter, G Barton, M Clamp, S Searle\r
+ * Copyright (C) 2007 AM Waterhouse, J Procter, G Barton, M Clamp, S Searle\r
*\r
* This program is free software; you can redistribute it and/or\r
* modify it under the terms of the GNU General Public License\r
*/\r
package jalview.schemes;\r
\r
+import java.util.*;\r
+\r
import java.awt.*;\r
\r
public class UserColourScheme\r
extends ResidueColourScheme\r
{\r
+ Color[] lowerCaseColours;\r
+\r
+ protected String schemeName;\r
+\r
+ public UserColourScheme()\r
+ {}\r
+\r
+ public UserColourScheme(Color[] newColors)\r
+ {\r
+ colors = newColors;\r
+ }\r
+\r
public UserColourScheme(String colour)\r
{\r
+ Color col = getColourFromString(colour);\r
+\r
+ if (col == null)\r
+ {\r
+ System.out.println("Unknown colour!! " + colour);\r
+ col = createColourFromName(colour);\r
+ }\r
+\r
+ colors = new Color[24];\r
+ for (int i = 0; i < 24; i++)\r
+ {\r
+ colors[i] = col;\r
+ }\r
+ }\r
+\r
+ public Color[] getColours()\r
+ {\r
+ return colors;\r
+ }\r
+\r
+ public Color[] getLowerCaseColours()\r
+ {\r
+ return lowerCaseColours;\r
+ }\r
+\r
+ public void setName(String name)\r
+ {\r
+ schemeName = name;\r
+ }\r
+\r
+ public String getName()\r
+ {\r
+ return schemeName;\r
+ }\r
+\r
+ public Color getColourFromString(String colour)\r
+ {\r
+ colour = colour.trim();\r
+\r
Color col = null;\r
- try{\r
+ try\r
+ {\r
int value = Integer.parseInt(colour, 16);\r
col = new Color(value);\r
}\r
- catch(NumberFormatException ex){}\r
+ catch (NumberFormatException ex)\r
+ {}\r
\r
- if(col==null)\r
+ if (col == null)\r
+ {\r
col = ColourSchemeProperty.getAWTColorFromName(colour);\r
+ }\r
\r
- if(col==null)\r
+ if (col == null)\r
{\r
- System.out.println("Unknown colour!! "+colour);\r
+ try\r
+ {\r
+ java.util.StringTokenizer st = new java.util.StringTokenizer(colour,\r
+ ",");\r
+ int r = Integer.parseInt(st.nextToken());\r
+ int g = Integer.parseInt(st.nextToken());\r
+ int b = Integer.parseInt(st.nextToken());\r
+ col = new Color(r, g, b);\r
+ }\r
+ catch (Exception ex)\r
+ {}\r
}\r
\r
- colors = new Color[24];\r
- for(int i=0; i<24; i++)\r
- colors[i] = col;\r
+ return col;\r
+\r
}\r
\r
- public UserColourScheme(Color[] newColors)\r
+ public Color createColourFromName(String name)\r
{\r
- colors = newColors;\r
+ int r, g, b;\r
+\r
+ int lsize = name.length();\r
+ int start = 0, end = lsize / 3;\r
+\r
+ int rgbOffset = Math.abs(name.hashCode() % 10) * 15;\r
+\r
+ r = Math.abs(name.substring(start, end).hashCode() + rgbOffset) % 210 + 20;\r
+ start = end;\r
+ end += lsize / 3;\r
+ if (end > lsize)\r
+ {\r
+ end = lsize;\r
+ }\r
+\r
+ g = Math.abs(name.substring(start, end).hashCode() + rgbOffset) % 210 + 20;\r
+\r
+ b = Math.abs(name.substring(end).hashCode() + rgbOffset) % 210 + 20;\r
+\r
+ Color color = new Color(r, g, b);\r
+\r
+ return color;\r
}\r
\r
- public Color[] getColours()\r
+ public void parseAppletParameter(String paramValue)\r
{\r
- return colors;\r
+ StringTokenizer st = new StringTokenizer(paramValue, ";");\r
+ StringTokenizer st2;\r
+ String token = null, colour, residues;\r
+ try\r
+ {\r
+ while (st.hasMoreElements())\r
+ {\r
+ token = st.nextToken().trim();\r
+ residues = token.substring(0, token.indexOf("="));\r
+ colour = token.substring(token.indexOf("=") + 1);\r
+\r
+ st2 = new StringTokenizer(residues, " ,");\r
+ while (st2.hasMoreTokens())\r
+ {\r
+ token = st2.nextToken();\r
+\r
+ if (ResidueProperties.aaIndex[token.charAt(0)] == -1)\r
+ {\r
+ continue;\r
+ }\r
+\r
+ int colIndex = ResidueProperties.aaIndex[token.charAt(0)];\r
+\r
+ if (token.equalsIgnoreCase("lowerCase"))\r
+ {\r
+ if (lowerCaseColours == null)\r
+ {\r
+ lowerCaseColours = new Color[23];\r
+ }\r
+ for (int i = 0; i < 23; i++)\r
+ {\r
+ if (lowerCaseColours[i] == null)\r
+ {\r
+ lowerCaseColours[i] = getColourFromString(colour);\r
+ }\r
+ }\r
+\r
+ continue;\r
+ }\r
+\r
+ if (token.equals(token.toLowerCase()))\r
+ {\r
+ if (lowerCaseColours == null)\r
+ {\r
+ lowerCaseColours = new Color[23];\r
+ }\r
+ lowerCaseColours[colIndex] = getColourFromString(colour);\r
+ }\r
+ else\r
+ {\r
+ colors[colIndex] = getColourFromString(colour);\r
+ }\r
+ }\r
+ }\r
+ }\r
+ catch (Exception ex)\r
+ {\r
+ System.out.println("Error parsing userDefinedColours:\n"\r
+ + token + "\n" + ex);\r
+ }\r
+\r
+ }\r
+\r
+ public Color findColour(char c, int j)\r
+ {\r
+ Color currentColour;\r
+ int index = ResidueProperties.aaIndex[c];\r
+\r
+ if ( (threshold == 0) || aboveThreshold(c, j))\r
+ {\r
+ if (lowerCaseColours != null && 'a' <= c && c <= 'z')\r
+ {\r
+ currentColour = lowerCaseColours[index];\r
+ }\r
+ else\r
+ {\r
+ currentColour = colors[index];\r
+ }\r
+ }\r
+ else\r
+ {\r
+ currentColour = Color.white;\r
+ }\r
+\r
+ if (conservationColouring)\r
+ {\r
+ currentColour = applyConservation(currentColour, j);\r
+ }\r
+\r
+ return currentColour;\r
}\r
+\r
+ public void setLowerCaseColours(Color[] lcolours)\r
+ {\r
+ lowerCaseColours = lcolours;\r
+ }\r
+\r
}\r