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 */
016 package org.opengion.hayabusa.io;
017
018 import org.opengion.fukurou.util.StringUtil;
019 import org.opengion.hayabusa.common.HybsSystem;
020 import org.opengion.hayabusa.common.HybsSystemException;
021 import org.opengion.hayabusa.db.DBTableModel;
022
023 import java.util.List;
024 import java.util.ArrayList;
025 import java.util.Arrays;
026 import java.awt.Color;
027 import java.sql.Connection;
028 import java.sql.SQLException;
029 import java.text.NumberFormat;
030 import java.text.DecimalFormat; // 5.5.2.1 (2012/05/07)
031 import java.text.DecimalFormatSymbols; // 5.5.2.1 (2012/05/07)
032 import java.text.FieldPosition; // 5.5.2.1 (2012/05/07)
033
034 import org.jfree.data.general.Dataset;
035 import org.jfree.data.general.DefaultValueDataset;
036 import org.jfree.chart.plot.ValueMarker;
037 import org.jfree.chart.axis.NumberAxis;
038 import org.jfree.chart.axis.NumberTickUnit;
039 import org.jfree.chart.renderer.category.CategoryItemRenderer;
040 import org.jfree.chart.renderer.category.BarRenderer;
041 import org.jfree.chart.renderer.category.LineAndShapeRenderer;
042 import org.jfree.chart.labels.CategoryItemLabelGenerator;
043 import org.jfree.chart.labels.StandardCategoryItemLabelGenerator;
044 import org.jfree.chart.urls.CategoryURLGenerator;
045 import org.jfree.ui.RectangleInsets;
046 import org.jfree.ui.TextAnchor;
047
048 /**
049 * ChartDataset は、Dataset および、JFreeChart の個別属?を管?て???タ管?ラスです?
050 * JFreeChart のグラフ合成機?のための、?別のグラフ描画属?を管?て?す?
051 * ??、引数の???JFreeChart の?ブジェクトへの変換なども行って?す?
052 *
053 * @version 0.9.0 2007/06/21
054 * @author Kazuhiko Hasegawa
055 * @since JDK1.1,
056 */
057 public class ChartDataset {
058
059 private Dataset dataset = null; // Dataset オブジェク?
060 private String query = null; // 実行クエリー
061 private String chartType = null; // チャート?種?
062 private boolean baseLegend = true; // シリーズ単位?凡?の表示可否
063 private String valueLabel = null;
064 private double[] markValues = null; // doubleの配?
065 private Color[] markColors = new Color[] { Color.RED }; // Colorの配?
066 private Color[] markOverColors = null; // 4.0.3.0 (2008/01/07) マ?カーラインの?色
067 private boolean useMarkAnchor = true; // 4.1.1.0 (2008/02/04) 設定?をラベル表示するかど?
068 private int dynamicOCNo = -1; // 4.1.1.0 (2008/02/04) 動的なマ?カーラインの基準シリーズ番号
069 private int dynamicOCadrs = -1; // 4.1.1.0 (2008/02/21) 動的なマ?カーラインの基準番号
070 private String lowerBound = null; // double
071 private String upperBound = null; // double
072 private String tickSize = null; // double 4.0.3.0 (2008/01/07)
073 private boolean useGradient = false;
074 private boolean shapesVisible = true;
075 private Color[] shapeColors = null; // 4.0.3.0 (2008/01/07) ??タ毎にShapeを?り替える時?色??
076 private String shapeScale = null; // 4.1.1.0 (2008/02/04) 基本形 Shape の表示倍率(double)
077 private boolean useDottedLine = false;
078 private Color[] seriesColors = null; // シリーズに対応した色??
079 private boolean isLabelsVisible = true; // 4.0.2.0 (2007/12/20) (縦軸)のラベルを表示するかど?
080 private boolean isMarksVisible = true; // 4.0.2.0 (2007/12/20) (縦軸)のマ?カーを表示するかど?
081 private boolean isItemValVisible= false; // 4.1.1.0 (2008/02/04) ??タの値(itemText)を表示するかど?
082 private boolean isItemLastVisible= false; // 4.1.2.0 (2008/03/12) ??タの値(itemText)で??み表示するかど?
083 private boolean useItemLabelSep = true; // 4.1.2.0 (2008/03/12) ??タの値(itemText)の表示に桁区??を使用するかど?
084 private String barWidth = null; // 4.0.3.0 (2008/01/07) バ??double)
085 private String maxBarWidth = null; // 4.0.2.0 (2007/12/20) バ????値(0.0??.0)
086 // private double chartOffset = 0.0; // 4.1.1.0 (2008/02/04) グラフ?書き?し位置(double)
087 private String itemMargin = null; // 4.0.2.0 (2007/12/20) バ?アイ?のマ?ジン(0.0??.0)
088 private String visibleLimit = null; // 4.0.3.0 (2008/01/07) 表示下限値(これ以下???タは未表示)
089 private String valueInset = null; // 4.0.3.0 (2008/01/07) 縦軸表示領域INSET値
090 private double domainMargin = 0.0; // 4.1.1.0 (2008/02/14) グラフ?書き?し位置の調整比率
091
092 private String timeFormatType = null; // 5.5.2.1 (2012/05/07) 時刻の表示方?E1/E2/E3/H1/H2/H3)
093 private boolean useVerticalLabels = false; // 5.5.2.1 (2012/05/07) ラベルの表示向き(横書?false/縦書?true)
094
095 /**
096 * Connection と query ??から、Dataset オブジェクトを作?します?
097 *
098 * setChartType( String ) で?されたチャートタイプに応じて、Datasetオブジェク?
099 * を構築します?
100 * Dataset クラスは?org.jfree.data.jdbc.JDBCXXXXDataset" の XXXX の??
101 * ChartFactory クラスのチャートタイプ変換表に基づ?求めます?
102 * 現状は、Category , Pie , XY の?種類と、Value が指定可能です?
103 * ※ Value は、conn ?sql を使用して?せん。?は、markValues を使用して?す?
104 * これは、現状の暫定方法であり、今後?変わる可能性があります?
105 *
106 * @og.rev 4.0.0.0 (2007/11/28) new Double(double) ?Double.valueOf(double) 変更
107 *
108 * @param conn Datasetの取得?のコネクション
109 * @param sql 取得するクエリー??
110 * @throws SQLException ??タベ?ス実行エラーが発生した??
111 */
112 public void makeDataset( final Connection conn,final String sql ) throws SQLException {
113 dataset = ChartFactory.newDataset( conn,sql,chartType );
114 query = sql ;
115
116 // 暫定的対応?本当?、SQL を実行してそ?値をセ?すべ?
117 if( dataset instanceof DefaultValueDataset ) {
118 if( markValues != null && markValues.length > 0 ) {
119 ((DefaultValueDataset)dataset).setValue( Double.valueOf( markValues[0] ) );
120 }
121 else {
122 String errMsg = "markValues が指定されて?せん?;
123 throw new HybsSystemException( errMsg );
124 }
125 }
126 }
127
128 /**
129 * DBTableModelオブジェクトから?Dataset オブジェクトを作?します?
130 *
131 * setChartType( String ) で?されたチャートタイプに応じて、Datasetオブジェク?
132 * を構築します?
133 *
134 * 現状は、Category , Pie , XY の?種類と、Value が指定可能です?
135 * ※ Value は、DBTableModel を使用して?せん。?は、markValues を使用して?す?
136 * これは、現状の暫定方法であり、今後?変わる可能性があります?
137 *
138 * @og.rev 5.3.0.0 (2010/12/01) 新規追?
139 *
140 * @param table Datasetの取得?の??ブルモ?
141 */
142 public void makeDataset( final DBTableModel table ) {
143 dataset = ChartFactory.newDataset( table,chartType );
144
145 // 暫定的対応?本当?、SQL を実行してそ?値をセ?すべ?
146 if( dataset instanceof DefaultValueDataset ) {
147 if( markValues != null && markValues.length > 0 ) {
148 ((DefaultValueDataset)dataset).setValue( Double.valueOf( markValues[0] ) );
149 }
150 else {
151 String errMsg = "markValues が指定されて?せん?;
152 throw new HybsSystemException( errMsg );
153 }
154 }
155 }
156
157 /**
158 * NumberAxis オブジェクトを作?します?
159 *
160 * NumberAxis オブジェクト?、Value(縦軸)の属?を設定する為に使用され?
161 * オブジェクトです?
162 * これに、各種属?を設定して、?を返します?
163 * 属?としては、isLineVisible、isLabelsVisible、isMarksVisible?
164 * range(lowerBound、upperBound) です?
165 *
166 * @og.rev 4.0.2.0 (2007/12/20) 新規追?
167 * @og.rev 4.0.3.0 (2008/01/07) 縦軸レンジを?別設定?チック??
168 * @og.rev 4.1.1.0 (2008/02/04) HybsNumberAxis 採用
169 * @og.rev 4.1.1.0 (2008/02/04) setAxisLineVisible を?isMarksVisible 値で設定する?
170 * @og.rev 5.5.2.1 (2012/05/07) timeFormatType 、useVerticalLabels 属?を追?る?
171 *
172 * @return 縦軸の属?(NumberAxisオブジェク?
173 */
174 protected NumberAxis makeNumberAxis() {
175 NumberAxis axis = new HybsNumberAxis( valueLabel );
176
177 // 縦軸レンジ??軸設?
178 if( lowerBound != null ) {
179 axis.setLowerBound( Double.parseDouble( lowerBound ) );
180 }
181
182 if( upperBound != null ) {
183 axis.setUpperBound( Double.parseDouble( upperBound ) );
184 }
185
186 if( tickSize != null ) {
187 axis.setTickUnit( new NumberTickUnit( Double.parseDouble( tickSize ) ) );
188 }
189
190 axis.setTickLabelsVisible( isLabelsVisible );
191 axis.setTickMarksVisible ( isMarksVisible );
192 axis.setAxisLineVisible ( isMarksVisible ); // 4.1.1.0 (2008/02/04)
193
194 if( valueInset != null ) {
195 double rightInset = Double.parseDouble( valueInset );
196 RectangleInsets base = axis.getTickLabelInsets();
197 RectangleInsets inset = new RectangleInsets(
198 base.getUnitType(), // UnitType unitType
199 base.getTop(), // double top
200 base.getLeft(), // double left
201 base.getBottom(), // double bottom
202 base.getRight() + rightInset // double right
203 );
204 axis.setTickLabelInsets( inset ) ;
205 }
206
207 // 5.5.2.1 (2012/05/07) 時刻の表示方?E1/E2/E3/H1/H2/H3)
208 if( timeFormatType != null ) {
209 axis.setNumberFormatOverride( new HybsTimeFormat( timeFormatType ) );
210 }
211
212 // 5.5.2.1 (2012/05/07) ラベルの表示向き(横書?false/縦書?true)
213 if( useVerticalLabels ) {
214 axis.setVerticalTickLabels( true ); // 処?には冗長?
215 }
216
217 return axis;
218 }
219
220 /**
221 * 検索を行う クエリー??を返します?
222 *
223 * これは、makeDataset( Connection ,String ) メソ?で?した?
224 * sql 属?の設定?そ?も?です?
225 *
226 * @return 取得するクエリー??
227 */
228 public String getQuery() { return query; }
229
230 /**
231 * Dataset オブジェクトを取得します?
232 *
233 * makeDataset( Connection,String ) で、予めオブジェクトを構築しておく
234 * ?があります?
235 * Dataset クラスは?org.jfree.data.jdbc.JDBCXXXXDataset" の XXXX の??
236 * ChartFactory クラスのチャートタイプ変換表に基づ?求めます?
237 * 現状は、Category , Pie , XY の?種類と、Value が指定可能です?
238 *
239 * @return Datasetオブジェク?
240 * @see #makeDataset( Connection ,String )
241 */
242 protected Dataset getDataset() { return dataset; }
243
244 /**
245 * Dataset オブジェクトを作?する時?チャートタイプを?します?
246 *
247 * チャートタイ?は、外部からチャートを?する?に便利なように、キー?
248 * されて?す?こ?キーに基づ?、ChartFactory クラスの
249 * チャートタイプ変換表に基づ?、レン?ー????タセ?を作?します?
250 *
251 * @param type チャートタイ?
252 */
253 public void setChartType( final String type ) {
254 if( type != null && type.length() > 0 ) {
255 chartType = type;
256 }
257 }
258
259 /**
260 * Dataset オブジェクトを作?する時?チャートタイプを取得します?
261 *
262 * チャートタイ?は、外部からチャートを?する?に便利なように、キー?
263 * されて?す?こ?キーに基づ?、ChartFactory クラスの
264 * チャートタイプ変換表に基づ?、レン?ー????タセ?を作?します?
265 *
266 * @return チャートタイ?
267 */
268 protected String getChartType() { return chartType; }
269
270 /**
271 * シリーズ単位?凡?の表示可否を設定します?
272 *
273 * @param baseLeg シリーズ単位?凡?の表示可否
274 */
275 public void setBaseLegend( final boolean baseLeg ) {
276 baseLegend = baseLeg;
277 }
278
279 /**
280 * Renderer 関連の共通インターフェースを返します?
281 *
282 * setChartType( String )で設定された、チャートタイプに応じた?レン?ー?
283 * 返します?
284 * 対応表は、ChartFactory クラスに持って?す?
285 * 基本?は、チャートタイ?は、この、レン?ー名称から決定して?す?
286 *
287 * @og.rev 4.1.1.0 (2008/02/04) useDynamicOC , isItemValVisible , shapeScale 属?追?
288 * @og.rev 4.1.1.0 (2008/02/04) クリ?ブル・マップ?設定を移動?serNo 引数追?
289 * @og.rev 4.1.1.0 (2008/02/04) 返す型を CategoryItemRenderer に変更
290 * @og.rev 4.1.1.0 (2008/02/16) HybsStackedBarRenderer に domainMargin を設?
291 * @og.rev 4.1.1.0 (2008/02/19) Shapes の設定をこちらに移動?
292 * @og.rev 4.1.2.0 (2008/03/12) isItemLastVisible の設?
293 *
294 * @param serNo シリアルNo
295 * @param urlGen CategoryURLGeneratorオブジェク?
296 *
297 * @return レン?ーの共通インターフェース
298 * @see org.jfree.chart.renderer.category.CategoryItemRenderer
299 * @see org.jfree.chart.renderer.xy.XYItemRenderer
300 */
301 protected CategoryItemRenderer getRenderer( final int serNo , final CategoryURLGenerator urlGen ) {
302 TypeRenderer typeRen = ChartFactory.getTypeRenderer( chartType );
303 CategoryItemRenderer rend = (CategoryItemRenderer)typeRen.getRenderer();
304
305 // 4.1.1.0 (2008/02/19) LineAndShapeRenderer オブジェクト?場合?設?
306 if( rend instanceof LineAndShapeRenderer ) {
307 LineAndShapeRenderer lsRend = (LineAndShapeRenderer)rend;
308
309 // シェー?四?表示。serNo ??表示は、?別に行います?
310 lsRend.setBaseShapesVisible( shapesVisible );
311 if( serNo >= 0 ) {
312 lsRend.setSeriesShapesVisible( serNo,true );
313 }
314
315 // 4.1.1.0 (2008/02/04) 繰返しshapeの開始番号(初期値:??
316 ShapeList shapeList = new ShapeList();
317 for( int i=0; i<shapeList.size(); i++ ) {
318 lsRend.setSeriesShape( i,shapeList.getShape(i) );
319 }
320 }
321
322 // 4.0.3.0 (2008/01/07) HybsLineRenderer 特別処?
323 if( rend instanceof HybsLineRenderer ) {
324 HybsLineRenderer hyRend = (HybsLineRenderer)rend ;
325 if( shapeColors != null ) {
326 hyRend.setShapeColors( shapeColors );
327 }
328
329 // 4.1.1.0 (2008/02/04) shapeの大きさの倍率(初期値:null)
330 hyRend.setShapeScale( shapeScale );
331
332 // 縦軸マ?カーの?時Shape色??未使用時? null)
333 if( markOverColors != null ) {
334 hyRend.setValueMarkOverColors( getValueMarkOverColors(),dynamicOCNo );
335 }
336
337 // 表示下限値(これ以下???タは未表示)の値(double)を指?
338 if( visibleLimit != null ) {
339 hyRend.setVisibleLimit( Double.valueOf( visibleLimit ) );
340 }
341 }
342
343 // 4.0.2.0 (2007/12/20) BarRenderer オブジェクト?場合にマ?ジン等を設定します?
344 if( rend instanceof BarRenderer ) {
345 BarRenderer barRend = (BarRenderer)rend ;
346
347 // 棒?間を表示領域を1として小数点以下?数値で?設定す?0.0??.0)
348 if( itemMargin != null ) {
349 double margin = Double.parseDouble( itemMargin );
350 barRend.setItemMargin( margin ) ;
351 }
352
353 // 棒??設定す?示領域を1として小数点以下?数値で?設定す?0.0??.0)
354 if( maxBarWidth != null ) {
355 barRend.setMaximumBarWidth( Double.parseDouble( maxBarWidth ) ) ;
356 }
357 }
358
359 // 4.1.1.0 (2008/02/16) HybsStackedBarRenderer オブジェクト?場合に domainMargin を設定します?
360 if( rend instanceof HybsStackedBarRenderer ) {
361 HybsStackedBarRenderer stBarRend = (HybsStackedBarRenderer)rend ;
362
363 stBarRend.setDomainMargin( domainMargin ) ;
364 }
365
366 // シリーズ単位?凡?の表示可否
367 rend.setBaseSeriesVisibleInLegend( baseLegend );
368
369 // 4.1.1.0 (2008/02/04) ??タの値(itemText)を表示するかど?
370 if( isItemValVisible ) {
371 // CategoryItemLabelGenerator labelGen = new StandardCategoryItemLabelGenerator();
372
373 // 4.1.2.0 (2008/03/12) 桁区??を使用するかど?
374 NumberFormat numForm = NumberFormat.getInstance();
375 numForm.setGroupingUsed( useItemLabelSep );
376
377 CategoryItemLabelGenerator labelGen
378 = new StandardCategoryItemLabelGenerator(
379 StandardCategoryItemLabelGenerator.DEFAULT_LABEL_FORMAT_STRING,
380 numForm
381 );
382 rend.setBaseItemLabelGenerator( labelGen );
383
384 if( serNo >= 0 ) {
385 rend.setSeriesItemLabelsVisible( serNo,true );
386 }
387 else {
388 rend.setBaseItemLabelsVisible( true );
389 }
390 // 4.1.1.0 (2008/02/04) 動的なマ?カーラインを使用する場合?
391 // ??番号は閾値なので、表示しません?
392 if( dynamicOCNo >= 0 ) {
393 rend.setSeriesItemLabelsVisible( dynamicOCNo,false ); // 閾値
394 }
395
396 // 4.1.2.0 (2008/03/12) isItemLastVisible の設?
397 if( isItemLastVisible && rend instanceof HybsDrawItem ) {
398 ((HybsDrawItem)rend).setItemLabelLastVisible( true ) ;
399 }
400 }
401
402 // クリ?ブル・マッ?
403 if( urlGen != null ) {
404 if( serNo >= 0 ) {
405 rend.setSeriesItemURLGenerator( serNo,urlGen );
406 }
407 else {
408 rend.setBaseItemURLGenerator( urlGen );
409 }
410 }
411
412 return rend;
413 }
414
415 /**
416 * 縦軸の表示名称を指定します?
417 *
418 * @param valLbl 縦軸の表示名称
419 */
420 public void setValueLabel( final String valLbl ) {
421 if( valLbl != null && valLbl.length() > 0 ) {
422 valueLabel = valLbl;
423 }
424 }
425
426 /**
427 * 縦軸の表示名称を取得します?
428 *
429 * @return 縦軸の表示名称
430 */
431 protected String getValueLabel() { return valueLabel; }
432
433 /**
434 * マ?カーラインの設定?配?を指定します?
435 *
436 * ??値にマ?カーラインを引きます?
437 * 色は、setMarkColor( String ) で?します?
438 * markColors と、あわせて設定する?があります?
439 * markColorsが??されて???合?、Color.RED で マ?カーされます?
440 * dynamicOCNo を使用する場合?、そのValues の並びの?に?
441 * "G" と???を設定して下さ??
442 * 例?000,G 基準1??000の直線?基準2?、グラ?と?意味?
443 *
444 * @og.rev 4.1.1.0 (2008/02/21) 基準ラインにグラフを使用する場合?位置??
445 *
446 * @param mkVal マ?カーラインの設定?配?
447 * @see #setMarkColors( String[] )
448 */
449 public void setMarkValues( final String[] mkVal ) {
450 if( mkVal != null && mkVal.length > 0 ) {
451 int size = mkVal.length;
452 markValues = new double[size];
453 for( int i=0; i<size; i++ ) {
454 if( "G".equals( mkVal[i] ) ) {
455 dynamicOCadrs = i;
456 markValues[i] = 0.0;
457 }
458 else {
459 markValues[i] = Double.parseDouble( mkVal[i] );
460 }
461 }
462 }
463 }
464
465 /**
466 * マ?カーラインの色を?列指定します?
467 *
468 * マ?カーラインとは、縦軸設定?ラインの事で、縦軸の設定?(markValues)に
469 * 横方向にラインを付与します?こ?ラインの色を?カンマ区?形式で
470 * ?します?
471 * markValues と、あわせて設定する?があります?
472 * 個数が異なる?合?、markValues が優先され?無??場合?、Color.REDで
473 * 表示されます?
474 *
475 * <pre>
476 * BLACK , BLUE , CYAN , DARK_GRAY , GRAY , GREEN , LIGHT_GRAY ,
477 * MAGENTA , ORANGE , PINK , RED , WHITE , YELLOW , (PURPLE)
478 * #XXXXXX形式?16bitRGB表?でも指定可能です?
479 * </pre>
480 *
481 * @param mkCol マ?カーラインの色配?
482 * @see java.awt.Color#BLACK
483 * @see #setMarkValues( String[] )
484 */
485 public void setMarkColors( final String[] mkCol ) {
486 if( mkCol != null && mkCol.length > 0 ) {
487 int size = mkCol.length;
488 markColors = new Color[size];
489 for( int i=0; i<size; i++ ) {
490 markColors[i] = StringUtil.getColorInstance( mkCol[i] );
491 }
492 }
493 }
494
495 /**
496 * マ?カーライン描画時に、その設定?を表示します?
497 *
498 * マ?カーラインの縦軸の設定?(markValues)に、設定?をラベル表示します?
499 * 位置は、TextAnchor.BASELINE_LEFT 固定です?
500 * 初期値は、表示する(true)です?
501 *
502 * @og.rev 4.1.1.0 (2008/02/04) 新規追?
503 *
504 * @param useAnchor true:設定?を表示する?
505 */
506 public void setUseMarkAnchor( final boolean useAnchor ) {
507 useMarkAnchor = useAnchor ;
508 }
509
510 /**
511 * マ?カーラインの?時?Shape色をカンマ区?形式で??します?
512 *
513 * HybsLine でのみ使用可能です?
514 * マ?カーラインを使用する場合に、そのラインを?な?、?る色を指定します?
515 * こ?色の??、?ーカーラインの色??ーカーラインの設定?の個数?1に
516 * なります?つまり?色?:設定??:色?:設定??:色??となります?
517 * 色??、設定??より小さ??合に使用され、色??、設定??より大きく?
518 * 設定??より小さ??合?色??、設定??より大きい場合になります?
519 *
520 * ?文字?は、java.awt.Color クラスのstatic フィールド名で?します?
521 * BLACK , BLUE , CYAN , DARK_GRAY , GRAY , GREEN , LIGHT_GRAY ,
522 * MAGENTA , ORANGE , PINK , RED , WHITE , YELLOW , (PURPLE) が指定できます?
523 * また?#XXXXXX形式?16bitRGB表?でも指定可能です?
524 * markValues と、あわせて設定する?があります?
525 * どちらかが??されて???合?、?ーカー表示されません?
526 * <pre>
527 * BLACK , BLUE , CYAN , DARK_GRAY , GRAY , GREEN , LIGHT_GRAY ,
528 * MAGENTA , ORANGE , PINK , RED , WHITE , YELLOW , (PURPLE)
529 * #XXXXXX形式?16bitRGB表?でも指定可能です?
530 * </pre>
531 *
532 * @og.rev 4.0.3.0 (2008/01/07) 新規追?
533 *
534 * @param ovCol マ?カーラインの?時?Shape色
535 * @see java.awt.Color#BLACK
536 */
537 public void setMarkOverColors( final String[] ovCol ) {
538 if( ovCol != null && ovCol.length > 0 ) {
539 int size = ovCol.length;
540 markOverColors = new Color[size];
541 for( int i=0; i<size; i++ ) {
542 markOverColors[i] = StringUtil.getColorInstance( ovCol[i] );
543 }
544 }
545 }
546
547 /**
548 * マ?カーラインの?時?Shape色を規定するオブジェクトを返します?
549 *
550 * HybsLine でのみ使用可能です?
551 * 設定情報が存在しな??合?、null を返します?
552 *
553 * @og.rev 4.0.3.0 (2008/01/07) 新規追?
554 * @og.rev 4.1.1.0 (2008/02/04) markColors 属?追?
555 * @og.rev 4.1.1.1 (2008/02/25) markValues での "G" ?を??
556 *
557 * @return マ?カーラインの?時?Shape色管?ブジェク?
558 */
559 private ValueMarkOverColors getValueMarkOverColors() {
560 ValueMarkOverColors vmoc = null;
561
562 if( markValues != null && markOverColors != null &&
563 markValues.length + 1 == markOverColors.length &&
564 markValues.length >= 1 ) {
565 int dynAdrs = (dynamicOCadrs >= 0) ? dynamicOCadrs : 0 ;
566
567 vmoc = new ValueMarkOverColors(
568 markValues,
569 markOverColors,
570 markColors[dynAdrs],
571 dynamicOCadrs
572 );
573 }
574
575 return vmoc ;
576 }
577
578 /**
579 * 動的なマ?カーラインの基準シリーズ番号を設定しま?初期値:-1)?
580 *
581 * 動的なマ?カーラインを使用する場合?、基準?となるシリーズ番号を指定します?
582 *
583 * マ?カーラインの?位閾値に相当します?これは、グラフ化されますが?
584 * Shape は自動的に削除されます?
585 * こ?設定を使用する場合???の??タには、?Shapeが付きます?それ以外?
586 * ??タに、Shape を付けるかど?は、shapesVisible 属?で?します?
587 * こ?線?色は、markColors で?した??位?色になります?また?
588 * markValues で?した??位?値は、使用されません。た?、色??
589 * 関係上?設定しておく?があります?
590 * また?isValueVisible == true で、設定?の値表示を行う場合も、最下位?
591 * 値は表示しな??します?
592 * 初期値は、使用しな?-1)です?
593 *
594 * @og.rev 4.1.1.0 (2008/02/04) 新規追?
595 * @og.rev 4.1.1.0 (2008/02/19) setUseDynamicOC ?setDynamicOCNo
596 *
597 * @param ocNo 動的なマ?カーラインの基準シリーズ番号
598 */
599 public void setDynamicOCNo( final int ocNo ) {
600 dynamicOCNo = ocNo;
601 }
602
603 /**
604 * マ?カーラインの ValueMarker オブジェクト?列を返します?
605 *
606 * マ?カーライン は、markValues(double配?) と markColors(Color配?)
607 * より、ValueMarker オブジェクトを??次配?化して?ます?
608 * useMarkAnchor == true の場合?、設定?(markValues) の Anchor ?
609 * 表示します?位置は、TextAnchor.BASELINE_LEFT 固定です?
610 * dynamicOCNo が指定された場合?、最下位?閾値は使用しません?
611 *
612 * @og.rev 4.1.1.0 (2008/02/04) useMarkAnchor 属?追?
613 * @og.rev 4.1.1.0 (2008/02/04) 動的なオーバ?カラー useDynamicOC 属?追?
614 *
615 * @return マ?カーラインのオブジェクト??not null)
616 * @see java.awt.Color#BLACK
617 * @see #setMarkValues( String[] )
618 * @see #setMarkColors( String[] )
619 * @see #setUseMarkAnchor( boolean )
620 */
621 protected ValueMarker[] getValueMarkers() {
622 List<ValueMarker> markerList = new ArrayList<ValueMarker>();
623 int size = (markValues == null) ? 0 : markValues.length;
624 for( int i=0; i<size; i++ ) {
625 if( i != dynamicOCadrs ) {
626 ValueMarker marker = new ValueMarker( markValues[i] );
627 marker.setPaint( markColors[i] );
628 if( useMarkAnchor ) {
629 marker.setLabel( String.valueOf( markValues[i] ) );
630 marker.setLabelTextAnchor( TextAnchor.BASELINE_LEFT );
631 }
632 markerList.add( marker );
633 }
634 }
635
636 return markerList.toArray( new ValueMarker[markerList.size()] );
637 }
638
639 /**
640 * チャート?縦軸の??をセ?しま?初期値:自動計??
641 *
642 * 何も?しな??合?、データの??から、?動的に計算します?
643 *
644 * @param lowBnd 縦軸の??
645 * @see #setUpperBound( String )
646 */
647 public void setLowerBound( final String lowBnd ) {
648 if( lowBnd != null && lowBnd.length() > 0 ) {
649 lowerBound = lowBnd;
650 }
651 }
652
653 /**
654 * チャート?縦軸の?値をセ?しま?初期値:自動計??
655 *
656 * 何も?しな??合?、データの?値から、?動的に計算します?
657 *
658 * @param upBnd 縦軸の?値
659 * @see #setLowerBound( String )
660 */
661 public void setUpperBound( final String upBnd ) {
662 if( upBnd != null && upBnd.length() > 0 ) {
663 upperBound = upBnd;
664 }
665 }
666
667 /**
668 * チャート?縦軸の目盛??セ?しま?初期値:自動計??
669 *
670 * 何も?しな??合?、データの?から、?動的に計算します?
671 *
672 * @og.rev 4.0.3.0 (2008/01/07) 新規追?
673 *
674 * @param size 縦軸のチック(目?の?
675 */
676 public void setTickSize( final String size ) {
677 if( size != null && size.length() > 0 ) {
678 tickSize = size;
679 }
680 }
681
682 /**
683 * バ?チャート?グラ??ション処?行うかど?[true/false]をセ?しま?初期値:true)?
684 *
685 * 通常のバ?チャート?、単?表示で表されますが、これにグラ??ション効果を
686 * 付加するかど?を指定します?
687 * 通常のバ?チャートが、少しきれ?見えます?
688 * 初期値は、true(グラ??ション効果を付与す?です?
689 *
690 * @param useGrad グラ??ション処?[true:する/false:しない]
691 */
692 public void setUseGradient( final boolean useGrad ) {
693 useGradient = useGrad;
694 }
695
696 /**
697 * バ?チャート?グラ??ション処?行うかど?を取得します?
698 *
699 * 通常のバ?チャート?、単?表示で表されますが、これにグラ??ション効果を
700 * 付加するかど?を指定します?
701 * 通常のバ?チャートが、少しきれ?見えます?
702 * 初期値は、false(使用しな?です?
703 *
704 * @return グラ??ション処?する:true/しな?false)
705 * @see #setUseGradient( boolean )
706 */
707 protected boolean isUseGradient() { return useGradient; }
708
709 /**
710 * ラインチャート?ポイントを四角表示するかど?を指定しま?初期値:false)?
711 *
712 * ラインチャート???常、線?で表され、各ポイントにつ?も?線?で接続されます?
713 * shapesVisible ?true に設定すると、各ポイントが、線上に四角く表示され?
714 * そ?ポイント?位置を?容易に判断出来るよ?なります?
715 * 初期値は、?ーカーを?れません?
716 *
717 * @param shVisible ポイントを四角表示するかど?
718 */
719 public void setShapesVisible( final boolean shVisible ) {
720 shapesVisible = shVisible;
721 }
722
723 /**
724 * ラインチャート?ポイントを四角表示するかど?を取得します?
725 *
726 * ラインチャート???常、線?で表され、各ポイントにつ?も?線?で接続されます?
727 * shapesVisible ?true に設定すると、各ポイントが、線上に四角く表示され?
728 * そ?ポイント?位置を?容易に判断出来るよ?なります?
729 * 初期値は、?ーカーを?れません?
730 *
731 * @return ポイントを四角表示するかど?
732 * @see #setShapesVisible( boolean )
733 */
734 protected boolean isShapesVisible() { return shapesVisible; }
735
736 /**
737 * ??タ毎にShapeを?り替える時?色の繰返しパターンを文字?配?で?します?
738 *
739 * HybsLine でのみ使用可能です?
740 * これは、データそ?も?が?繰返し性のある場合に、その繰返し性に対応し?
741 * 形状のShape を表示させる?合に使用します?
742 * 繰返しShapeの形状は、JFreeChart のシリーズ毎?繰返し標準形状を使用します?
743 * 現在のバ?ジョンでは?0?までの繰返しに対応可能です?
744 * 繰返し色を??した????に使用されて?ます?
745 *
746 * ?文字?は、java.awt.Color クラスのstatic フィールド名で?します?
747 * BLACK , BLUE , CYAN , DARK_GRAY , GRAY , GREEN , LIGHT_GRAY ,
748 * MAGENTA , ORANGE , PINK , RED , WHITE , YELLOW , (PURPLE) が指定できます?
749 * また?#XXXXXX形式?16bitRGB表?でも指定可能です?
750 *
751 * @og.rev 4.0.3.0 (2008/01/07) 新規追?
752 *
753 * @param colors ??タ毎?色の繰返しパターン(??配?)
754 * @see java.awt.Color#BLACK
755 */
756 public void setShapeColors( final String[] colors ) {
757 if( colors != null && colors.length > 0 ) {
758 int size = colors.length;
759 shapeColors = new Color[size];
760 for( int i=0; i<size; i++ ) {
761 shapeColors[i] = StringUtil.getColorInstance( colors[i] );
762 }
763 }
764 }
765
766 /**
767 * shapeの大きさを??定で変更しま?初期値:null)?
768 *
769 * ラインチャート?Shape(?ラフ?ポイント?マ?カー)の大きさは??常は?
770 * 自動設定されます?
771 * こ?大きさを?倍率?で、変更可能です?
772 * ??、double 型です?
773 * 初期値は、null は、スケール変更しません(自動設定?ままの大きさ)
774 *
775 * @og.rev 4.1.1.0 (2008/02/04) 新規追?
776 *
777 * @param scale shapeの大きさの倍率
778 */
779 public void setShapeScale( final String scale ) {
780 shapeScale = scale;
781 }
782
783 /**
784 * ラインチャート?線をドットラインにするかど?を指定しま?初期値:false)?
785 *
786 * ラインチャート???常、線?で表されます?
787 * これに、点線で表すことで、グラフ?違いを?色?でなく形状でも識別
788 * しやすくすることが可能です?
789 * 初期値は、線?です?
790 *
791 * @param useDotLine ドットラインにするかど?
792 */
793 public void setUseDottedLine( final boolean useDotLine ) {
794 useDottedLine = useDotLine;
795 }
796
797 /**
798 * ラインチャート?線をドットラインにするかど?を取得します?
799 *
800 * ラインチャート???常、線?で表されます?
801 * これに、点線で表すことで、グラフ?違いを?色?でなく形状でも識別
802 * しやすくすることが可能です?
803 * 初期値は、線?です?
804 *
805 * @return ドットラインにするかど?
806 * @see #setUseDottedLine( boolean )
807 */
808 protected boolean isUseDottedLine() { return useDottedLine; }
809
810 /**
811 * ?チャート描画時?チャート色の繰返しパターンを文字?配?で?します?
812 *
813 * 通常、?のチャートを同時に表示させる?合?、縦軸が?通であれば?
814 * ?回のSelect????タを取得します?
815 * こ?、データをシリーズと呼んでおり、これを区別する為に、色を?けます?
816 * 初期値は、JFreeChart が?動で割り振ります?
817 * これを?外部からCVS形式で、カンマ区?で色コードを?します?
818 * ?データが多い場合?、多い??色は使用されません。少な??合??
819 * ?に繰り返して使用されます?
820 * 例えば?色??した?合?、すべてのシリーズが同じ色で表されます?
821 *
822 * ?文字?は、java.awt.Color クラスのstatic フィールド名で?します?
823 * BLACK , BLUE , CYAN , DARK_GRAY , GRAY , GREEN , LIGHT_GRAY ,
824 * MAGENTA , ORANGE , PINK , RED , WHITE , YELLOW , (PURPLE) が指定できます?
825 * また?#XXXXXX形式?16bitRGB表?でも指定可能です?
826 *
827 * @param colors チャート色の繰返しパターン(??配?)
828 * @see java.awt.Color#BLACK
829 */
830 public void setSeriesColors( final String[] colors ) {
831 if( colors != null && colors.length > 0 ) {
832 int size = colors.length;
833 seriesColors = new Color[size];
834 for( int i=0; i<size; i++ ) {
835 seriesColors[i] = StringUtil.getColorInstance( colors[i] );
836 }
837 }
838 }
839
840 /**
841 * ?チャート描画時?チャート色の繰返しパターンをColor配?で?します?
842 *
843 * @return チャート色の繰返しパターン(Color配?)
844 * @see #setSeriesColors( String[] )
845 */
846 protected Color[] getSeriesColors() {
847 return seriesColors ;
848 }
849
850 /**
851 * Value(縦軸)のラベルを表示するかど?を指定しま?初期値:true[表示する])?
852 *
853 * ValueAxis にて設定される、縦軸??の、ラベルを表示するかど??します?
854 * 初期値は、true(表示する)です?
855 *
856 * @og.rev 4.0.2.0 (2007/12/20) 新規追?
857 *
858 * @param labelsVisible Value(縦軸)のラベルを表示するかど?
859 */
860 public void setValueLabelsVisible( final boolean labelsVisible ) {
861 isLabelsVisible = labelsVisible;
862 }
863
864 /**
865 * Value(縦軸)のマ?カーを表示するかど?を指定しま?初期値:true[表示する])?
866 *
867 * ValueAxis にて設定される、縦軸??の、?ーカーを表示するかど??します?
868 * 初期値は、true(表示する)です?
869 *
870 * @og.rev 4.0.2.0 (2007/12/20) 新規追?
871 *
872 * @param marksVisible Value(縦軸)のマ?カーを表示するかど?
873 */
874 public void setValueMarksVisible( final boolean marksVisible ) {
875 isMarksVisible = marksVisible;
876 }
877
878 /**
879 * ??タの値(itemText)を表示するかど?[true/false/last]を指定しま?初期値:false[表示しない])?
880 *
881 * CategoryItemRenderer 関連のグラフ?設定?をグラフ上に表示するかど??
882 * ?します?
883 * true に設定した?合?通常の場合?、すべてのシリーズにラベル表示されます?
884 * false に設定すると、表示されません?
885 * last を設定すると、各シリーズの??値のみ表示されます?
886 * ChartCreate クラスに、seriesPikup が設定されて?場合?、指定?シリーズ
887 * のみの設定?を表示し?他?値は、表示しません?
888 * 同様に、dynamicOCNo が指定されて?場?動的なマ?カーライン)
889 * ??シリーズは?値として使用されるため?設定?は表示されません?
890 * ラベルの表示位置は、表示する線グラフ?傾きに応じてラベルの表示場?
891 * 変えます?山形、右坂?谷形、左?に応じて、上中、下右、下中、上右 に
892 * 位置を設定します?右にずらす?は?0 ピクセル固定です?
893 * 初期値は、false(表示しな?です?
894 *
895 * @og.rev 4.1.1.0 (2008/02/04) 新規追?
896 * @og.rev 4.1.2.0 (2008/03/12) ??のまま、受け取りるように変更
897 *
898 * @param visible ??タの値の表示のさせ方 [true/false/last]
899 * @see ChartCreate#setSeriesPikup( int )
900 */
901 public void setItemLabelVisible( final String visible ) {
902 if( "true".equalsIgnoreCase( visible ) ) {
903 isItemValVisible = true;
904 }
905 else if( "last".equalsIgnoreCase( visible ) ) {
906 isItemValVisible = true;
907 isItemLastVisible = true;
908 }
909 else if( visible != null && !"false".equalsIgnoreCase( visible ) ) {
910 String errMsg = "itemLabelVisible は、?true,false,last」から指定してください?"
911 + visible + "]";
912 throw new HybsSystemException( errMsg );
913 }
914 }
915
916 /**
917 * ??タの値(itemText)の表示に桁区??を使用するかど?を指定します?
918 *
919 * itemLabelVisible=true 時に、表示されるデータ値ラベルで?
920 * NumberFormat して?すが?桁区???123,456,789.0) の
921 * 区?記号を表示するかど?を指定します?
922 * true を指定すると、表示します?false では、表示しません?
923 * 初期値は、true(使用する)です?
924 *
925 * @og.rev 4.1.2.0 (2008/03/12) 新規追?
926 *
927 * @param used 桁区??を使用するかど?
928 */
929 public void setUseItemLabelSep( final boolean used ) {
930 useItemLabelSep = used;
931 }
932
933 /**
934 * 縦軸の表示領域INSET値(double)を指定します?
935 *
936 * 縦軸?表示領域(NumberAxis)の??追??を設定します?
937 * これは??常の表示領域の左側にスペ?スを挿入します?
938 * あくまで、追?る?なので、文字?長さ?含まれません?
939 * 何も?しな??合?、設定しません?
940 *
941 * @og.rev 4.0.3.0 (2008/01/07) 新規追?
942 *
943 * @param inset Value(縦軸)の表示領域INSET値
944 */
945 public void setValueInset( final String inset ) {
946 valueInset = inset;
947 }
948
949 /**
950 * BOXチャート?バ??double)を指定します?
951 *
952 * BOXチャート?バ??double)を指定します?
953 * 設定されるのは、org.jfree.chart.renderer.category.BarRenderer ?
954 * 使用した描画のみです?
955 * 棒グラフ?バ??定?、直接、CategoryItemRendererState に設定して?す?
956 * 通常は、barMaxWidth(0.0??.0)とbarItemMargin(0.0??.0)を用?比率で?します?
957 * 何も?しな??合?、設定しません?
958 *
959 * @og.rev 4.0.3.0 (2008/01/07) 新規追?
960 *
961 * @param width BOXチャート?バ??double)
962 */
963 public void setBarWidth( final String width ) {
964 barWidth = width;
965 }
966
967 /**
968 * BOXチャート?バ??double)を取得します?
969 *
970 * 設定されるのは、org.jfree.chart.renderer.category.BarRenderer ?
971 * 使用した描画のみです?
972 * 棒グラフ?バ??定?、直接、CategoryItemRendererState に設定して?す?
973 * 通常は、barMaxWidth(0.0??.0)とbarItemMargin(0.0??.0)を用?比率で?します?
974 * 何も?しな??合?、設定しません?
975 *
976 * @og.rev 4.0.3.0 (2008/01/07) 新規追?
977 *
978 * @return BOXチャート?バ??double)の??
979 */
980 protected String getBarWidth() {
981 return barWidth ;
982 }
983
984 /**
985 * BOXチャート?バ????値(0.0??.0)を指定します?
986 *
987 * BOXチャート?バ???比率の?値を指定します?
988 * 表示領域を1として小数点以下?数値で棒??設定します?
989 * 設定した?無?ある時?適当なサイズに調整されます?
990 * (小さくしたときには棒が線?ようにな?
991 * 設定されるのは、org.jfree.chart.renderer.category.BarRenderer ?
992 * 使用した描画のみです?
993 * 何も?しな??合?、設定しません?
994 *
995 * @og.rev 4.0.2.0 (2007/12/20) 新規追?
996 *
997 * @param barWidth BOXチャート?バ????値(0.0??.0)
998 */
999 public void setBarMaxWidth( final String barWidth ) {
1000 maxBarWidth = barWidth;
1001 }
1002
1003 /**
1004 * BOXチャート?バ?アイ?のマ?ジン(0.0??.0)を指定します?
1005 *
1006 * BOXチャート?バ?アイ?のマ?ジンの比率を指定します?
1007 * 棒?間を表示領域を1として小数点以下?数値で?設定します?
1008 * 無?ある時?適当なサイズに調整されます?
1009 * barMaxWidth より優先されます?
1010 * 設定されるのは、org.jfree.chart.renderer.category.BarRenderer ?
1011 * 使用した描画のみです?
1012 * 何も?しな??合?、設定しません?
1013 *
1014 * @og.rev 4.0.2.0 (2007/12/20) 新規追?
1015 *
1016 * @param margin BOXチャート?バ?アイ?のマ?ジン(0.0??.0)
1017 */
1018 public void setBarItemMargin( final String margin ) {
1019 itemMargin = margin;
1020 }
1021
1022 /**
1023 * 表示下限値(これ以下???タは未表示)の値(double)を指定します?
1024 *
1025 * HybsLine でのみ使用可能です?
1026 * こ?設定?以下???タは、存在しな??します?
1027 * Lineを引くとき?こ???タと、存在して???タ間にラインは引かれません?
1028 * 何も?しな??合?、設定しません?
1029 *
1030 * @og.rev 4.0.3.0 (2008/01/07) 新規追?
1031 *
1032 * @param limit 表示下限値(これ以下???タは未表示)
1033 */
1034 public void setVisibleLimit( final String limit ) {
1035 visibleLimit = limit;
1036 }
1037
1038 /**
1039 * グラフ?書き?し位置の調整比率を指定します?
1040 *
1041 * グラフを描画する場合?、書き?し位置を少しずらします?
1042 * これは、グラフ??対して、比率で?します?
1043 * 0.0(初期値)の場合?、?期描画位置である、CategoryAnchor.Middle と
1044 * 同じ?から、書き?されます?
1045 * 1.0 の場合?中?ら?グラフ??半?が加算され?END位置に?ます?
1046 * 同様に?1.0 の場合?、グラフ??半?が減算され?START 位置になります?
1047 * つまり?中?ら?グラフ??半?単位で、前方/後方にずらす事が出来ます?
1048 * 書き?し位置 ??中?Middle) + (domainMargin)????
1049 * 初期値は?.0(真ん中:MIDDLE)です?
1050 *
1051 * @og.rev 4.1.1.0 (2008/02/14) 新規追?
1052 *
1053 * @param margin グラフ?書き?し位置の調整比率
1054 */
1055 public void setDomainMargin( final double margin ) {
1056 domainMargin = margin;
1057 }
1058
1059 /**
1060 * 時刻を表す?合?表現の仕方を指定しま?初期値:null)?
1061 *
1062 * HybsNumberAxis にオーバ?ライドす?時間を表示する DecimalFormat の?クラスを利用するに当たり?
1063 * 時刻の表示方法を?します?
1064 * 外部から与える数字???続して??があるため?0?数です?
1065 * たとえ??700 ?17:00 , 2150 ?21:30 と?感じです?
1066 * 2400 を?ると日付違?なります?
1067 *
1068 * 英語表?:)と日本語表??の区別と?4時間を?る?合?表示方法によって?種類?パターンが存在します?
1069 * ?1:そ?まま?4:00 となり??されて??
1070 * ?2:そ?まま?:00 に戻る?(日付?無?
1071 * ?3:そ?まま? 00:00 と日付が付与される?
1072 * ?1:そ?まま?4?0?となり??されて??
1073 * ?2:そ?まま?0?0?に戻る?(日付?無?
1074 * ?3:そ?まま?日 00?0?と日付が付与される?
1075 * 初期値は、使用しな?-1)です?
1076 *
1077 * @og.rev 5.5.2.1 (2012/05/07) 新規追?
1078 *
1079 * @param type 時刻の表示方?[E1/E2/E3/H1/H2/H3]
1080 */
1081 public void setTimeFormatType( final String type ) {
1082 timeFormatType = type;
1083 }
1084
1085 /**
1086 * ラベルの表示向きを縦にするかど?[true/false]を指定しま?初期値:false)?
1087 *
1088 * ChartCreate の rotationLabel は、角度を指定できましたが?NumberAxis では?
1089 * 縦にするかど?の?しかできません?
1090 * ここでは、true を指定するとラベルは、縦書きになります?
1091 * 初期値は、false(横書?です?
1092 *
1093 * @og.rev 5.5.2.1 (2012/05/07) 新規追?
1094 *
1095 * @param useVLavels ラベルの表示向き [false:横書?:true:縦書き]
1096 */
1097 public void setUseVerticalLabels( final boolean useVLavels ) {
1098 useVerticalLabels = useVLavels;
1099 }
1100
1101 /**
1102 * HybsNumberAxis にオーバ?ライドす?時間を表示する DecimalFormat の?クラスを定義します?
1103 *
1104 * これは、ChartPlot_XY で使用する、HybsNumberAxis に対して、拡張します?
1105 * ??タが?時刻を表す?合?Date型?オブジェクトを利用して、org.jfree.chart.axis.PeriodAxis
1106 * を利用できればよいのですが、単なる数字で扱って?ケースがあり?時刻に??
1107 * 変換するケースで使?す?
1108 * 外部から与える数字???続して??があるため?0?数です?
1109 * たとえ??700 ?17:00 , 2150 ?21:30 と?感じです?
1110 * 24時間を?る?合??
1111 * Type1:そ?まま?:00 に戻る?
1112 * Type2:そ?まま?4:00 と、そのまま、加算されて??
1113 * の?種類が用意されて?す?
1114 *
1115 * @og.rev 5.5.2.1 (2012/05/07) 新規追?
1116 *
1117 */
1118 private static final class HybsTimeFormat extends DecimalFormat {
1119 /** For serialization. */
1120 private static final long serialVersionUID = 201205075512L;
1121
1122 private final boolean is24repeat ;
1123 private final boolean useDay ;
1124
1125 private final int hsCode ;
1126
1127 /**
1128 * コンストラクター
1129 *
1130 * 引数に、時刻を表す?合?表現の仕方を指定します?
1131 * ?1:そ?まま?4:00 となり??されて??
1132 * ?2:そ?まま?:00 に戻る?(日付?無?
1133 * ?3:そ?まま? 00:00 と日付が付与される?
1134 * ?1:そ?まま?4?0?となり??されて??
1135 * ?2:そ?まま?0?0?に戻る?(日付?無?
1136 * ?3:そ?まま?日 00?0?と日付が付与される?
1137 *
1138 * @param type 時刻の表示方?[E1/E2/E3/H1/H2/H3]
1139 */
1140 public HybsTimeFormat( final String inType ) {
1141 super();
1142
1143 DecimalFormatSymbols sym = new DecimalFormatSymbols();
1144 if( "E1".equals( inType ) ) {
1145 applyPattern( "#0.00" );
1146 sym.setDecimalSeparator( ':' );
1147 is24repeat = false; useDay = false;
1148 }
1149 else if( "E2".equals( inType ) ) {
1150 applyPattern( "#0.00" );
1151 sym.setDecimalSeparator( ':' );
1152 is24repeat = true; useDay = false;
1153 }
1154 else if( "E3".equals( inType ) ) {
1155 applyPattern( "#,#0.00" );
1156 sym.setDecimalSeparator( ':' );
1157 sym.setGroupingSeparator( ' ' );
1158 is24repeat = true; useDay = true;
1159 }
1160 else if( "H1".equals( inType ) ) {
1161 applyPattern( "#0.00? );
1162 sym.setDecimalSeparator( '? );
1163 is24repeat = false; useDay = false;
1164 }
1165 else if( "H2".equals( inType ) ) {
1166 applyPattern( "#0.00? );
1167 sym.setDecimalSeparator( '? );
1168 is24repeat = true; useDay = false;
1169 }
1170 else if( "H3".equals( inType ) ) {
1171 applyPattern( "#,#0.00? );
1172 sym.setDecimalSeparator( '? );
1173 sym.setGroupingSeparator( '日' );
1174 is24repeat = true; useDay = true;
1175 }
1176 else {
1177 String errMsg = "timeFormatType は?E1/E2/E3/H1/H2/H3) から?してください。timeFormatType=[" + inType + "]" ;
1178 throw new HybsSystemException( errMsg );
1179 }
1180 setDecimalFormatSymbols( sym );
1181
1182 hsCode = super.hashCode() + Boolean.valueOf(is24repeat).hashCode() + Boolean.valueOf(useDay).hashCode();
1183 }
1184
1185 /**
1186 * double をフォーマットして??を作?しま? format(double,StringBuffer,FieldPosition) のオーバ?ライ?)
1187 *
1188 * timeFormatType によって、データの処?変わります?
1189 * ?1:そ?まま?4:00 となり??されて??
1190 * ?2:そ?まま?:00 に戻る?(日付?無?
1191 * ?3:そ?まま? 00:00 と日付が付与される?
1192 * ?1:そ?まま?4?0?となり??されて??
1193 * ?2:そ?まま?0?0?に戻る?(日付?無?
1194 * ?3:そ?まま?日 00?0?と日付が付与される?
1195 *
1196 * @param number フォーマットす?double
1197 * @param result ?ストを追?る位置
1198 * @param fieldPos 入力では、?であれば位置合わせフィールド? 出力では、その位置合わせフィールド?オフセ?
1199 * @return フォーマットされた数値??
1200 */
1201 public StringBuffer format( final double number, final StringBuffer result, final FieldPosition fieldPos ) {
1202 int day = (int)(number/100/24); // 日付?端数は?捨てる?
1203 int hour = (int)(number/100); // 時間のみ取り出す?
1204 if( is24repeat ) { hour = hour%24; } // ?4時間を?た?合?余りのみ使用する?
1205
1206 int minute = (int)((number%100)*0.6); // 0.6 = 60/100 の事?100 ?60?となる?
1207
1208 double timeVal = hour + minute/100.0 ;
1209 if( useDay ) { timeVal = timeVal + day*100 ; } // 端数を?り捨てた日付に対して?00倍しておく?
1210 return super.format( timeVal, result, fieldPos );
1211 }
1212
1213 /**
1214 * こ?オブジェクトと?されたオブジェクトを比?ます?
1215 *
1216 * @og.rev 5.5.2.4 (2012/05/16) 新規追?findbug対?
1217 *
1218 * @param anObject 比?れるオブジェク?
1219 * @return ?されたオブジェクトが等し??合? true、そ?な??合? false
1220 */
1221 public boolean equals( final Object anObject ) {
1222 return this == anObject;
1223 }
1224
1225 /**
1226 * こ?オブジェクト?ハッシュコードを取得します?
1227 *
1228 * @og.rev 5.5.2.4 (2012/05/16) 新規追?findbug対?
1229 *
1230 * @return ハッシュコー?
1231 */
1232 public int hashCode() {
1233 return hsCode;
1234 }
1235 }
1236
1237 /**
1238 * こ?オブジェクト???表現を返します?
1239 * 基本???目?使用します?
1240 *
1241 * @return こ?クラスの??表現
1242 */
1243 @Override
1244 public String toString() {
1245 StringBuilder rtn = new StringBuilder( HybsSystem.BUFFER_MIDDLE );
1246
1247 rtn.append( "[" ).append( this.getClass().getName() ).append( "]" ).append( HybsSystem.CR );
1248 rtn.append( "chartType [" ).append( chartType ).append( "]" ).append( HybsSystem.CR );
1249 rtn.append( "valueLabel [" ).append( valueLabel ).append( "]" ).append( HybsSystem.CR );
1250 rtn.append( "markValues [" ).append( Arrays.toString( markValues ) ).append( "]" ).append( HybsSystem.CR );
1251 rtn.append( "markColors [" ).append( Arrays.toString( markColors ) ).append( "]" ).append( HybsSystem.CR );
1252 rtn.append( "lowerBound [" ).append( lowerBound ).append( "]" ).append( HybsSystem.CR );
1253 rtn.append( "upperBound [" ).append( upperBound ).append( "]" ).append( HybsSystem.CR );
1254 rtn.append( "useGradient [" ).append( useGradient ).append( "]" ).append( HybsSystem.CR );
1255 rtn.append( "shapesVisible [" ).append( shapesVisible ).append( "]" ).append( HybsSystem.CR );
1256 rtn.append( "useDottedLine [" ).append( useDottedLine ).append( "]" ).append( HybsSystem.CR );
1257
1258 return rtn.toString();
1259 }
1260 }