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