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.data.general.ValueDataset;
037 import org.jfree.chart.plot.ValueMarker;
038 import org.jfree.chart.axis.NumberAxis;
039 import org.jfree.chart.axis.NumberTickUnit;
040 import org.jfree.chart.renderer.category.CategoryItemRenderer;
041 import org.jfree.chart.renderer.category.BarRenderer;
042 import org.jfree.chart.renderer.category.LineAndShapeRenderer;
043 import org.jfree.chart.labels.CategoryItemLabelGenerator;
044 import org.jfree.chart.labels.StandardCategoryItemLabelGenerator;
045 import org.jfree.chart.urls.CategoryURLGenerator;
046 import org.jfree.ui.RectangleInsets;
047 import org.jfree.ui.TextAnchor;
048
049 import org.jfree.chart.plot.MeterPlot; // 5.7.8.0 (2014/07/04)
050 import org.jfree.chart.plot.ThermometerPlot; // 5.7.8.0 (2014/07/04)
051 import org.jfree.chart.plot.CompassPlot; // 5.7.8.0 (2014/07/04)
052 import org.jfree.chart.plot.Plot; // 5.7.8.0 (2014/07/04)
053 import java.awt.BasicStroke; // 5.7.8.0 (2014/07/04)
054 import org.jfree.data.Range; // 5.7.8.0 (2014/07/04)
055 import org.jfree.chart.plot.MeterInterval; // 5.7.8.0 (2014/07/04)
056 import org.jfree.chart.plot.DialShape; // 5.7.8.0 (2014/07/04)
057
058 /**
059 * ChartDataset は、Dataset および、JFreeChart の個別属?を管?て???タ管?ラスです?
060 * JFreeChart のグラフ合成機?のための、?別のグラフ描画属?を管?て?す?
061 * ??、引数の???JFreeChart の?ブジェクトへの変換なども行って?す?
062 *
063 * @version 0.9.0 2007/06/21
064 * @author Kazuhiko Hasegawa
065 * @since JDK1.1,
066 */
067 public class ChartDataset {
068
069 private Dataset dataset = null; // Dataset オブジェク?
070 private String query = null; // 実行クエリー
071 private String chartType = null; // チャート?種?
072 private String needleType = null; // Needleの種?
073 private boolean baseLegend = true; // シリーズ単位?凡?の表示可否
074 private String valueLabel = null;
075 private double[] markValues = null; // doubleの配?
076 private Color[] markColors = new Color[] { Color.RED }; // Colorの配?
077 private Color[] markOverColors = null; // 4.0.3.0 (2008/01/07) マ?カーラインの?色
078 private boolean useMarkAnchor = true; // 4.1.1.0 (2008/02/04) 設定?をラベル表示するかど?
079 private int dynamicOCNo = -1; // 4.1.1.0 (2008/02/04) 動的なマ?カーラインの基準シリーズ番号
080 private int dynamicOCadrs = -1; // 4.1.1.0 (2008/02/21) 動的なマ?カーラインの基準番号
081 private String lowerBound = null; // double
082 private String upperBound = null; // double
083 private String tickSize = null; // double 4.0.3.0 (2008/01/07)
084 private boolean useGradient = false;
085 private boolean shapesVisible = true;
086 private Color[] shapeColors = null; // 4.0.3.0 (2008/01/07) ??タ毎にShapeを?り替える時?色??
087 private String shapeScale = null; // 4.1.1.0 (2008/02/04) 基本形 Shape の表示倍率(double)
088 private boolean useDottedLine = false;
089 private Color[] seriesColors = null; // シリーズに対応した色??
090 private boolean isLabelsVisible = true; // 4.0.2.0 (2007/12/20) (縦軸)のラベルを表示するかど?
091 private boolean isMarksVisible = true; // 4.0.2.0 (2007/12/20) (縦軸)のマ?カーを表示するかど?
092 private boolean isItemValVisible= false; // 4.1.1.0 (2008/02/04) ??タの値(itemText)を表示するかど?
093 private boolean isItemLastVisible= false; // 4.1.2.0 (2008/03/12) ??タの値(itemText)で??み表示するかど?
094 private boolean useItemLabelSep = true; // 4.1.2.0 (2008/03/12) ??タの値(itemText)の表示に桁区??を使用するかど?
095 private String barWidth = null; // 4.0.3.0 (2008/01/07) バ??double)
096 private String maxBarWidth = null; // 4.0.2.0 (2007/12/20) バ????値(0.0??.0)
097 private String itemMargin = null; // 4.0.2.0 (2007/12/20) バ?アイ?のマ?ジン(0.0??.0)
098 private String visibleLimit = null; // 4.0.3.0 (2008/01/07) 表示下限値(これ以下???タは未表示)
099 private String valueInset = null; // 4.0.3.0 (2008/01/07) 縦軸表示領域INSET値
100 private double domainMargin = 0.0; // 4.1.1.0 (2008/02/14) グラフ?書き?し位置の調整比率
101
102 private String timeFormatType = null; // 5.5.2.1 (2012/05/07) 時刻の表示方?E1/E2/E3/H1/H2/H3)
103 private boolean useVerticalLabels = false; // 5.5.2.1 (2012/05/07) ラベルの表示向き(横書?false/縦書?true)
104
105 /**
106 * Connection と query ??から、Dataset オブジェクトを作?します?
107 *
108 * setChartType( String ) で?されたチャートタイプに応じて、Datasetオブジェク?
109 * を構築します?
110 * Dataset クラスは?org.jfree.data.jdbc.JDBCXXXXDataset" の XXXX の??
111 * ChartFactory クラスのチャートタイプ変換表に基づ?求めます?
112 * 現状は、Category , Pie , XY の?種類と、Value が指定可能です?
113 * ※ Value は、conn ?sql を使用して?せん。?は、markValues を使用して?す?
114 * これは、現状の暫定方法であり、今後?変わる可能性があります?
115 *
116 * @og.rev 4.0.0.0 (2007/11/28) new Double(double) ?Double.valueOf(double) 変更
117 *
118 * @param conn Datasetの取得?のコネクション
119 * @param sql 取得するクエリー??
120 * @throws SQLException ??タベ?ス実行エラーが発生した??
121 */
122 public void makeDataset( final Connection conn,final String sql ) throws SQLException {
123 dataset = ChartFactory.newDataset( conn,sql,chartType );
124 query = sql ;
125
126 // 暫定的対応?本当?、SQL を実行してそ?値をセ?すべ?
127 if( dataset instanceof DefaultValueDataset ) {
128 if( markValues != null && markValues.length > 0 ) {
129 ((DefaultValueDataset)dataset).setValue( Double.valueOf( markValues[0] ) );
130 }
131 else {
132 String errMsg = "markValues が指定されて?せん?;
133 throw new HybsSystemException( errMsg );
134 }
135 }
136 }
137
138 /**
139 * DBTableModelオブジェクトから?Dataset オブジェクトを作?します?
140 *
141 * setChartType( String ) で?されたチャートタイプに応じて、Datasetオブジェク?
142 * を構築します?
143 *
144 * 現状は、Category , Pie , XY の?種類と、Value が指定可能です?
145 * ※ Value は、DBTableModel を使用して?せん。?は、markValues を使用して?す?
146 * これは、現状の暫定方法であり、今後?変わる可能性があります?
147 *
148 * @og.rev 5.3.0.0 (2010/12/01) 新規追?
149 *
150 * @param table Datasetの取得?の??ブルモ?
151 */
152 public void makeDataset( final DBTableModel table ) {
153 dataset = ChartFactory.newDataset( table,chartType );
154
155 // 暫定的対応?本当?、SQL を実行してそ?値をセ?すべ?
156 if( dataset instanceof DefaultValueDataset ) {
157 if( markValues != null && markValues.length > 0 ) {
158 ((DefaultValueDataset)dataset).setValue( Double.valueOf( markValues[0] ) );
159 }
160 else {
161 String errMsg = "markValues が指定されて?せん?;
162 throw new HybsSystemException( errMsg );
163 }
164 }
165 }
166
167 /**
168 * NumberAxis オブジェクトを作?します?
169 *
170 * NumberAxis オブジェクト?、Value(縦軸)の属?を設定する為に使用され?
171 * オブジェクトです?
172 * これに、各種属?を設定して、?を返します?
173 * 属?としては、isLineVisible、isLabelsVisible、isMarksVisible?
174 * range(lowerBound、upperBound) です?
175 *
176 * @og.rev 4.0.2.0 (2007/12/20) 新規追?
177 * @og.rev 4.0.3.0 (2008/01/07) 縦軸レンジを?別設定?チック??
178 * @og.rev 4.1.1.0 (2008/02/04) HybsNumberAxis 採用
179 * @og.rev 4.1.1.0 (2008/02/04) setAxisLineVisible を?isMarksVisible 値で設定する?
180 * @og.rev 5.5.2.1 (2012/05/07) timeFormatType 、useVerticalLabels 属?を追?る?
181 * @og.rev 5.8.5.0 (2015/03/06) 縦軸表示の暫定対応?ための修正
182 *
183 * @return 縦軸の属?(NumberAxisオブジェク?
184 */
185 protected NumberAxis makeNumberAxis() {
186 NumberAxis axis = new HybsNumberAxis( valueLabel );
187
188 // 縦軸レンジ??軸設?
189 if( lowerBound != null ) {
190 // axis.setLowerBound( Double.parseDouble( lowerBound ) );
191 final double lower = Double.parseDouble( lowerBound );// 5.8.5.0 (2015/03/06)
192 axis.setLowerBound( lower );
193 }
194
195 if( upperBound != null ) {
196 axis.setUpperBound( Double.parseDouble( upperBound ) );
197 }
198 else { // 5.8.5.0 (2015/03/06)
199 if( dataset instanceof HybsCategoryDataset ) {
200 final Range range = ((HybsCategoryDataset)dataset).getRange();
201 if( range != null ) {
202 final double upper = range.getUpperBound() * 1.1; // UpperBoundの 10% 大き目の値にする?
203 axis.setUpperBound( upper );
204 }
205 }
206 }
207
208 if( tickSize != null ) {
209 axis.setTickUnit( new NumberTickUnit( Double.parseDouble( tickSize ) ) );
210 }
211
212 axis.setTickLabelsVisible( isLabelsVisible );
213 axis.setTickMarksVisible ( isMarksVisible );
214 axis.setAxisLineVisible ( isMarksVisible ); // 4.1.1.0 (2008/02/04)
215
216 if( valueInset != null ) {
217 double rightInset = Double.parseDouble( valueInset );
218 RectangleInsets base = axis.getTickLabelInsets();
219 RectangleInsets inset = new RectangleInsets(
220 base.getUnitType(), // UnitType unitType
221 base.getTop(), // double top
222 base.getLeft(), // double left
223 base.getBottom(), // double bottom
224 base.getRight() + rightInset // double right
225 );
226 axis.setTickLabelInsets( inset ) ;
227 }
228
229 // 5.5.2.1 (2012/05/07) 時刻の表示方?E1/E2/E3/H1/H2/H3)
230 if( timeFormatType != null ) {
231 axis.setNumberFormatOverride( new HybsTimeFormat( timeFormatType ) );
232 }
233
234 // 5.5.2.1 (2012/05/07) ラベルの表示向き(横書?false/縦書?true)
235 if( useVerticalLabels ) {
236 axis.setVerticalTickLabels( true ); // 処?には冗長?
237 }
238
239 return axis;
240 }
241
242 /**
243 * 検索を行う クエリー??を返します?
244 *
245 * これは、makeDataset( Connection ,String ) メソ?で?した?
246 * sql 属?の設定?そ?も?です?
247 *
248 * @return 取得するクエリー??
249 */
250 public String getQuery() { return query; }
251
252 /**
253 * Dataset オブジェクトを取得します?
254 *
255 * makeDataset( Connection,String ) で、予めオブジェクトを構築しておく
256 * ?があります?
257 * Dataset クラスは?org.jfree.data.jdbc.JDBCXXXXDataset" の XXXX の??
258 * ChartFactory クラスのチャートタイプ変換表に基づ?求めます?
259 * 現状は、Category , Pie , XY の?種類と、Value が指定可能です?
260 *
261 * @return Datasetオブジェク?
262 * @see #makeDataset( Connection ,String )
263 */
264 protected Dataset getDataset() { return dataset; }
265
266 /**
267 * Dataset オブジェクトを作?する時?チャートタイプを?します?
268 *
269 * チャートタイ?は、外部からチャートを?する?に便利なように、キー?
270 * されて?す?こ?キーに基づ?、ChartFactory クラスの
271 * チャートタイプ変換表に基づ?、レン?ー????タセ?を作?します?
272 *
273 * @param type チャートタイ?
274 */
275 public void setChartType( final String type ) {
276 if( type != null && type.length() > 0 ) {
277 chartType = type;
278 }
279 }
280
281 /**
282 * Dataset オブジェクトを作?する時?Needleタイプを?します?
283 *
284 * Needleタイ?は、MeterPlot,Compassチャートを使用する場合に?します?
285 *
286 * MeterPlot
287 * org.jfree.chart.plot.DialShape の?キ??ー??として、CHORD,CIRCLE,PIE が指定可能です?
288 * 初期値は、CIRCLE です?
289 *
290 * Compass
291 * org.jfree.chart.needle.MeterNeedle の?キ??ー??として、下記??種類が?可能です?
292 * ??、Arrow,Line,Long,Pin,Plum,Pointer,Ship,Wind,Arrow,MiddlePin と???です?
293 * 初期値は、Pointer です?
294 *
295 * 0 = ArrowNeedle;
296 * 1 = LineNeedle;
297 * 2 = LongNeedle;
298 * 3 = PinNeedle;
299 * 4 = PlumNeedle;
300 * 5 = PointerNeedle;
301 * 6 = ShipNeedle;
302 * 7 = WindNeedle;
303 * 8 = ArrowNeedle;
304 * 9 = MiddlePinNeedle;
305 *
306 * @og.rev 5.7.8.0 (2014/07/04) 新規追?
307 *
308 * @param type Needleタイ?
309 */
310 public void setNeedleType( final String type ) {
311 if( type != null && type.length() > 0 ) {
312 needleType = type;
313 }
314 }
315
316 /**
317 * Dataset オブジェクトを作?する時?チャートタイプを取得します?
318 *
319 * チャートタイ?は、外部からチャートを?する?に便利なように、キー?
320 * されて?す?こ?キーに基づ?、ChartFactory クラスの
321 * チャートタイプ変換表に基づ?、レン?ー????タセ?を作?します?
322 *
323 * @return チャートタイ?
324 */
325 protected String getChartType() { return chartType; }
326
327 /**
328 * シリーズ単位?凡?の表示可否を設定します?
329 *
330 * @param baseLeg シリーズ単位?凡?の表示可否
331 */
332 public void setBaseLegend( final boolean baseLeg ) {
333 baseLegend = baseLeg;
334 }
335
336 /**
337 * Renderer 関連の共通インターフェースを返します?
338 *
339 * setChartType( String )で設定された、チャートタイプに応じた?レン?ー?
340 * 返します?
341 * 対応表は、ChartFactory クラスに持って?す?
342 * 基本?は、チャートタイ?は、この、レン?ー名称から決定して?す?
343 *
344 * @og.rev 4.1.1.0 (2008/02/04) useDynamicOC , isItemValVisible , shapeScale 属?追?
345 * @og.rev 4.1.1.0 (2008/02/04) クリ?ブル・マップ?設定を移動?serNo 引数追?
346 * @og.rev 4.1.1.0 (2008/02/04) 返す型を CategoryItemRenderer に変更
347 * @og.rev 4.1.1.0 (2008/02/16) HybsStackedBarRenderer に domainMargin を設?
348 * @og.rev 4.1.1.0 (2008/02/19) Shapes の設定をこちらに移動?
349 * @og.rev 4.1.2.0 (2008/03/12) isItemLastVisible の設?
350 *
351 * @param serNo シリアルNo
352 * @param urlGen CategoryURLGeneratorオブジェク?
353 *
354 * @return レン?ーの共通インターフェース
355 * @see org.jfree.chart.renderer.category.CategoryItemRenderer
356 * @see org.jfree.chart.renderer.xy.XYItemRenderer
357 */
358 protected CategoryItemRenderer getRenderer( final int serNo , final CategoryURLGenerator urlGen ) {
359 TypeRenderer typeRen = ChartFactory.getTypeRenderer( chartType );
360 CategoryItemRenderer rend = (CategoryItemRenderer)typeRen.getRenderer();
361
362 // 4.1.1.0 (2008/02/19) LineAndShapeRenderer オブジェクト?場合?設?
363 if( rend instanceof LineAndShapeRenderer ) {
364 LineAndShapeRenderer lsRend = (LineAndShapeRenderer)rend;
365
366 // シェー?四?表示。serNo ??表示は、?別に行います?
367 lsRend.setBaseShapesVisible( shapesVisible );
368 if( serNo >= 0 ) {
369 lsRend.setSeriesShapesVisible( serNo,true );
370 }
371
372 // 4.1.1.0 (2008/02/04) 繰返しshapeの開始番号(初期値:??
373 ShapeList shapeList = new ShapeList();
374 for( int i=0; i<shapeList.size(); i++ ) {
375 lsRend.setSeriesShape( i,shapeList.getShape(i) );
376 }
377 }
378
379 // 4.0.3.0 (2008/01/07) HybsLineRenderer 特別処?
380 if( rend instanceof HybsLineRenderer ) {
381 HybsLineRenderer hyRend = (HybsLineRenderer)rend ;
382 if( shapeColors != null ) {
383 hyRend.setShapeColors( shapeColors );
384 }
385
386 // 4.1.1.0 (2008/02/04) shapeの大きさの倍率(初期値:null)
387 hyRend.setShapeScale( shapeScale );
388
389 // 縦軸マ?カーの?時Shape色??未使用時? null)
390 if( markOverColors != null ) {
391 hyRend.setValueMarkOverColors( getValueMarkOverColors(),dynamicOCNo );
392 }
393
394 // 表示下限値(これ以下???タは未表示)の値(double)を指?
395 if( visibleLimit != null ) {
396 hyRend.setVisibleLimit( Double.valueOf( visibleLimit ) );
397 }
398 }
399
400 // 4.0.2.0 (2007/12/20) BarRenderer オブジェクト?場合にマ?ジン等を設定します?
401 if( rend instanceof BarRenderer ) {
402 BarRenderer barRend = (BarRenderer)rend ;
403
404 // 棒?間を表示領域を1として小数点以下?数値で?設定す?0.0??.0)
405 if( itemMargin != null ) {
406 double margin = Double.parseDouble( itemMargin );
407 barRend.setItemMargin( margin ) ;
408 }
409
410 // 棒??設定す?示領域を1として小数点以下?数値で?設定す?0.0??.0)
411 if( maxBarWidth != null ) {
412 barRend.setMaximumBarWidth( Double.parseDouble( maxBarWidth ) ) ;
413 }
414 }
415
416 // 4.1.1.0 (2008/02/16) HybsStackedBarRenderer オブジェクト?場合に domainMargin を設定します?
417 if( rend instanceof HybsStackedBarRenderer ) {
418 HybsStackedBarRenderer stBarRend = (HybsStackedBarRenderer)rend ;
419
420 stBarRend.setDomainMargin( domainMargin ) ;
421 }
422
423 // シリーズ単位?凡?の表示可否
424 rend.setBaseSeriesVisibleInLegend( baseLegend );
425
426 // 4.1.1.0 (2008/02/04) ??タの値(itemText)を表示するかど?
427 if( isItemValVisible ) {
428 // 4.1.2.0 (2008/03/12) 桁区??を使用するかど?
429 NumberFormat numForm = NumberFormat.getInstance();
430 numForm.setGroupingUsed( useItemLabelSep );
431
432 CategoryItemLabelGenerator labelGen
433 = new StandardCategoryItemLabelGenerator(
434 StandardCategoryItemLabelGenerator.DEFAULT_LABEL_FORMAT_STRING,
435 numForm
436 );
437 rend.setBaseItemLabelGenerator( labelGen );
438
439 if( serNo >= 0 ) {
440 rend.setSeriesItemLabelsVisible( serNo,true );
441 }
442 else {
443 rend.setBaseItemLabelsVisible( true );
444 }
445 // 4.1.1.0 (2008/02/04) 動的なマ?カーラインを使用する場合?
446 // ??番号は閾値なので、表示しません?
447 if( dynamicOCNo >= 0 ) {
448 rend.setSeriesItemLabelsVisible( dynamicOCNo,false ); // 閾値
449 }
450
451 // 4.1.2.0 (2008/03/12) isItemLastVisible の設?
452 if( isItemLastVisible && rend instanceof HybsDrawItem ) {
453 ((HybsDrawItem)rend).setItemLabelLastVisible( true ) ;
454 }
455 }
456
457 // クリ?ブル・マッ?
458 if( urlGen != null ) {
459 if( serNo >= 0 ) {
460 rend.setSeriesItemURLGenerator( serNo,urlGen );
461 }
462 else {
463 rend.setBaseItemURLGenerator( urlGen );
464 }
465 }
466
467 return rend;
468 }
469
470 /**
471 * 縦軸の表示名称を指定します?
472 *
473 * @param valLbl 縦軸の表示名称
474 */
475 public void setValueLabel( final String valLbl ) {
476 if( valLbl != null && valLbl.length() > 0 ) {
477 valueLabel = valLbl;
478 }
479 }
480
481 /**
482 * 縦軸の表示名称を取得します?
483 *
484 * @return 縦軸の表示名称
485 */
486 protected String getValueLabel() { return valueLabel; }
487
488 /**
489 * マ?カーラインの設定?配?を指定します?
490 *
491 * ??値にマ?カーラインを引きます?
492 * 色は、setMarkColor( String ) で?します?
493 * markColors と、あわせて設定する?があります?
494 * markColorsが??されて???合?、Color.RED で マ?カーされます?
495 * dynamicOCNo を使用する場合?、そのValues の並びの?に?
496 * "G" と???を設定して下さ??
497 * 例?000,G 基準1??000の直線?基準2?、グラ?と?意味?
498 *
499 * @og.rev 4.1.1.0 (2008/02/21) 基準ラインにグラフを使用する場合?位置??
500 *
501 * @param mkVal マ?カーラインの設定?配?
502 * @see #setMarkColors( String[] )
503 */
504 public void setMarkValues( final String[] mkVal ) {
505 if( mkVal != null && mkVal.length > 0 ) {
506 int size = mkVal.length;
507 markValues = new double[size];
508 for( int i=0; i<size; i++ ) {
509 if( "G".equals( mkVal[i] ) ) {
510 dynamicOCadrs = i;
511 markValues[i] = 0.0;
512 }
513 else {
514 markValues[i] = Double.parseDouble( mkVal[i] );
515 }
516 }
517 }
518 }
519
520 /**
521 * マ?カーラインの色を?列指定します?
522 *
523 * マ?カーラインとは、縦軸設定?ラインの事で、縦軸の設定?(markValues)に
524 * 横方向にラインを付与します?こ?ラインの色を?カンマ区?形式で
525 * ?します?
526 * markValues と、あわせて設定する?があります?
527 * 個数が異なる?合?、markValues が優先され?無??場合?、Color.REDで
528 * 表示されます?
529 *
530 * <pre>
531 * BLACK , BLUE , CYAN , DARK_GRAY , GRAY , GREEN , LIGHT_GRAY ,
532 * MAGENTA , ORANGE , PINK , RED , WHITE , YELLOW , (PURPLE)
533 * #XXXXXX形式?16bitRGB表?でも指定可能です?
534 * </pre>
535 *
536 * @param mkCol マ?カーラインの色配?
537 * @see java.awt.Color#BLACK
538 * @see #setMarkValues( String[] )
539 */
540 public void setMarkColors( final String[] mkCol ) {
541 if( mkCol != null && mkCol.length > 0 ) {
542 int size = mkCol.length;
543 markColors = new Color[size];
544 for( int i=0; i<size; i++ ) {
545 markColors[i] = StringUtil.getColorInstance( mkCol[i] );
546 }
547 }
548 }
549
550 /**
551 * マ?カーライン描画時に、その設定?を表示します?
552 *
553 * マ?カーラインの縦軸の設定?(markValues)に、設定?をラベル表示します?
554 * 位置は、TextAnchor.BASELINE_LEFT 固定です?
555 * 初期値は、表示する(true)です?
556 *
557 * @og.rev 4.1.1.0 (2008/02/04) 新規追?
558 *
559 * @param useAnchor true:設定?を表示する?
560 */
561 public void setUseMarkAnchor( final boolean useAnchor ) {
562 useMarkAnchor = useAnchor ;
563 }
564
565 /**
566 * マ?カーラインの?時?Shape色をカンマ区?形式で??します?
567 *
568 * HybsLine でのみ使用可能です?
569 * マ?カーラインを使用する場合に、そのラインを?な?、?る色を指定します?
570 * こ?色の??、?ーカーラインの色??ーカーラインの設定?の個数?1に
571 * なります?つまり?色?:設定??:色?:設定??:色??となります?
572 * 色??、設定??より小さ??合に使用され、色??、設定??より大きく?
573 * 設定??より小さ??合?色??、設定??より大きい場合になります?
574 *
575 * ?文字?は、java.awt.Color クラスのstatic フィールド名で?します?
576 * BLACK , BLUE , CYAN , DARK_GRAY , GRAY , GREEN , LIGHT_GRAY ,
577 * MAGENTA , ORANGE , PINK , RED , WHITE , YELLOW , (PURPLE) が指定できます?
578 * また?#XXXXXX形式?16bitRGB表?でも指定可能です?
579 * markValues と、あわせて設定する?があります?
580 * どちらかが??されて???合?、?ーカー表示されません?
581 * <pre>
582 * BLACK , BLUE , CYAN , DARK_GRAY , GRAY , GREEN , LIGHT_GRAY ,
583 * MAGENTA , ORANGE , PINK , RED , WHITE , YELLOW , (PURPLE)
584 * #XXXXXX形式?16bitRGB表?でも指定可能です?
585 * </pre>
586 *
587 * @og.rev 4.0.3.0 (2008/01/07) 新規追?
588 *
589 * @param ovCol マ?カーラインの?時?Shape色
590 * @see java.awt.Color#BLACK
591 */
592 public void setMarkOverColors( final String[] ovCol ) {
593 if( ovCol != null && ovCol.length > 0 ) {
594 int size = ovCol.length;
595 markOverColors = new Color[size];
596 for( int i=0; i<size; i++ ) {
597 markOverColors[i] = StringUtil.getColorInstance( ovCol[i] );
598 }
599 }
600 }
601
602 /**
603 * マ?カーラインの?時?Shape色を規定するオブジェクトを返します?
604 *
605 * HybsLine でのみ使用可能です?
606 * 設定情報が存在しな??合?、null を返します?
607 *
608 * @og.rev 4.0.3.0 (2008/01/07) 新規追?
609 * @og.rev 4.1.1.0 (2008/02/04) markColors 属?追?
610 * @og.rev 4.1.1.1 (2008/02/25) markValues での "G" ?を??
611 *
612 * @return マ?カーラインの?時?Shape色管?ブジェク?
613 */
614 private ValueMarkOverColors getValueMarkOverColors() {
615 ValueMarkOverColors vmoc = null;
616
617 if( markValues != null && markOverColors != null &&
618 markValues.length + 1 == markOverColors.length &&
619 markValues.length >= 1 ) {
620 int dynAdrs = (dynamicOCadrs >= 0) ? dynamicOCadrs : 0 ;
621
622 vmoc = new ValueMarkOverColors(
623 markValues,
624 markOverColors,
625 markColors[dynAdrs],
626 dynamicOCadrs
627 );
628 }
629
630 return vmoc ;
631 }
632
633 /**
634 * 動的なマ?カーラインの基準シリーズ番号を設定しま?初期値:-1)?
635 *
636 * 動的なマ?カーラインを使用する場合?、基準?となるシリーズ番号を指定します?
637 *
638 * マ?カーラインの?位閾値に相当します?これは、グラフ化されますが?
639 * Shape は自動的に削除されます?
640 * こ?設定を使用する場合???の??タには、?Shapeが付きます?それ以外?
641 * ??タに、Shape を付けるかど?は、shapesVisible 属?で?します?
642 * こ?線?色は、markColors で?した??位?色になります?また?
643 * markValues で?した??位?値は、使用されません。た?、色??
644 * 関係上?設定しておく?があります?
645 * また?isValueVisible == true で、設定?の値表示を行う場合も、最下位?
646 * 値は表示しな??します?
647 * 初期値は、使用しな?-1)です?
648 *
649 * @og.rev 4.1.1.0 (2008/02/04) 新規追?
650 * @og.rev 4.1.1.0 (2008/02/19) setUseDynamicOC ?setDynamicOCNo
651 *
652 * @param ocNo 動的なマ?カーラインの基準シリーズ番号
653 */
654 public void setDynamicOCNo( final int ocNo ) {
655 dynamicOCNo = ocNo;
656 }
657
658 /**
659 * マ?カーラインの ValueMarker オブジェクト?列を返します?
660 *
661 * マ?カーライン は、markValues(double配?) と markColors(Color配?)
662 * より、ValueMarker オブジェクトを??次配?化して?ます?
663 * useMarkAnchor == true の場合?、設定?(markValues) の Anchor ?
664 * 表示します?位置は、TextAnchor.BASELINE_LEFT 固定です?
665 * dynamicOCNo が指定された場合?、最下位?閾値は使用しません?
666 *
667 * @og.rev 4.1.1.0 (2008/02/04) useMarkAnchor 属?追?
668 * @og.rev 4.1.1.0 (2008/02/04) 動的なオーバ?カラー useDynamicOC 属?追?
669 *
670 * @return マ?カーラインのオブジェクト??not null)
671 * @see java.awt.Color#BLACK
672 * @see #setMarkValues( String[] )
673 * @see #setMarkColors( String[] )
674 * @see #setUseMarkAnchor( boolean )
675 */
676 protected ValueMarker[] getValueMarkers() {
677 List<ValueMarker> markerList = new ArrayList<ValueMarker>();
678 int size = (markValues == null) ? 0 : markValues.length;
679 for( int i=0; i<size; i++ ) {
680 if( i != dynamicOCadrs ) {
681 ValueMarker marker = new ValueMarker( markValues[i] );
682 marker.setPaint( markColors[i] );
683 if( useMarkAnchor ) {
684 marker.setLabel( String.valueOf( markValues[i] ) );
685 marker.setLabelTextAnchor( TextAnchor.BASELINE_LEFT );
686 }
687 markerList.add( marker );
688 }
689 }
690
691 return markerList.toArray( new ValueMarker[markerList.size()] );
692 }
693
694 /**
695 * チャート?縦軸の??をセ?しま?初期値:自動計??
696 *
697 * 何も?しな??合?、データの??から、?動的に計算します?
698 *
699 * @param lowBnd 縦軸の??
700 * @see #setUpperBound( String )
701 */
702 public void setLowerBound( final String lowBnd ) {
703 if( lowBnd != null && lowBnd.length() > 0 ) {
704 lowerBound = lowBnd;
705 }
706 }
707
708 /**
709 * チャート?縦軸の?値をセ?しま?初期値:自動計??
710 *
711 * 何も?しな??合?、データの?値から、?動的に計算します?
712 *
713 * @param upBnd 縦軸の?値
714 * @see #setLowerBound( String )
715 */
716 public void setUpperBound( final String upBnd ) {
717 if( upBnd != null && upBnd.length() > 0 ) {
718 upperBound = upBnd;
719 }
720 }
721
722 /**
723 * チャート?縦軸の目盛??セ?しま?初期値:自動計??
724 *
725 * 何も?しな??合?、データの?から、?動的に計算します?
726 *
727 * @og.rev 4.0.3.0 (2008/01/07) 新規追?
728 *
729 * @param size 縦軸のチック(目?の?
730 */
731 public void setTickSize( final String size ) {
732 if( size != null && size.length() > 0 ) {
733 tickSize = size;
734 }
735 }
736
737 /**
738 * バ?チャート?グラ??ション処?行うかど?[true/false]をセ?しま?初期値:true)?
739 *
740 * 通常のバ?チャート?、単?表示で表されますが、これにグラ??ション効果を
741 * 付加するかど?を指定します?
742 * 通常のバ?チャートが、少しきれ?見えます?
743 * 初期値は、true(グラ??ション効果を付与す?です?
744 *
745 * @param useGrad グラ??ション処?[true:する/false:しない]
746 */
747 public void setUseGradient( final boolean useGrad ) {
748 useGradient = useGrad;
749 }
750
751 /**
752 * バ?チャート?グラ??ション処?行うかど?を取得します?
753 *
754 * 通常のバ?チャート?、単?表示で表されますが、これにグラ??ション効果を
755 * 付加するかど?を指定します?
756 * 通常のバ?チャートが、少しきれ?見えます?
757 * 初期値は、false(使用しな?です?
758 *
759 * @return グラ??ション処?する:true/しな?false)
760 * @see #setUseGradient( boolean )
761 */
762 protected boolean isUseGradient() { return useGradient; }
763
764 /**
765 * ラインチャート?ポイントを四角表示するかど?を指定しま?初期値:false)?
766 *
767 * ラインチャート???常、線?で表され、各ポイントにつ?も?線?で接続されます?
768 * shapesVisible ?true に設定すると、各ポイントが、線上に四角く表示され?
769 * そ?ポイント?位置を?容易に判断出来るよ?なります?
770 * 初期値は、?ーカーを?れません?
771 *
772 * @param shVisible ポイントを四角表示するかど?
773 */
774 public void setShapesVisible( final boolean shVisible ) {
775 shapesVisible = shVisible;
776 }
777
778 /**
779 * ラインチャート?ポイントを四角表示するかど?を取得します?
780 *
781 * ラインチャート???常、線?で表され、各ポイントにつ?も?線?で接続されます?
782 * shapesVisible ?true に設定すると、各ポイントが、線上に四角く表示され?
783 * そ?ポイント?位置を?容易に判断出来るよ?なります?
784 * 初期値は、?ーカーを?れません?
785 *
786 * @return ポイントを四角表示するかど?
787 * @see #setShapesVisible( boolean )
788 */
789 protected boolean isShapesVisible() { return shapesVisible; }
790
791 /**
792 * ??タ毎にShapeを?り替える時?色の繰返しパターンを文字?配?で?します?
793 *
794 * HybsLine でのみ使用可能です?
795 * これは、データそ?も?が?繰返し性のある場合に、その繰返し性に対応し?
796 * 形状のShape を表示させる?合に使用します?
797 * 繰返しShapeの形状は、JFreeChart のシリーズ毎?繰返し標準形状を使用します?
798 * 現在のバ?ジョンでは?0?までの繰返しに対応可能です?
799 * 繰返し色を??した????に使用されて?ます?
800 *
801 * ?文字?は、java.awt.Color クラスのstatic フィールド名で?します?
802 * BLACK , BLUE , CYAN , DARK_GRAY , GRAY , GREEN , LIGHT_GRAY ,
803 * MAGENTA , ORANGE , PINK , RED , WHITE , YELLOW , (PURPLE) が指定できます?
804 * また?#XXXXXX形式?16bitRGB表?でも指定可能です?
805 *
806 * @og.rev 4.0.3.0 (2008/01/07) 新規追?
807 *
808 * @param colors ??タ毎?色の繰返しパターン(??配?)
809 * @see java.awt.Color#BLACK
810 */
811 public void setShapeColors( final String[] colors ) {
812 if( colors != null && colors.length > 0 ) {
813 int size = colors.length;
814 shapeColors = new Color[size];
815 for( int i=0; i<size; i++ ) {
816 shapeColors[i] = StringUtil.getColorInstance( colors[i] );
817 }
818 }
819 }
820
821 /**
822 * shapeの大きさを??定で変更しま?初期値:null)?
823 *
824 * ラインチャート?Shape(?ラフ?ポイント?マ?カー)の大きさは??常は?
825 * 自動設定されます?
826 * こ?大きさを?倍率?で、変更可能です?
827 * ??、double 型です?
828 * 初期値は、null は、スケール変更しません(自動設定?ままの大きさ)
829 *
830 * @og.rev 4.1.1.0 (2008/02/04) 新規追?
831 *
832 * @param scale shapeの大きさの倍率
833 */
834 public void setShapeScale( final String scale ) {
835 shapeScale = scale;
836 }
837
838 /**
839 * ラインチャート?線をドットラインにするかど?を指定しま?初期値:false)?
840 *
841 * ラインチャート???常、線?で表されます?
842 * これに、点線で表すことで、グラフ?違いを?色?でなく形状でも識別
843 * しやすくすることが可能です?
844 * 初期値は、線?です?
845 *
846 * @param useDotLine ドットラインにするかど?
847 */
848 public void setUseDottedLine( final boolean useDotLine ) {
849 useDottedLine = useDotLine;
850 }
851
852 /**
853 * ラインチャート?線をドットラインにするかど?を取得します?
854 *
855 * ラインチャート???常、線?で表されます?
856 * これに、点線で表すことで、グラフ?違いを?色?でなく形状でも識別
857 * しやすくすることが可能です?
858 * 初期値は、線?です?
859 *
860 * @return ドットラインにするかど?
861 * @see #setUseDottedLine( boolean )
862 */
863 protected boolean isUseDottedLine() { return useDottedLine; }
864
865 /**
866 * ?チャート描画時?チャート色の繰返しパターンを文字?配?で?します?
867 *
868 * 通常、?のチャートを同時に表示させる?合?、縦軸が?通であれば?
869 * ?回のSelect????タを取得します?
870 * こ?、データをシリーズと呼んでおり、これを区別する為に、色を?けます?
871 * 初期値は、JFreeChart が?動で割り振ります?
872 * これを?外部からCVS形式で、カンマ区?で色コードを?します?
873 * ?データが多い場合?、多い??色は使用されません。少な??合??
874 * ?に繰り返して使用されます?
875 * 例えば?色??した?合?、すべてのシリーズが同じ色で表されます?
876 *
877 * ?文字?は、java.awt.Color クラスのstatic フィールド名で?します?
878 * BLACK , BLUE , CYAN , DARK_GRAY , GRAY , GREEN , LIGHT_GRAY ,
879 * MAGENTA , ORANGE , PINK , RED , WHITE , YELLOW , (PURPLE) が指定できます?
880 * また?#XXXXXX形式?16bitRGB表?でも指定可能です?
881 *
882 * @param colors チャート色の繰返しパターン(??配?)
883 * @see java.awt.Color#BLACK
884 */
885 public void setSeriesColors( final String[] colors ) {
886 if( colors != null && colors.length > 0 ) {
887 int size = colors.length;
888 seriesColors = new Color[size];
889 for( int i=0; i<size; i++ ) {
890 seriesColors[i] = StringUtil.getColorInstance( colors[i] );
891 }
892 }
893 }
894
895 /**
896 * ?チャート描画時?チャート色の繰返しパターンをColor配?で?します?
897 *
898 * @return チャート色の繰返しパターン(Color配?)
899 * @see #setSeriesColors( String[] )
900 */
901 protected Color[] getSeriesColors() {
902 return seriesColors ;
903 }
904
905 /**
906 * Value(縦軸)のラベルを表示するかど?を指定しま?初期値:true[表示する])?
907 *
908 * ValueAxis にて設定される、縦軸??の、ラベルを表示するかど??します?
909 * 初期値は、true(表示する)です?
910 *
911 * @og.rev 4.0.2.0 (2007/12/20) 新規追?
912 *
913 * @param labelsVisible Value(縦軸)のラベルを表示するかど?
914 */
915 public void setValueLabelsVisible( final boolean labelsVisible ) {
916 isLabelsVisible = labelsVisible;
917 }
918
919 /**
920 * Value(縦軸)のマ?カーを表示するかど?を指定しま?初期値:true[表示する])?
921 *
922 * ValueAxis にて設定される、縦軸??の、?ーカーを表示するかど??します?
923 * 初期値は、true(表示する)です?
924 *
925 * @og.rev 4.0.2.0 (2007/12/20) 新規追?
926 *
927 * @param marksVisible Value(縦軸)のマ?カーを表示するかど?
928 */
929 public void setValueMarksVisible( final boolean marksVisible ) {
930 isMarksVisible = marksVisible;
931 }
932
933 /**
934 * ??タの値(itemText)を表示するかど?[true/false/last]を指定しま?初期値:false[表示しない])?
935 *
936 * CategoryItemRenderer 関連のグラフ?設定?をグラフ上に表示するかど??
937 * ?します?
938 * true に設定した?合?通常の場合?、すべてのシリーズにラベル表示されます?
939 * false に設定すると、表示されません?
940 * last を設定すると、各シリーズの??値のみ表示されます?
941 * ChartCreate クラスに、seriesPikup が設定されて?場合?、指定?シリーズ
942 * のみの設定?を表示し?他?値は、表示しません?
943 * 同様に、dynamicOCNo が指定されて?場?動的なマ?カーライン)
944 * ??シリーズは?値として使用されるため?設定?は表示されません?
945 * ラベルの表示位置は、表示する線グラフ?傾きに応じてラベルの表示場?
946 * 変えます?山形、右坂?谷形、左?に応じて、上中、下右、下中、上右 に
947 * 位置を設定します?右にずらす?は?0 ピクセル固定です?
948 * 初期値は、false(表示しな?です?
949 *
950 * @og.rev 4.1.1.0 (2008/02/04) 新規追?
951 * @og.rev 4.1.2.0 (2008/03/12) ??のまま、受け取りるように変更
952 *
953 * @param visible ??タの値の表示のさせ方 [true/false/last]
954 * @see ChartCreate#setSeriesPikup( int )
955 */
956 public void setItemLabelVisible( final String visible ) {
957 if( "true".equalsIgnoreCase( visible ) ) {
958 isItemValVisible = true;
959 }
960 else if( "last".equalsIgnoreCase( visible ) ) {
961 isItemValVisible = true;
962 isItemLastVisible = true;
963 }
964 else if( visible != null && !"false".equalsIgnoreCase( visible ) ) {
965 String errMsg = "itemLabelVisible は、?true,false,last」から指定してください?"
966 + visible + "]";
967 throw new HybsSystemException( errMsg );
968 }
969 }
970
971 /**
972 * ??タの値(itemText)の表示に桁区??を使用するかど?を指定します?
973 *
974 * itemLabelVisible=true 時に、表示されるデータ値ラベルで?
975 * NumberFormat して?すが?桁区???123,456,789.0) の
976 * 区?記号を表示するかど?を指定します?
977 * true を指定すると、表示します?false では、表示しません?
978 * 初期値は、true(使用する)です?
979 *
980 * @og.rev 4.1.2.0 (2008/03/12) 新規追?
981 *
982 * @param used 桁区??を使用するかど?
983 */
984 public void setUseItemLabelSep( final boolean used ) {
985 useItemLabelSep = used;
986 }
987
988 /**
989 * 縦軸の表示領域INSET値(double)を指定します?
990 *
991 * 縦軸?表示領域(NumberAxis)の??追??を設定します?
992 * これは??常の表示領域の左側にスペ?スを挿入します?
993 * あくまで、追?る?なので、文字?長さ?含まれません?
994 * 何も?しな??合?、設定しません?
995 *
996 * @og.rev 4.0.3.0 (2008/01/07) 新規追?
997 *
998 * @param inset Value(縦軸)の表示領域INSET値
999 */
1000 public void setValueInset( final String inset ) {
1001 valueInset = inset;
1002 }
1003
1004 /**
1005 * BOXチャート?バ??double)を指定します?
1006 *
1007 * BOXチャート?バ??double)を指定します?
1008 * 設定されるのは、org.jfree.chart.renderer.category.BarRenderer ?
1009 * 使用した描画のみです?
1010 * 棒グラフ?バ??定?、直接、CategoryItemRendererState に設定して?す?
1011 * 通常は、barMaxWidth(0.0??.0)とbarItemMargin(0.0??.0)を用?比率で?します?
1012 * 何も?しな??合?、設定しません?
1013 *
1014 * @og.rev 4.0.3.0 (2008/01/07) 新規追?
1015 *
1016 * @param width BOXチャート?バ??double)
1017 */
1018 public void setBarWidth( final String width ) {
1019 barWidth = width;
1020 }
1021
1022 /**
1023 * BOXチャート?バ??double)を取得します?
1024 *
1025 * 設定されるのは、org.jfree.chart.renderer.category.BarRenderer ?
1026 * 使用した描画のみです?
1027 * 棒グラフ?バ??定?、直接、CategoryItemRendererState に設定して?す?
1028 * 通常は、barMaxWidth(0.0??.0)とbarItemMargin(0.0??.0)を用?比率で?します?
1029 * 何も?しな??合?、設定しません?
1030 *
1031 * @og.rev 4.0.3.0 (2008/01/07) 新規追?
1032 *
1033 * @return BOXチャート?バ??double)の??
1034 */
1035 protected String getBarWidth() {
1036 return barWidth ;
1037 }
1038
1039 /**
1040 * BOXチャート?バ????値(0.0??.0)を指定します?
1041 *
1042 * BOXチャート?バ???比率の?値を指定します?
1043 * 表示領域を1として小数点以下?数値で棒??設定します?
1044 * 設定した?無?ある時?適当なサイズに調整されます?
1045 * (小さくしたときには棒が線?ようにな?
1046 * 設定されるのは、org.jfree.chart.renderer.category.BarRenderer ?
1047 * 使用した描画のみです?
1048 * 何も?しな??合?、設定しません?
1049 *
1050 * @og.rev 4.0.2.0 (2007/12/20) 新規追?
1051 *
1052 * @param barWidth BOXチャート?バ????値(0.0??.0)
1053 */
1054 public void setBarMaxWidth( final String barWidth ) {
1055 maxBarWidth = barWidth;
1056 }
1057
1058 /**
1059 * BOXチャート?バ?アイ?のマ?ジン(0.0??.0)を指定します?
1060 *
1061 * BOXチャート?バ?アイ?のマ?ジンの比率を指定します?
1062 * 棒?間を表示領域を1として小数点以下?数値で?設定します?
1063 * 無?ある時?適当なサイズに調整されます?
1064 * barMaxWidth より優先されます?
1065 * 設定されるのは、org.jfree.chart.renderer.category.BarRenderer ?
1066 * 使用した描画のみです?
1067 * 何も?しな??合?、設定しません?
1068 *
1069 * @og.rev 4.0.2.0 (2007/12/20) 新規追?
1070 *
1071 * @param margin BOXチャート?バ?アイ?のマ?ジン(0.0??.0)
1072 */
1073 public void setBarItemMargin( final String margin ) {
1074 itemMargin = margin;
1075 }
1076
1077 /**
1078 * 表示下限値(これ以下???タは未表示)の値(double)を指定します?
1079 *
1080 * HybsLine でのみ使用可能です?
1081 * こ?設定?以下???タは、存在しな??します?
1082 * Lineを引くとき?こ???タと、存在して???タ間にラインは引かれません?
1083 * 何も?しな??合?、設定しません?
1084 *
1085 * @og.rev 4.0.3.0 (2008/01/07) 新規追?
1086 *
1087 * @param limit 表示下限値(これ以下???タは未表示)
1088 */
1089 public void setVisibleLimit( final String limit ) {
1090 visibleLimit = limit;
1091 }
1092
1093 /**
1094 * グラフ?書き?し位置の調整比率を指定します?
1095 *
1096 * グラフを描画する場合?、書き?し位置を少しずらします?
1097 * これは、グラフ??対して、比率で?します?
1098 * 0.0(初期値)の場合?、?期描画位置である、CategoryAnchor.Middle と
1099 * 同じ?から、書き?されます?
1100 * 1.0 の場合?中?ら?グラフ??半?が加算され?END位置に?ます?
1101 * 同様に?1.0 の場合?、グラフ??半?が減算され?START 位置になります?
1102 * つまり?中?ら?グラフ??半?単位で、前方/後方にずらす事が出来ます?
1103 * 書き?し位置 ??中?Middle) + (domainMargin)????
1104 * 初期値は?.0(真ん中:MIDDLE)です?
1105 *
1106 * @og.rev 4.1.1.0 (2008/02/14) 新規追?
1107 *
1108 * @param margin グラフ?書き?し位置の調整比率
1109 */
1110 public void setDomainMargin( final double margin ) {
1111 domainMargin = margin;
1112 }
1113
1114 /**
1115 * 時刻を表す?合?表現の仕方を指定しま?初期値:null)?
1116 *
1117 * HybsNumberAxis にオーバ?ライドす?時間を表示する DecimalFormat の?クラスを利用するに当たり?
1118 * 時刻の表示方法を?します?
1119 * 外部から与える数字???続して??があるため?0?数です?
1120 * たとえ??700 ?17:00 , 2150 ?21:30 と?感じです?
1121 * 2400 を?ると日付違?なります?
1122 *
1123 * 英語表?:)と日本語表??の区別と?4時間を?る?合?表示方法によって?種類?パターンが存在します?
1124 * ?1:そ?まま?4:00 となり??されて??
1125 * ?2:そ?まま?:00 に戻る?(日付?無?
1126 * ?3:そ?まま? 00:00 と日付が付与される?
1127 * ?1:そ?まま?4?0?となり??されて??
1128 * ?2:そ?まま?0?0?に戻る?(日付?無?
1129 * ?3:そ?まま?日 00?0?と日付が付与される?
1130 * 初期値は、使用しな?-1)です?
1131 *
1132 * @og.rev 5.5.2.1 (2012/05/07) 新規追?
1133 *
1134 * @param type 時刻の表示方?[E1/E2/E3/H1/H2/H3]
1135 */
1136 public void setTimeFormatType( final String type ) {
1137 timeFormatType = type;
1138 }
1139
1140 /**
1141 * ラベルの表示向きを縦にするかど?[true/false]を指定しま?初期値:false)?
1142 *
1143 * ChartCreate の rotationLabel は、角度を指定できましたが?NumberAxis では?
1144 * 縦にするかど?の?しかできません?
1145 * ここでは、true を指定するとラベルは、縦書きになります?
1146 * 初期値は、false(横書?です?
1147 *
1148 * @og.rev 5.5.2.1 (2012/05/07) 新規追?
1149 *
1150 * @param useVLavels ラベルの表示向き [false:横書?:true:縦書き]
1151 */
1152 public void setUseVerticalLabels( final boolean useVLavels ) {
1153 useVerticalLabels = useVLavels;
1154 }
1155
1156 /**
1157 * MeterPlot に?な??を設定します?
1158 *
1159 * これは、ChartDataset(こ?クラス)に?な getterメソ?を用意して?
1160 * 利用側のクラス(ChartPlot_Pie) でセ?すべきですが、メソ?が増える?で?
1161 * こちらに MeterPlotオブジェクトを渡して、メソ?数を減らそうとして??です?
1162 *
1163 * lowerBound は、最小?(low)
1164 * upperBound は、最大値(upp)
1165 * markValues 値,A,B,C
1166 * markOverColors GREEN,BLUE,YELLOW,RED
1167 * low-A⇒GREEN , A-B⇒BLUE , B-C⇒YELLOW , C-upp⇒RED で、MeterIntervalを指定します?
1168 *
1169 * shapeColors に、NeedlePaint,ValuePaint,TickPaint,TickLabelPaint,DialBackgroundPaint,DialOutlinePaint を指定できます?
1170 * 初期値は、BLACK,BLACK,BLACK,BLACK,透?,BLACK です?
1171 * needleType に、DialShape の?キ??ー??として、CHORD,CIRCLE,PIE が指定可能です?
1172 * ?方法としては、taglib上で、chartType ?時に、Meter_PIE などと?します?
1173 * shapeScale は、MeterAngle(メーターの表示角度) を指定できます?
1174 * valueLabel は、MeterInterval の規定?(値,A,B,C) に対応した?例ラベルです?
1175 *
1176 * @og.rev 5.7.8.0 (2014/07/04) 新規追?
1177 *
1178 * @return 値をセ?し終わった?MeterPlotオブジェク?
1179 */
1180 protected Plot makeMeterPlot() {
1181 MeterPlot mplot = new MeterPlot();
1182
1183 // ?(上限、下限)??
1184 double low= lowerBound == null ? 0.0 : Double.parseDouble( lowerBound ) ;
1185 double upp= upperBound == null ? 100.0 : Double.parseDouble( upperBound ) ;
1186 mplot.setRange( new Range( low, upp ) );
1187
1188 // markValues 値,A,B,C
1189 // markOverColors GREEN,BLUE,YELLOW,RED
1190 // low-A⇒GREEN , A-B⇒BLUE , B-C⇒YELLOW , C-upp⇒RED
1191 // ?の??MeterInterval)は、markValues に?番目の値が設定された場合に行う?
1192 if( markValues != null && markValues.length > 1 ) {
1193 int size = markValues.length ;
1194 if( markOverColors != null && size == markOverColors.length ) {
1195
1196 // BasicStroke に、大きな値を指定すると?始位置がずれてしま??
1197 BasicStroke bs = new BasicStroke( 2.0F );
1198
1199 // valueLabel は、markValues の規定?(A,B,C) に対応した?例ラベルです?
1200 String[] lbls = StringUtil.csv2Array( valueLabel );
1201 int lblSize = lbls.length ;
1202 int j = 0; // ラベルの配?番号
1203
1204 double st = low;
1205 for( int i=1; i<=size; i++ ) {
1206 double en = i<size ? markValues[i] : upp ;
1207 Color co1 = markOverColors[i-1];
1208 Color co2 = new Color( co1.getRed() , co1.getGreen() , co1.getBlue() , 128 ); // 透過色(半??
1209 String lbl = j < lblSize ? lbls[j++] : "" ;
1210 mplot.addInterval( new MeterInterval( lbl, new Range( st, en ), co1, bs, co2 ) );
1211 st = en ;
1212 }
1213 }
1214 else {
1215 String errMsg = "Meter で、markValues を??する?合?、同じ数のmarkOverColorsの?が?です?"
1216 + HybsSystem.CR ;
1217 throw new HybsSystemException( errMsg );
1218 }
1219 }
1220
1221 // ?の??MeterInterval) のサンプル
1222 // mplot.addInterval(new MeterInterval("Battery LOW", new Range(0.0, 10.0),
1223 // Color.RED, new BasicStroke(2.0F), new Color(255, 0, 0, 128)));
1224 // mplot.addInterval(new MeterInterval("Moderate", new Range(10.0, 90.0),
1225 // Color.YELLOW, new BasicStroke(2.0F), new Color(255, 255, 0, 64)));
1226 // mplot.addInterval(new MeterInterval("Battery FULL", new Range(90.0, 100.0),
1227 // Color.GREEN, new BasicStroke(2.0F), new Color(0, 255, 0, 64)));
1228
1229 // TickSize を設定?null なら?、?期?を使??で、設定しな??
1230 if( tickSize != null ) {
1231 mplot.setTickSize( Double.parseDouble( tickSize ) );
1232 }
1233
1234 // shapeColors に、NeedlePaint,ValuePaint,TickPaint,TickLabelPaint,DialBackgroundPaint,DialOutlinePaint を指定できます?
1235 // NeedlePaint , ValuePaint , TickPaint , TickLabelPaint , DialBackgroundPaint(=透?) , DialOutlinePaint
1236 Color[] shCols = new Color[] { Color.BLACK , Color.BLACK , Color.BLACK , Color.BLACK , new Color(255, 255, 255, 0), Color.BLACK }; // 初期値
1237 if( shapeColors != null && shapeColors.length > 0 ) {
1238 for( int i=0; i<shapeColors.length; i++ ) {
1239 shCols[i] = shapeColors[i];
1240 }
1241 }
1242 mplot.setNeedlePaint( shCols[0] ); // 針?色
1243 mplot.setValuePaint( shCols[1] ); // 値の色
1244 mplot.setTickPaint( shCols[2] ); // メモリの色
1245 mplot.setTickLabelPaint( shCols[3] ); // メモリの??色
1246 mplot.setDialBackgroundPaint( shCols[4] ); // 背景色
1247 mplot.setDialOutlinePaint( shCols[5] ); // セ?しても?表示が変わらな??
1248
1249 // needleType 属?で、DialShape を指定できます?
1250 DialShape dshape = DialShape.CIRCLE ; // 初期値
1251 if( needleType != null ) {
1252 if( "CHORD".equalsIgnoreCase( needleType ) ) { dshape = DialShape.CHORD; }
1253 else if( "CIRCLE".equalsIgnoreCase( needleType ) ) { dshape = DialShape.CIRCLE; } // 初期値
1254 else if( "PIE".equalsIgnoreCase( needleType ) ) { dshape = DialShape.PIE; }
1255 }
1256 mplot.setDialShape( dshape ); // CHORD,CIRCLE,PIE
1257
1258 // shapeScale は、MeterAngle(メーターの表示角度) を指?
1259 if( shapeScale != null ) {
1260 mplot.setMeterAngle( Integer.parseInt( shapeScale ) );
1261 }
1262
1263 // isLabelsVisible ??
1264 mplot.setTickLabelsVisible( isLabelsVisible );
1265
1266 // そ?他決め打ちの値設?
1267 // mplot.setValueFont(new Font("Arial", Font.BOLD, 14));
1268 // mplot.setTickLabelFont(new Font("Arial", Font.BOLD, 14));
1269
1270 mplot.setDataset( (ValueDataset)dataset );
1271 return mplot;
1272 }
1273
1274 /**
1275 * ThermometerPlot に?な??を設定します?
1276 *
1277 * markValues 値,A,B
1278 * markOverColors GREEN,YELLOW,RED
1279 * xxx-low⇒GRAY , low-A⇒GREEN , A-B⇒YELLOW , B-upp⇒RED , upp-xxx⇒GRAY で、SubrangePaintを指定します?
1280 * markOverColors を指定しな??合?、ThermometerPlot.NORMAL , WARNING , CRITICAL が?に?されます?
1281 * これは、GREEN,YELLOW,RED になります?
1282 *
1283 * shapeColors に、ValuePaint,ThermometerPaint(温度計???,MercuryPaint を指定できます?
1284 *
1285 * @og.rev 5.7.8.0 (2014/07/04) 新規追?
1286 *
1287 * @return 値をセ?し終わった???ThermometerPlotオブジェク?
1288 */
1289 protected Plot makeThermometerPlot() {
1290 ThermometerPlot tplot = new ThermometerPlot();
1291
1292 // ?(上限、下限)??
1293 double low= lowerBound == null ? 0.0 : Double.parseDouble( lowerBound ) ;
1294 double upp= upperBound == null ? 100.0 : Double.parseDouble( upperBound ) ;
1295 tplot.setRange( low , upp );
1296
1297 // markValues 値,A,B,C
1298 // markOverColors GREEN,YELLOW,RED
1299 // low-A⇒Red , A-B⇒Yellow , B-C⇒Green , C-upp⇒Blue
1300 // ?の??MeterInterval)は、markValues に?番目の値が設定された場合に行う?
1301 if( markValues != null && markValues.length > 1 ) {
1302 int size = markValues.length ;
1303
1304 // markOverColors が存在して、?数が??して?ば、true
1305 boolean inCols = ( markOverColors != null && size == markOverColors.length ) ;
1306 if( inCols || markOverColors == null || markOverColors.length == 0 ) {
1307 double st = low;
1308 for( int i=1; i<=size; i++ ) {
1309 double en = i<size ? markValues[i] : upp ;
1310 // 第?数は、i(?)ではなく?サブレンジ番号(ThermometerPlot.NORMAL , WARNING , CRITICAL)
1311 tplot.setSubrange( i-1, st, en );
1312
1313 if( inCols ) {
1314 Color co1 = markOverColors[i-1];
1315 tplot.setSubrangePaint( i-1,co1 );
1316 }
1317 st = en ;
1318 }
1319 }
1320 else {
1321 String errMsg = "Meter で、markValues を??する?合?、同じ数のmarkOverColorsの?が?です?"
1322 + HybsSystem.CR ;
1323 throw new HybsSystemException( errMsg );
1324 }
1325 }
1326
1327 // ?の??setSubrange) のサンプル
1328 // tplot.setSubrange(ThermometerPlot.NORMAL , 0.0, 55.0);
1329 // tplot.setSubrange(ThermometerPlot.WARNING , 55.0, 75.0);
1330 // tplot.setSubrange(ThermometerPlot.CRITICAL, 75.0, 150.0);
1331
1332 // shapeColors に、ValuePaint,ThermometerPaint(温度計???,MercuryPaint を指定できます?
1333 // ValuePaint , ThermometerPaint , MercuryPaint
1334 Color[] shCols = new Color[] { Color.BLACK , Color.BLACK , Color.GRAY }; // 初期値
1335 if( shapeColors != null && shapeColors.length > 0 ) {
1336 for( int i=0; i<shapeColors.length; i++ ) {
1337 shCols[i] = shapeColors[i];
1338 }
1339 }
1340 tplot.setValuePaint( shCols[0] ); // 値の色
1341 tplot.setThermometerPaint( shCols[1] ); // 温度計???
1342 tplot.setMercuryPaint( shCols[2] ); // オーバ?時?色
1343
1344 // tplot.setValueFont(new Font("Arial", 1, 14));
1345
1346 tplot.setDataset( (ValueDataset)dataset );
1347 return tplot;
1348 }
1349
1350 /**
1351 * CompassPlot に?な??を設定します?
1352 *
1353 * shapeColors に、Compassの色を指定できます?(??は、SeriesPaint にセ?して??
1354 * SeriesPaint,SeriesOutlinePaint,RoseCenterPaint,RoseHighlightPaint,RosePaint を指定します?
1355 * needleType には、MeterNeedle の?キ??ー??として、下記??種類が?可能です?
1356 * ??、Arrow,Line,Long,Pin,Plum,Pointer,Ship,Wind,Arrow,MiddlePin と???です?
1357 * 初期値は、Pointer です?
1358 *
1359 * @og.rev 5.7.8.0 (2014/07/04) 新規追?
1360 *
1361 * @return 値をセ?し終わった???CompassPlotオブジェク?
1362 */
1363 protected Plot makeCompassPlot() {
1364 CompassPlot cplot = new CompassPlot();
1365
1366 // Series ??? 固?
1367 final int serNo = 0;
1368
1369 // needleType 属?で、SeriesNeedle 番号を指定できます?
1370 int sNeedle = 5 ; // Pointer
1371 if( needleType != null ) {
1372 if( "Arrow".equalsIgnoreCase( needleType ) ) { sNeedle = 0; } // 0 = ArrowNeedle;
1373 else if( "Line".equalsIgnoreCase( needleType ) ) { sNeedle = 1; } // 1 = LineNeedle;
1374 else if( "Long".equalsIgnoreCase( needleType ) ) { sNeedle = 2; } // 2 = LongNeedle;
1375 else if( "Pin".equalsIgnoreCase( needleType ) ) { sNeedle = 3; } // 3 = PinNeedle;
1376 else if( "Plum".equalsIgnoreCase( needleType ) ) { sNeedle = 4; } // 4 = PlumNeedle;
1377 else if( "Pointer".equalsIgnoreCase( needleType ) ) { sNeedle = 5; } // 5 = PointerNeedle;
1378 else if( "Ship".equalsIgnoreCase( needleType ) ) { sNeedle = 6; } // 6 = ShipNeedle;
1379 else if( "Wind".equalsIgnoreCase( needleType ) ) { sNeedle = 7; } // 7 = WindNeedle;
1380 else if( "Arrow".equalsIgnoreCase( needleType ) ) { sNeedle = 8; } // 8 = ArrowNeedle;
1381 else if( "MiddlePin".equalsIgnoreCase( needleType ) ) { sNeedle = 9; } // 9 = MiddlePinNeedle;
1382 }
1383 cplot.setSeriesNeedle( serNo, sNeedle );
1384
1385 // shapeColors に、SeriesPaint,SeriesOutlinePaint,RoseCenterPaint,RoseHighlightPaint,RosePaint を指?
1386 // SeriesPaint, SeriesOutlinePaint , RoseCenter , RoseHighlight, Rose
1387 Color[] shCols = new Color[] { Color.RED , Color.BLACK , Color.WHITE , Color.BLACK , Color.YELLOW }; // 初期値
1388 if( shapeColors != null && shapeColors.length > 0 ) {
1389 for( int i=0; i<shapeColors.length; i++ ) {
1390 shCols[i] = shapeColors[i];
1391 }
1392 }
1393 cplot.setSeriesPaint( serNo, shCols[0] ); // 針?色
1394 cplot.setSeriesOutlinePaint( serNo, shCols[1] ); // 針???色
1395 cplot.setRoseCenterPaint( shCols[2] ); // ?盤の中??
1396 cplot.setRoseHighlightPaint( shCols[3] ); // ?盤の???
1397 cplot.setRosePaint( shCols[4] ); // ??塗りつぶし色
1398
1399 cplot.addDataset( (ValueDataset)dataset );
1400
1401 return cplot;
1402 }
1403
1404 /**
1405 * HybsNumberAxis にオーバ?ライドす?時間を表示する DecimalFormat の?クラスを定義します?
1406 *
1407 * これは、ChartPlot_XY で使用する、HybsNumberAxis に対して、拡張します?
1408 * ??タが?時刻を表す?合?Date型?オブジェクトを利用して、org.jfree.chart.axis.PeriodAxis
1409 * を利用できればよいのですが、単なる数字で扱って?ケースがあり?時刻に??
1410 * 変換するケースで使?す?
1411 * 外部から与える数字???続して??があるため?0?数です?
1412 * たとえ??700 ?17:00 , 2150 ?21:30 と?感じです?
1413 * 24時間を?る?合??
1414 * Type1:そ?まま?:00 に戻る?
1415 * Type2:そ?まま?4:00 と、そのまま、加算されて??
1416 * の?種類が用意されて?す?
1417 *
1418 * @og.rev 5.5.2.1 (2012/05/07) 新規追?
1419 *
1420 */
1421 private static final class HybsTimeFormat extends DecimalFormat {
1422 /** For serialization. */
1423 private static final long serialVersionUID = 201205075512L ;
1424
1425 private final boolean is24repeat ;
1426 private final boolean useDay ;
1427
1428 private final int hsCode ;
1429
1430 /**
1431 * コンストラクター
1432 *
1433 * 引数に、時刻を表す?合?表現の仕方を指定します?
1434 * ?1:そ?まま?4:00 となり??されて??
1435 * ?2:そ?まま?:00 に戻る?(日付?無?
1436 * ?3:そ?まま? 00:00 と日付が付与される?
1437 * ?1:そ?まま?4?0?となり??されて??
1438 * ?2:そ?まま?0?0?に戻る?(日付?無?
1439 * ?3:そ?まま?日 00?0?と日付が付与される?
1440 *
1441 * @param type 時刻の表示方?[E1/E2/E3/H1/H2/H3]
1442 */
1443 public HybsTimeFormat( final String inType ) {
1444 super();
1445
1446 DecimalFormatSymbols sym = new DecimalFormatSymbols();
1447 if( "E1".equals( inType ) ) {
1448 applyPattern( "#0.00" );
1449 sym.setDecimalSeparator( ':' );
1450 is24repeat = false; useDay = false;
1451 }
1452 else if( "E2".equals( inType ) ) {
1453 applyPattern( "#0.00" );
1454 sym.setDecimalSeparator( ':' );
1455 is24repeat = true; useDay = false;
1456 }
1457 else if( "E3".equals( inType ) ) {
1458 applyPattern( "#,#0.00" );
1459 sym.setDecimalSeparator( ':' );
1460 sym.setGroupingSeparator( ' ' );
1461 is24repeat = true; useDay = true;
1462 }
1463 else if( "H1".equals( inType ) ) {
1464 applyPattern( "#0.00? );
1465 sym.setDecimalSeparator( '? );
1466 is24repeat = false; useDay = false;
1467 }
1468 else if( "H2".equals( inType ) ) {
1469 applyPattern( "#0.00? );
1470 sym.setDecimalSeparator( '? );
1471 is24repeat = true; useDay = false;
1472 }
1473 else if( "H3".equals( inType ) ) {
1474 applyPattern( "#,#0.00? );
1475 sym.setDecimalSeparator( '? );
1476 sym.setGroupingSeparator( '日' );
1477 is24repeat = true; useDay = true;
1478 }
1479 else {
1480 String errMsg = "timeFormatType は?E1/E2/E3/H1/H2/H3) から?してください。timeFormatType=[" + inType + "]" ;
1481 throw new HybsSystemException( errMsg );
1482 }
1483 setDecimalFormatSymbols( sym );
1484
1485 hsCode = super.hashCode() + Boolean.valueOf(is24repeat).hashCode() + Boolean.valueOf(useDay).hashCode();
1486 }
1487
1488 /**
1489 * double をフォーマットして??を作?しま? format(double,StringBuffer,FieldPosition) のオーバ?ライ?)
1490 *
1491 * timeFormatType によって、データの処?変わります?
1492 * ?1:そ?まま?4:00 となり??されて??
1493 * ?2:そ?まま?:00 に戻る?(日付?無?
1494 * ?3:そ?まま? 00:00 と日付が付与される?
1495 * ?1:そ?まま?4?0?となり??されて??
1496 * ?2:そ?まま?0?0?に戻る?(日付?無?
1497 * ?3:そ?まま?日 00?0?と日付が付与される?
1498 *
1499 * @param number フォーマットす?double
1500 * @param result ?ストを追?る位置
1501 * @param fieldPos 入力では、?であれば位置合わせフィールド? 出力では、その位置合わせフィールド?オフセ?
1502 * @return フォーマットされた数値??
1503 */
1504 public StringBuffer format( final double number, final StringBuffer result, final FieldPosition fieldPos ) {
1505 int day = (int)(number/100/24); // 日付?端数は?捨てる?
1506 int hour = (int)(number/100); // 時間のみ取り出す?
1507 if( is24repeat ) { hour = hour%24; } // ?4時間を?た?合?余りのみ使用する?
1508
1509 int minute = (int)((number%100)*0.6); // 0.6 = 60/100 の事?100 ?60?となる?
1510
1511 double timeVal = hour + minute/100.0 ;
1512 if( useDay ) { timeVal = timeVal + day*100 ; } // 端数を?り捨てた日付に対して?00倍しておく?
1513 return super.format( timeVal, result, fieldPos );
1514 }
1515
1516 /**
1517 * こ?オブジェクトと?されたオブジェクトを比?ます?
1518 *
1519 * @og.rev 5.5.2.4 (2012/05/16) 新規追?findbug対?
1520 *
1521 * @param anObject 比?れるオブジェク?
1522 * @return ?されたオブジェクトが等し??合? true、そ?な??合? false
1523 */
1524 public boolean equals( final Object anObject ) {
1525 return this == anObject;
1526 }
1527
1528 /**
1529 * こ?オブジェクト?ハッシュコードを取得します?
1530 *
1531 * @og.rev 5.5.2.4 (2012/05/16) 新規追?findbug対?
1532 *
1533 * @return ハッシュコー?
1534 */
1535 public int hashCode() {
1536 return hsCode;
1537 }
1538 }
1539
1540 /**
1541 * こ?オブジェクト???表現を返します?
1542 * 基本???目?使用します?
1543 *
1544 * @return こ?クラスの??表現
1545 */
1546 @Override
1547 public String toString() {
1548 StringBuilder rtn = new StringBuilder( HybsSystem.BUFFER_MIDDLE );
1549
1550 rtn.append( "[" ).append( this.getClass().getName() ).append( "]" ).append( HybsSystem.CR );
1551 rtn.append( "chartType [" ).append( chartType ).append( "]" ).append( HybsSystem.CR );
1552 rtn.append( "valueLabel [" ).append( valueLabel ).append( "]" ).append( HybsSystem.CR );
1553 rtn.append( "markValues [" ).append( Arrays.toString( markValues ) ).append( "]" ).append( HybsSystem.CR );
1554 rtn.append( "markColors [" ).append( Arrays.toString( markColors ) ).append( "]" ).append( HybsSystem.CR );
1555 rtn.append( "lowerBound [" ).append( lowerBound ).append( "]" ).append( HybsSystem.CR );
1556 rtn.append( "upperBound [" ).append( upperBound ).append( "]" ).append( HybsSystem.CR );
1557 rtn.append( "useGradient [" ).append( useGradient ).append( "]" ).append( HybsSystem.CR );
1558 rtn.append( "shapesVisible [" ).append( shapesVisible ).append( "]" ).append( HybsSystem.CR );
1559 rtn.append( "useDottedLine [" ).append( useDottedLine ).append( "]" ).append( HybsSystem.CR );
1560
1561 return rtn.toString();
1562 }
1563 }