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}