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}