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