001/* 002 * Copyright (c) 2009 The openGion Project. 003 * 004 * Licensed under the Apache License, Version 2.0 (the "License"); 005 * you may not use this file except in compliance with the License. 006 * You may obtain a copy of the License at 007 * 008 * http://www.apache.org/licenses/LICENSE-2.0 009 * 010 * Unless required by applicable law or agreed to in writing, software 011 * distributed under the License is distributed on an "AS IS" BASIS, 012 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, 013 * either express or implied. See the License for the specific language 014 * governing permissions and limitations under the License. 015 */ 016package org.opengion.fukurou.util; 017 018import org.opengion.fukurou.system.OgRuntimeException ; // 6.4.2.0 (2016/01/29) 019import java.awt.Color; 020// import java.util.LinkedHashMap; // 6.4.6.1 (2016/06/03) 021import java.util.Map; 022import java.util.HashMap; // 7.0.1.1 (2018/10/22) 023// import java.util.List; // 6.9.9.2 (2018/09/18) 024// import java.util.ArrayList; // 6.9.9.2 (2018/09/18) 025import java.util.Locale ; 026 027import static org.opengion.fukurou.system.HybsConst.CR; // 6.1.0.0 (2014/12/26) refactoring 028 029/** 030 * ColorMap.java は、共通的に使用される Color関連メソッドを集約した、クラスです。 031 * StringUtil から、Color関係の部分を独立させました。 032 * 033 * カラー文字列は、java.awt.Color static 定義色、CSS1 / HTML3–4 / VGA の色名称、 034 * X11の色名称 が指定できます。 035 * 036 * カラー番号は、ビビッドを、0~11 (V0~V11) , パステルを、12~23 (P0~P11) として登録します。 037 * 従来のカラー番号と異なりますので、ご注意ください。 038 * 039 * @og.group ユーティリティ 040 * @og.rev 6.0.2.1 (2014/09/26) 新規作成 041 * @og.rev 6.4.3.3 (2016/03/04) ViewForm_ImageTimeBar#FlgColorMap 内部クラスから機能移動 042 * @og.rev 7.0.1.1 (2018/10/22) 内部色コードを文字列として管理、配列は、パステルとビビッドから作成します。 043 * 044 * @version 6.0 045 * @author Kazuhiko Hasegawa 046 * @since JDK8.0, 047 */ 048public final class ColorMap { 049// // 6.9.9.2 (2018/09/18) Map から、CLR_ARY を作成します。 050// // 6.4.3.3 (2016/03/04) ViewForm_ImageTimeBar#FlgColorMap 内部クラスから移動 051// private static final Color[] CLR_ARY = new Color[] { 052// Color.BLUE ,Color.CYAN ,Color.GRAY ,Color.GREEN ,Color.LIGHT_GRAY ,Color.MAGENTA , 053// Color.DARK_GRAY ,Color.ORANGE ,Color.PINK ,Color.RED ,Color.YELLOW 054// }; 055 056 /** 色種別キーワード {@value} */ 057 public static final String VIVID = "VIVID" ; // 7.0.1.3 (2018/11/12) 058 /** 色種別キーワード {@value} */ 059 public static final String PASTEL = "PASTEL" ; // 7.0.1.3 (2018/11/12) 060 061 // 7.0.1.1 (2018/10/22) ビビッドカラー の色コード配列追加 062 private static final String[] VIVID_KEY = new String[] { 063 "#0000FF" , "#00FF00" , "#FF0000" , // 5, 9, 1 064 "#00FFFF" , "#FFFF00" , "#FF00FF" , // 7, 11, 3 065 "#00FF7F" , "#FF7F00" , "#7F00FF" , // 8, 12, 4 066 "#007FFF" , "#7FFF00" , "#FF007F" // 6, 10, 2 067 }; 068 069 // 6.9.9.2 (2018/09/18) パステルカラー の色コード配列追加 070 private static final String[] PSTL_KEY = new String[] { 071 "#7F7FFF" , "#7FFF7F" , "#FF7F7F" , // 5, 9, 1 072 "#7FFFFF" , "#FFFF7F" , "#FF7FFF" , // 7, 11, 3 073 "#7FFFBF" , "#FFBF7F" , "#BF7FFF" , // 8, 12, 4 074 "#7FBFFF" , "#BFFF7F" , "#FF7FBF" // 6, 10, 2 075 }; 076 077 private static final String[] COLOR_KEY = new String[VIVID_KEY.length + PSTL_KEY.length]; 078 static { 079 System.arraycopy( VIVID_KEY, 0, COLOR_KEY, 0 , VIVID_KEY.length ); 080 System.arraycopy( PSTL_KEY , 0, COLOR_KEY, VIVID_KEY.length , PSTL_KEY.length ); 081 } 082 083// 084// // 4.0.3.0 (2007/12/26) 色コードにPURPLE を追加 085// // 5.7.8.0 (2014/07/04) 透明追加 086// private static final List<Color> CLR_LIST = new ArrayList<>(); // 6.9.9.2 (2018/09/18) 色配列ではなく、リストに変更します。 087 /** staticイニシャライザ。読み取り専用(Collections.unmodifiableMap(Map))や、ConcurrentHashMap を使用しません。 */ 088// private static final Map<String,Color> CLR_MAP = new LinkedHashMap<>(); // 6.4.6.1 (2016/06/03) 登録順をキープします。 089 private static final Map<String,String> CLR_MAP = new HashMap<>(); // 7.0.1.1 (2018/10/22) 文字列として管理します。 090 static { 091 // java.awt.Color static 定義色 092 CLR_MAP.put( "BLUE" , "#0000FF" ); // Color.BLUE 093 CLR_MAP.put( "CYAN" , "#00FFFF" ); // Color.CYAN 094 CLR_MAP.put( "GRAY" , "#808080" ); // Color.GRAY 095 CLR_MAP.put( "GREEN" , "#008000" ); // Color.GREEN 096 CLR_MAP.put( "LIGHTGRAY" , "#D3D3D3" ); // Color.LIGHT_GRAY 097 CLR_MAP.put( "MAGENTA" , "#FF00FF" ); // Color.MAGENTA 098 CLR_MAP.put( "DARKGRAY" , "#A9A9A9" ); // Color.DARK_GRAY 099 CLR_MAP.put( "ORANGE" , "#FFA500" ); // Color.ORANGE 100 CLR_MAP.put( "PINK" , "#FFC0CB" ); // Color.PINK 101 CLR_MAP.put( "RED" , "#FF0000" ); // Color.RED 102 CLR_MAP.put( "YELLOW" , "#FFFF00" ); // Color.YELLOW 103 104// // 6.9.9.2 (2018/09/18) CSS1 / HTML3–4 / VGA の色名称の後ろに移動。 105// CLR_MAP.put( "WHITE" ,Color.WHITE ); 106// CLR_MAP.put( "BLACK" ,Color.BLACK ); 107// CLR_MAP.put( "TRANSPARENT" ,new Color( 255,255,255,0 ) ); // 5.7.8.0 (2014/07/04) 透明追加 108 109 // 6.0.2.1 (2014/09/26) CSS1 / HTML3–4 / VGA の色名称 追加 110 CLR_MAP.put( "LIME" , "#00FF00" ); 111 CLR_MAP.put( "AQUA" , "#00FFFF" ); 112 CLR_MAP.put( "SILVER" , "#C0C0C0" ); 113 CLR_MAP.put( "MAROON" , "#800000" ); // X11では、#B03060 114 CLR_MAP.put( "OLIVE" , "#808000" ); 115 CLR_MAP.put( "TEAL" , "#008080" ); 116 CLR_MAP.put( "NAVY" , "#000080" ); 117 CLR_MAP.put( "FUCHSIA" , "#FF00FF" ); 118 CLR_MAP.put( "PURPLE" , "#800080" ); // X11では、#A020F0 119 120// // 6.9.9.2 (2018/09/18) Map から、CLR_LIST を作成するのは、ここまで。 121// CLR_LIST.addAll( CLR_MAP.values() ); 122// 123// // 6.9.9.2 (2018/09/18) パステルカラー の色コード配列追加 124// for( final String col : PSTL_KEY ) { 125// CLR_LIST.add( Color.decode( col ) ); 126// } 127 128 CLR_MAP.put( "WHITE" , "#FFFFFF" ); // WHITE 129 CLR_MAP.put( "BLACK" , "#000000" ); // BLACK 130// CLR_MAP.put( "TRANSPARENT" , new Color( 255,255,255,0 ) ); // 5.7.8.0 (2014/07/04) 透明追加 131 CLR_MAP.put( "TRANSPARENT" , "rgba( 255,255,255,0 )" ); // 7.0.1.2 (2018/11/04) 透明 132 133 // 6.0.2.1 (2014/09/26) X11の色名称 追加 134 CLR_MAP.put( "ALICEBLUE" , "#F0F8FF" ); 135 CLR_MAP.put( "ANTIQUEWHITE" , "#FAEBD7" ); 136 CLR_MAP.put( "AQUAMARINE" , "#7FFFD4" ); 137 CLR_MAP.put( "AZURE" , "#F0FFFF" ); 138 CLR_MAP.put( "BEIGE" , "#F5F5DC" ); 139 CLR_MAP.put( "BISQUE" , "#FFE4C4" ); 140 CLR_MAP.put( "BLANCHEDALMOND" , "#FFEBCD" ); 141 CLR_MAP.put( "BLUEVIOLET" , "#8A2BE2" ); 142 CLR_MAP.put( "BROWN" , "#A52A2A" ); 143 CLR_MAP.put( "BURLYWOOD" , "#DEB887" ); 144 CLR_MAP.put( "CADETBLUE" , "#5F9EA0" ); 145 CLR_MAP.put( "CHARTREUSE" , "#7FFF00" ); 146 CLR_MAP.put( "CHOCOLATE" , "#D2691E" ); 147 CLR_MAP.put( "CORAL" , "#FF7F50" ); 148 CLR_MAP.put( "CORNFLOWERBLUE" , "#6495ED" ); 149 CLR_MAP.put( "CORNSILK" , "#FFF8DC" ); 150 CLR_MAP.put( "CRIMSON" , "#DC143C" ); 151 CLR_MAP.put( "DARKBLUE" , "#00008B" ); 152 CLR_MAP.put( "DARKCYAN" , "#008B8B" ); 153 CLR_MAP.put( "DARKGOLDENROD" , "#B8860B" ); 154 CLR_MAP.put( "DARKGREEN" , "#006400" ); 155 CLR_MAP.put( "DARKKHAKI" , "#BDB76B" ); 156 CLR_MAP.put( "DARKMAGENTA" , "#8B008B" ); 157 CLR_MAP.put( "DARKOLIVEGREEN" , "#556B2F" ); 158 CLR_MAP.put( "DARKORANGE" , "#FF8C00" ); 159 CLR_MAP.put( "DARKORCHID" , "#9932CC" ); 160 CLR_MAP.put( "DARKRED" , "#8B0000" ); 161 CLR_MAP.put( "DARKSALMON" , "#E9967A" ); 162 CLR_MAP.put( "DARKSEAGREEN" , "#8FBC8F" ); 163 CLR_MAP.put( "DARKSLATEBLUE" , "#483D8B" ); 164 CLR_MAP.put( "DARKSLATEGRAY" , "#2F4F4F" ); 165 CLR_MAP.put( "DARKTURQUOISE" , "#00CED1" ); 166 CLR_MAP.put( "DARKVIOLET" , "#9400D3" ); 167 CLR_MAP.put( "DEEPPINK" , "#FF1493" ); 168 CLR_MAP.put( "DEEPSKYBLUE" , "#00BFFF" ); 169 CLR_MAP.put( "DIMGRAY" , "#696969" ); 170 CLR_MAP.put( "DODGERBLUE" , "#1E90FF" ); 171 CLR_MAP.put( "FIREBRICK" , "#B22222" ); 172 CLR_MAP.put( "FLORALWHITE" , "#FFFAF0" ); 173 CLR_MAP.put( "FORESTGREEN" , "#228B22" ); 174 CLR_MAP.put( "GAINSBORO" , "#DCDCDC" ); 175 CLR_MAP.put( "GHOSTWHITE" , "#F8F8FF" ); 176 CLR_MAP.put( "GOLD" , "#FFD700" ); 177 CLR_MAP.put( "GOLDENROD" , "#DAA520" ); 178 CLR_MAP.put( "GREENYELLOW" , "#ADFF2F" ); 179 CLR_MAP.put( "HONEYDEW" , "#F0FFF0" ); 180 CLR_MAP.put( "HOTPINK" , "#FF69B4" ); 181 CLR_MAP.put( "INDIANRED" , "#CD5C5C" ); 182 CLR_MAP.put( "INDIGO" , "#4B0082" ); 183 CLR_MAP.put( "IVORY" , "#FFFFF0" ); 184 CLR_MAP.put( "KHAKI" , "#F0E68C" ); 185 CLR_MAP.put( "LAVENDER" , "#E6E6FA" ); 186 CLR_MAP.put( "LAVENDERBLUSH" , "#FFF0F5" ); 187 CLR_MAP.put( "LAWNGREEN" , "#7CFC00" ); 188 CLR_MAP.put( "LEMONCHIFFON" , "#FFFACD" ); 189 CLR_MAP.put( "LIGHTBLUE" , "#ADD8E6" ); 190 CLR_MAP.put( "LIGHTCORAL" , "#F08080" ); 191 CLR_MAP.put( "LIGHTCYAN" , "#E0FFFF" ); 192 CLR_MAP.put( "LIGHTGOLDENRODYELLOW" , "#FAFAD2" ); 193 CLR_MAP.put( "LIGHTGREEN" , "#90EE90" ); 194 CLR_MAP.put( "LIGHTPINK" , "#FFB6C1" ); 195 CLR_MAP.put( "LIGHTSALMON" , "#FFA07A" ); 196 CLR_MAP.put( "LIGHTSEAGREEN" , "#20B2AA" ); 197 CLR_MAP.put( "LIGHTSKYBLUE" , "#87CEFA" ); 198 CLR_MAP.put( "LIGHTSLATEGRAY" , "#778899" ); 199 CLR_MAP.put( "LIGHTSTEELBLUE" , "#B0C4DE" ); 200 CLR_MAP.put( "LIGHTYELLOW" , "#FFFFE0" ); 201 CLR_MAP.put( "LIMEGREEN" , "#32CD32" ); 202 CLR_MAP.put( "LINEN" , "#FAF0E6" ); 203 CLR_MAP.put( "MEDIUMAQUAMARINE" , "#66CDAA" ); 204 CLR_MAP.put( "MEDIUMBLUE" , "#0000CD" ); 205 CLR_MAP.put( "MEDIUMORCHID" , "#BA55D3" ); 206 CLR_MAP.put( "MEDIUMPURPLE" , "#9370DB" ); 207 CLR_MAP.put( "MEDIUMSEAGREEN" , "#3CB371" ); 208 CLR_MAP.put( "MEDIUMSLATEBLUE" , "#7B68EE" ); 209 CLR_MAP.put( "MEDIUMSPRINGGREEN" , "#00FA9A" ); 210 CLR_MAP.put( "MEDIUMTURQUOISE" , "#48D1CC" ); 211 CLR_MAP.put( "MEDIUMVIOLETRED" , "#C71585" ); 212 CLR_MAP.put( "MIDNIGHTBLUE" , "#191970" ); 213 CLR_MAP.put( "MINTCREAM" , "#F5FFFA" ); 214 CLR_MAP.put( "MISTYROSE" , "#FFE4E1" ); 215 CLR_MAP.put( "MOCCASIN" , "#FFE4B5" ); 216 CLR_MAP.put( "NAVAJOWHITE" , "#FFDEAD" ); 217 CLR_MAP.put( "OLDLACE" , "#FDF5E6" ); 218 CLR_MAP.put( "OLIVEDRAB" , "#6B8E23" ); 219 CLR_MAP.put( "ORANGERED" , "#FF4500" ); 220 CLR_MAP.put( "ORCHID" , "#DA70D6" ); 221 CLR_MAP.put( "PALEGOLDENROD" , "#EEE8AA" ); 222 CLR_MAP.put( "PALEGREEN" , "#98FB98" ); 223 CLR_MAP.put( "PALETURQUOISE" , "#AFEEEE" ); 224 CLR_MAP.put( "PALEVIOLETRED" , "#DB7093" ); 225 CLR_MAP.put( "PAPAYAWHIP" , "#FFEFD5" ); 226 CLR_MAP.put( "PEACHPUFF" , "#FFDAB9" ); 227 CLR_MAP.put( "PERU" , "#CD853F" ); 228 CLR_MAP.put( "PLUM" , "#DDA0DD" ); 229 CLR_MAP.put( "POWDERBLUE" , "#B0E0E6" ); 230 CLR_MAP.put( "ROSYBROWN" , "#BC8F8F" ); 231 CLR_MAP.put( "ROYALBLUE" , "#4169E1" ); 232 CLR_MAP.put( "SADDLEBROWN" , "#8B4513" ); 233 CLR_MAP.put( "SALMON" , "#FA8072" ); 234 CLR_MAP.put( "SANDYBROWN" , "#F4A460" ); 235 CLR_MAP.put( "SEAGREEN" , "#2E8B57" ); 236 CLR_MAP.put( "SEASHELL" , "#FFF5EE" ); 237 CLR_MAP.put( "SIENNA" , "#A0522D" ); 238 CLR_MAP.put( "SKYBLUE" , "#87CEEB" ); 239 CLR_MAP.put( "SLATEBLUE" , "#6A5ACD" ); 240 CLR_MAP.put( "SLATEGRAY" , "#708090" ); 241 CLR_MAP.put( "SNOW" , "#FFFAFA" ); 242 CLR_MAP.put( "SPRINGGREEN" , "#00FF7F" ); 243 CLR_MAP.put( "STEELBLUE" , "#4682B4" ); 244 CLR_MAP.put( "TAN" , "#D2B48C" ); 245 CLR_MAP.put( "THISTLE" , "#D8BFD8" ); 246 CLR_MAP.put( "TOMATO" , "#FF6347" ); 247 CLR_MAP.put( "TURQUOISE" , "#40E0D0" ); 248 CLR_MAP.put( "VIOLET" , "#EE82EE" ); 249 CLR_MAP.put( "WHEAT" , "#F5DEB3" ); 250 CLR_MAP.put( "WHITESMOKE" , "#F5F5F5" ); 251 CLR_MAP.put( "YELLOWGREEN" , "#9ACD32" ); 252 253// // 6.4.4.1 (2016/03/18) 数字に対応する 254// for( int i=0; i<CLR_ARY.length; i++ ) { 255// CLR_MAP.put( String.valueOf( i ) ,CLR_ARY[i] ); // 0:BLUE , 1:CYAN , 2:GRAY ・・・ を、Mapに登録しておきます。 256// } 257 258// // 6.9.9.2 (2018/09/18) 数字に対応する(配列からリストに変更の対応) 259// for( int i=0; i<CLR_LIST.size(); i++ ) { 260// CLR_MAP.put( String.valueOf( i ) ,CLR_LIST.get(i) ); // 0:BLUE , 1:CYAN , 2:GRAY ・・・ を、Mapに登録しておきます。 261// } 262 263 // 7.0.1.1 (2018/10/22) 色番号も、Mapに登録しておきます。 264 // ビビッドを、0~11 (V0~V11) , パステルを、11~23 (P0~P11) とします。 265 int cno = 0; 266 for( int i=0; i<VIVID_KEY.length; i++ ) { 267 CLR_MAP.put( String.valueOf( cno++ ) , VIVID_KEY[i] ); // 0~11 268 CLR_MAP.put( "V" + i , VIVID_KEY[i] ); // V0~V11 269 } 270 271 for( int i=0; i<PSTL_KEY.length; i++ ) { 272 CLR_MAP.put( String.valueOf( cno++ ) , PSTL_KEY[i] ); // 11~23 273 CLR_MAP.put( "P" + i , PSTL_KEY[i] ); // P0~P11 274 } 275 276 // 7.0.1.3 (2018/11/12) VIVIDとPASTELというキーワードに、V0とP0を割り当てておきます。 277 CLR_MAP.put( VIVID , VIVID_KEY[0] ); // V0 278 CLR_MAP.put( PASTEL , PSTL_KEY[0] ); // P0 279 } 280 281 /** 282 * デフォルトコンストラクターをprivateにして、 283 * オブジェクトの生成をさせないようにする。 284 * 285 */ 286 private ColorMap() {} 287 288 /** 289 * カラーキーワードより、Colorオブジェクトを作成します。 290 * 291 * 指定文字列は、java.awt.Color クラスのstatic フィールド名で指定します。 292 * BLACK , BLUE , CYAN , DARK_GRAY , GRAY , GREEN , LIGHT_GRAY , 293 * MAGENTA , ORANGE , PINK , RED , WHITE , YELLOW , PURPLE , TRANSPARENT(透明) が指定できます。 294 * 295 * 6.0.2.1 (2014/09/26) 以降では、CSS1/HTML3–4/VGA の色名称として、 296 * LIME , AQUA , SILVER , MAROON , OLIVE , TEAL , NAVY , FUCHSIA を追加。 297 * それと、X11の色名称 を追加しました。 298 * 299 * また、先頭に、# を付ける事で、#XXXXXX形式の16bitRGB表記 でも指定可能です。 300 * static フィールド名のMapを管理していますが、存在しない場合は、エラーになります。 301 * 302 * 色番号は、ビビッドを、0~11 (V0~V11) , パステルを、11~23 (P0~P11) とします。 303 * 304 * @og.rev 3.8.9.1 (2007/06/29) 新規作成 305 * @og.rev 4.1.1.0 (2008/02/04) CLR_MAP に存在しない場合はエラーにします。 306 * @og.rev 6.0.2.1 (2014/09/26) CSS1/HTML3–4/VGA の色名称 , X11の色名称 追加 307 * @og.rev 6.3.9.0 (2015/11/06) valueのnullチェックの仕方が間違っていた。 308 * @og.rev 6.4.6.1 (2016/06/03) 色番号の取得も対応しておきます。 309 * @og.rev 7.0.1.1 (2018/10/22) ビビッドとパステルの全24色を対象とします。 310 * @og.rev 7.0.6.4 (2019/11/29) 数値指定の色がMapにないとエラーになっていた個所を修正 311 * 312 * @param value java.awt.Color フィールドを示す文字列または、#XXXXXX形式の16bitRGB表記 313 * 314 * @return Colorオブジェクト 315 * @see java.awt.Color#BLACK 316 */ 317 public static Color getColorInstance( final String value ) { 318 // 6.3.9.0 (2015/11/06) valueのnullチェックの仕方が間違っていた。 319 if( value == null || value.length() == 0 ) { 320 final String errMsg = "色コードが指定されていません。" + CR // 6.4.6.1 (2016/06/03) 321 + "ColorMap=" + CLR_MAP.keySet().toString(); 322 throw new OgRuntimeException( errMsg ); 323 } 324 325 // 色コードの番号(#XXXXXX) Mapになければエラー 326 final String colCode ; 327 if( value.charAt(0) == '#' ) { 328 colCode = value; 329 } 330 else { 331 final String val = value.replaceAll( "_" , "" ).toUpperCase(Locale.JAPAN); 332 colCode = CLR_MAP.get( val ); 333 334 if( colCode == null ) { 335 // 7.0.6.4 (2019/11/29) 数値指定の色がMapにないとエラーになっていた個所を修正 336 try { 337 return getColorInstance( Integer.parseInt( val ) ); 338 } 339 catch( final NumberFormatException ex ) { // 数字ではない value をパースしているので、この、Exception は伝播不要。 340 final String errMsg = "指定の色コードはカラーマップに存在しません。 Color=[" + value + "]" + CR 341 + "ColorMap=" + CLR_MAP.keySet().toString(); 342 throw new OgRuntimeException( errMsg,ex ); 343 } 344 } 345 } 346 347 try { 348 return Color.decode( colCode ); 349 } 350 catch( final NumberFormatException ex ) { // 10進、8進、および16進の整数値に変換できない場合 351 final String errMsg = "指定の色コードのフォーマットが異なります(#XXXXXX形式の16bitRGB表記) Color=[" + value + "]" ; 352 throw new OgRuntimeException( errMsg,ex ); 353 } 354 355// Color clr = null ; // 6.4.6.1 (2016/06/03) 色番号で、再設定しているため、final をはずす。 356// 357// if( value.charAt(0) == '#' ) { 358// try { 359// clr = Color.decode( value ); 360// } 361// catch( final NumberFormatException ex ) { // 10進、8進、および16進の整数値に変換できない場合 362// final String errMsg = "指定の色コードのフォーマットが異なります Color=[" + value + "]" + CR 363// + "ColorMap=" + CLR_MAP.keySet().toString(); 364// throw new OgRuntimeException( errMsg,ex ); 365// } 366// } 367// else { 368// // "_"を削除するのは、LIGHT_GRAY などの表記を統一するため。 369// final String val = value.replaceAll( "_" , "" ).toUpperCase(Locale.JAPAN); 370// clr = CLR_MAP.get( val ); 371// if( clr == null ) { 372// // 6.4.6.1 (2016/06/03) 色番号の取得も対応しておきます。 373// // 0 ~ 10 は登録済みなので、それ以降の数字の繰り返しが出来ない 374// try { 375// clr = getColorInstance( Integer.parseInt( value ) ); 376// } 377// catch( final NumberFormatException ex ) { // 数字ではない value をパースしているので、この、Exception は伝播不要。 378// final String errMsg = "指定の色コードは使用できません Color=[" + value + "]" + CR 379// + "ColorMap=" + CLR_MAP.keySet().toString(); 380// throw new OgRuntimeException( errMsg,ex ); 381// } 382// } 383// } 384// return clr; 385 } 386 387 /** 388 * 指定の番号に対応した、色オブジェクトを返します。 389 * 390 * カラー番号は、ビビッドを、0~11 , パステルを、12~23 として登録しています。 391 * 従来のカラー番号と異なりますので、ご注意ください。 392 * 393 * 23を超えると、0 に戻ります。 394 * 395 * @og.rev 6.4.3.3 (2016/03/04) ViewForm_ImageTimeBar#uniqColor() メソッドから移動。 396 * @og.rev 6.9.9.2 (2018/09/18) 配列からリストに変更の対応 397 * @og.rev 7.0.1.1 (2018/10/22) ビビッドとパステルの全24色を対象とします。 398 * 399 * @param no 内部で管理している色番号 400 * @return 色オブジェクト 401 */ 402 public static Color getColorInstance( final int no ) { 403 try { 404 return Color.decode( COLOR_KEY[no % COLOR_KEY.length] ); 405 } 406 catch( final NumberFormatException ex ) { 407 final String errMsg = "指定の色番号の内部フォーマットがエラーです。no=[" + no + "] , code=[" + COLOR_KEY[no % COLOR_KEY.length] + "]" ; 408 throw new OgRuntimeException( errMsg,ex ); 409 } 410 } 411 412 /** 413 * 内部で管理している ColorMap のキー配列を返します。 414 * 415 * ここで返すのは、ビビッドを、0~11 , パステルを、12~23 として登録しています。 416 * この、#XXXXXX形式の16bitRGB表記 を返します。 417 * 418 * @og.rev 6.0.2.1 (2014/09/26) 新規追加 419 * @og.rev 7.0.1.1 (2018/10/22) ビビッドとパステルの全24色を対象とします。 420 * 421 * @param no 内部で管理している色番号 422 * @return キー配列 423 * @og.rtnNotNull 424 */ 425 public static String getColorKey( final int no ) { 426 return COLOR_KEY[no % COLOR_KEY.length]; 427 } 428 429 /** 430 * 内部で管理している ColorMap から、指定のキーに対する色コードを返します。 431 * 432 * 色名称でも返しますが、主に、色番号を想定しています。 433 * 引数が、文字列なのは、ビビッドを、0~11 (V0~V11) , パステルを、12~23 (P0~P11) 434 * として管理しているためです。 435 * 436 * 色コードは、、#XXXXXX形式の16bitRGB表記です。 437 * 色マップに値が存在しない場合は、null を返します。 438 * 439 * @og.rev 7.0.1.1 (2018/10/22) ビビッドとパステルの全24色を対象とします。 440 * 441 * @param sno 内部で管理している色番号 442 * @return 色コード(対象の色がMapに存在しない場合は、nullを返します) 443 */ 444 public static String getColorKey( final String sno ) { 445// return CLR_MAP.get( sno ); 446 return getColorKey( sno , null ); 447 } 448 449 /** 450 * 内部で管理している ColorMap から、指定のキーに対する色コードを返します。 451 * 452 * 色名称でも返しますが、主に、色番号を想定しています。 453 * 引数が、文字列なのは、ビビッドを、0~11 (V0~V11) , パステルを、12~23 (P0~P11) 454 * として管理しているためです。 455 * 456 * 色コードは、、#XXXXXX形式の16bitRGB表記です。 457 * 458 * @og.rev 7.0.1.1 (2018/10/22) ビビッドとパステルの全24色を対象とします。 459 * 460 * @param sno 内部で管理している色番号,色記号 461 * @param defCol 色マップに値が存在しない場合に返す色 462 * @return 色コード 463 */ 464 public static String getColorKey( final String sno , final String defCol ) { 465 return CLR_MAP.getOrDefault( sno , defCol ); 466 } 467 468 /** 469 * 内部で管理している ColorMap のキー配列を返します。 470 * 471 * ここで返すのは、ビビッドを、0~11 , パステルを、12~23 として登録しています。 472 * この、#XXXXXX形式の16bitRGB表記 を返します。 473 * 474 * @og.rev 6.0.2.1 (2014/09/26) 新規追加 475 * @og.rev 7.0.1.1 (2018/10/22) ビビッドとパステルの全24色を対象とします。 476 * 477 * @return キー配列 478 * @og.rtnNotNull 479 */ 480 public static String[] getColorKeys() { 481// return CLR_MAP.keySet().toArray( new String[CLR_MAP.size()] ); 482 return COLOR_KEY.clone(); 483 } 484 485 /** 486 * 引数に応じた内部で管理している ColorMap のキー配列を返します。 487 * 488 * colKey が null の場合は、#getColorKeys() と同じ、COLOR_KEYすべてを返します。 489 * colKey が、VIVID の場合は、#getVividKeys() を返します。 490 * colKey が、PASTEL の場合は、#getPastelKeys() を返します。 491 * それ以外は、CSVで分解して、各値を、#getColorKey(String,String) で求めた色コードの 492 * 配列を返します。 493 * 494 * @og.rev 7.0.1.3 (2018/11/12) 引数に応じたColorMap のキー配列を返す。 495 * 496 * @param colKey 内部で管理している色コード(nullの場合は、COLOR_KEYすべて。) 497 * @return キー配列 498 * @og.rtnNotNull 499 */ 500 public static String[] getColorKeys( final String colKey ) { 501 final String[] rtnCols ; 502 503 if( colKey == null || colKey.isEmpty() ) { rtnCols = getColorKeys(); } 504 else if( VIVID.equalsIgnoreCase( colKey ) ) { rtnCols = getVividKeys(); } 505 else if( PASTEL.equalsIgnoreCase( colKey ) ) { rtnCols = getPastelKeys(); } 506 else { 507 rtnCols = StringUtil.csv2Array( colKey ); 508 for( int i=0; i<rtnCols.length; i++ ) { 509 rtnCols[i] = getColorKey( rtnCols[i] , rtnCols[i] ); 510 } 511 } 512 513 return rtnCols ; 514 } 515 516// /** 517// * 指定の番号に対応した、ビビッドカラーの色オブジェクトを返します。 518// * 519// * #getColorInstance(int) とほぼ同じ機能で、返すのは、パステルカラーの色オブジェクトです。 520// * https://www.colordic.org/v/ 521// * 522// * 12色のビビッドカラーを、指定の番号に応じて、返します。 523// * 隣接する色は、できるだけ離れるようにしています。 524// * 525// * @og.rev 7.0.1.1 (2018/10/22) ビビッドとパステルの全24色を対象とします。 526// * @og.rev 7.0.1.3 (2018/11/12) 廃止 527// * 528// * @param no 内部で管理している色番号 529// * @return ビビッドカラーの色コード 530// */ 531// public static String getVividKey( final int no ) { 532// return VIVID_KEY[no % VIVID_KEY.length]; 533// } 534 535 /** 536 * 内部で管理している ビビッドカラー のキー配列を返します。 537 * 538 * @og.rev 7.0.1.1 (2018/10/22) ビビッドとパステルの全24色を対象とします。 539 * 540 * @return パステルカラーのキー配列 541 */ 542 public static String[] getVividKeys() { 543 return VIVID_KEY.clone(); 544 } 545 546// /** 547// * 指定の番号に対応した、パステルカラーの色オブジェクトを返します。 548// * 549// * #getColorInstance(int) とほぼ同じ機能で、返すのは、パステルカラーの色オブジェクトです。 550// * https://www.colordic.org/p/ 551// * 552// * 12色のパステルカラーを、指定の番号に応じて、返します。 553// * 隣接する色は、できるだけ離れるようにしています。 554// * 555// * @og.rev 6.9.9.2 (2018/09/18) パステルカラーの色オブジェクト 556// * @og.rev 7.0.1.3 (2018/11/12) 廃止 557// * 558// * @param no 内部で管理している色番号 559// * @return パステルカラーの色コード 560// */ 561// public static String getPastelKey( final int no ) { 562// return PSTL_KEY[no % PSTL_KEY.length]; 563// } 564 565 /** 566 * 内部で管理している パステルカラー のキー配列を返します。 567 * 568 * @og.rev 6.9.9.2 (2018/09/18) パステルカラーの色オブジェクト 569 * 570 * @return パステルカラーのキー配列 571 */ 572 public static String[] getPastelKeys() { 573 return PSTL_KEY.clone(); 574 } 575}