React ブレット グラフの概要
React Bullet Graph コンポーネントは、目盛り上でメジャーの比較を簡潔にリニアで表示します。
ブレット グラフ コンポーネントは、きれいなデータ表現を作成するための多数の機能をサポートします。ブレット グラフは、目標に対する進捗状況、評価の範囲、複数の測定比較を表現する際に最も効率的で効果的なグラフの 1 つです。ブレット グラフは、水平または垂直のわずかな領域で、ゴールに至る進捗、評価の範囲、複数の測定比較を表現するための最も効率的で効果的な方法の 1 つです。
React ブレット グラフの例
以下のサンプルは、同じ IgrBulletGraph
でいくつかのプロパティを設定して全く異なるゲージにする方法を示します。
このゲージは、スケール、針、目盛 (1 組)、ラベル (1 組) をサポートします。このコンポーネントには、アニメーション化されたトランジションのサポートも組み込まれています。アニメーションは、transitionDuration
プロパティの設定で簡単にカスタマイズできます。
ブレット グラフの機能には構成可能な向きや方向、視覚要素やツールチップなどがあります。
依存関係
gauge パッケージのインストール時に core パッケージもインストールする必要があります。
npm install --save igniteui-react-core
npm install --save igniteui-react-gauges
モジュールの要件
IgrBulletGraph
を作成するには、以下のモジュールが必要です。
import { IgrBulletGraphModule } from 'igniteui-react-gauges';
IgrBulletGraphModule.register();
使用方法
以下のコードは、ブレット グラフ コンポーネントを作成し、パフォ―マンス バーと比較目盛マーカー、および 3 つの比較範囲をスケールに構成します。
<IgrBulletGraph height="100"
width="300"
minimumValue={5}
maximumValue={55}
value={35}
targetValue={43}>
<IgrLinearGraphRange startValue={0}
endValue={15}
brush="#828181"/>
<IgrLinearGraphRange StartValue={15}
endValue={30}
brush="#AAAAAA"/>
<IgrLinearGraphRange StartValue={30}
bndValue={55}
brush="#D0D0D0"/>
</IgrBulletGraph>
比較メジャー
ブレットグラフは、パフォーマンス値とターゲット値の 2 つのメジャーを表示できます。
パフォーマンス値は、コンポーネントで表示されるプライマリ メジャーでグラフ全体の長さに沿って拡張するバーとして表示されます。ターゲット値は、パフォーマンス値が比較の対象とするメジャーでパフォーマンス バーの向きに対して直角に交わる小さなブロックとして表示されます。
<IgrBulletGraph
value={50}
valueBrush="DodgerBlue"
valueStrokeThickness={1}
valueInnerExtent={0.5}
valueOuterExtent={0.65}
targetValue={80}
targetValueBreadth={10}
targetValueBrush="LimeGreen"
targetValueOutline="LimeGreen"
targetValueStrokeThickness={1}
targetValueInnerExtent={0.3}
targetValueOuterExtent={0.85}
height="80px" width="400px"
minimumValue={0} value={50}
maximumValue={100} />
ハイライト値
バレット グラフのパフォーマンス値をさらに変更して、進捗状況をハイライト値として表示することもできます。これにより、value
が低い不透明度で表示されます。良い例としては、value
が 50 で、highlightValue
が 25 に設定されている場合です。これは、targetValue
の値が何に設定されているかに関係なく、50% のパフォーマンスを表します。これを有効にするには、まず highlightValueDisplayMode
を Overlay に設定し、次に highlightValue
を value
よりも低い値に適用します。
<IgrBulletGraph
height="80px"
width="100%"
value={70}
targetValue={90}
interval={10}
minimumValue={0}
maximumValue={100}
labelInterval={10}
labelExtent={0.025}
labelsPreTerminal={0}
labelsPostInitial={0}
highlightValueDisplayMode="Overlay"
highlightValue={25} />
比較範囲
範囲はスケールで指定した値の範囲をハイライト表示する視覚的な要素です。その目的は、パフォーマンス バー メジャーの質的状態を視覚で伝えると同時に、その状態をレベルとして示すことにあります。
<IgrBulletGraph
height="80px" width="400px"
minimumValue={0} value={80} interval={10}
maximumValue={100} targetValue={90}
rangeBrushes ="#C62828, #F96232, #FF9800"
rangeOutlines="#C62828, #F96232, #FF9800">
<IgrLinearGraphRange
startValue={0} endValue={40}
innerStartExtent={0.075} innerEndExtent={0.075}
outerStartExtent={0.95} outerEndExtent={0.95} />
<IgrLinearGraphRange
startValue={40} endValue={70}
innerStartExtent={0.075} innerEndExtent={0.075}
outerStartExtent={0.95} outerEndExtent={0.95} />
<IgrLinearGraphRange
startValue={70} endValue={100}
innerStartExtent={0.075} innerEndExtent={0.075}
outerStartExtent={0.95} outerEndExtent={0.95} />
</IgrBulletGraph>
目盛
目盛は、ブレット グラフを読み取りやすくするために、目盛の間隔でスケールを分割して見せる役割を果たします。
- 主目盛 - 主目盛は、スケールの主要な区切りとして使用されます。表示間隔、範囲、およびスタイルは、対応するプロパティを設定し制御できます。
- 補助目盛 - 補助目盛は主目盛を補助し、スケールの数値を読み取りやすくするために追加して使用します。主目盛と同じ方法でカスタマイズできます。
<IgrBulletGraph
height="80px" width="400px"
minimumValue={0} value={70}
maximumValue={100} targetValue={90}
interval={10}
tickBrush="DodgerBlue"
ticksPreTerminal={0}
ticksPostInitial={0}
tickStrokeThickness={2}
tickStartExtent={0.2}
tickEndExtent={0.075}
minorTickCount={4}
minorTickBrush="DarkViolet"
minorTickEndExtent={0.1}
minorTickStartExtent={0.2}
minorTickStrokeThickness={1} />
ラベル
ラベルはスケールのメジャーを示します。
<IgrBulletGraph
height="80px" width="400px"
minimumValue={0} value={70} interval={10}
maximumValue={100} targetValue={90}
labelInterval={10}
labelExtent={0.025}
labelsPreTerminal={0}
labelsPostInitial={0}
fontBrush="DodgerBlue"
font="11px Verdana"/>
バッキング
バッキング要素はブレット グラフ コントロールの背景と境界線を表します。常に最初に描画される要素でラベルやメモリなどの残りの要素は互いにオーバーレイします。
<IgrBulletGraph
height="80px" width="400px"
minimumValue={0} value={70} interval={10}
maximumValue={100} targetValue={90}
backingBrush="#bddcfc"
backingOutline="DodgerBlue"
backingStrokeThickness={4}
backingInnerExtent={0}
backingOuterExtent={1} />
スケール
スケールはゲージで値の全範囲をハイライト表示する視覚的な要素です。外観やスケールの図形のカスタマイズ、更にスケールを反転 (isScaleInverted
プロパティを使用) させて、すべてのラベルを左から右ではなく、右から左へ描画することもできます。
<IgrBulletGraph
height="80px" width="400px"
minimumValue={0} value={70} interval={10}
maximumValue={100} targetValue={90}
isScaleInverted={false}
scaleBackgroundBrush="DodgerBlue"
scaleBackgroundOutline="DarkViolet"
scaleBackgroundThickness={2}
scaleStartExtent={0.05}
scaleEndExtent={0.95} />
まとめ
上記すべてのコード スニペットを以下のコード ブロックにまとめています。プロジェクトに簡単にコピーしてブレットグラフのすべての機能を再現できます。
<IgrBulletGraph
height="80px" width="400px"
minimumValue={0}
maximumValue={100}
isScaleInverted={false}
scaleBackgroundBrush="Gray"
scaleBackgroundOutline="Gray"
scaleBackgroundThickness={2}
scaleStartExtent={0.05}
scaleEndExtent={0.95}
value={50}
valueBrush="Black"
valueStrokeThickness={1}
valueInnerExtent={0.5}
valueOuterExtent={0.65}
targetValue={80}
targetValueBreadth={7.5}
targetValueBrush="Black"
targetValueOutline="Black"
targetValueStrokeThickness={1}
targetValueInnerExtent={0.3}
targetValueOuterExtent={0.85}
labelInterval={10}
labelExtent={0.025}
labelsPreTerminal={0}
labelsPostInitial={0}
fontBrush="Black"
font="11px Verdana"
backingBrush="#cecece"
backingOutline="#cecece"
backingStrokeThickness={4}
backingInnerExtent={0}
backingOuterExtent={1}
interval={10}
tickBrush="Black"
ticksPreTerminal={0}
ticksPostInitial={0}
tickStrokeThickness={2}
tickStartExtent={0.2}
tickEndExtent={0.075}
minorTickCount={4}
minorTickBrush="Black"
minorTickEndExtent={0.1}
minorTickStartExtent={0.2}
minorTickStrokeThickness={1}
rangeBrushes ="#C62828, #F96232, #FF9800"
rangeOutlines="#C62828, #F96232, #FF9800">
<IgrLinearGraphRange
startValue={20} endValue={40}
innerStartExtent={0.25} innerEndExtent={0.25}
outerStartExtent={0.9} outerEndExtent={0.9} />
<IgrLinearGraphRange
startValue={40} endValue={60}
innerStartExtent={0.25} innerEndExtent={0.25}
outerStartExtent={0.9} outerEndExtent={0.9} />
<IgrLinearGraphRange
startValue={60} endValue={90}
innerStartExtent={0.25} innerEndExtent={0.25}
outerStartExtent={0.9} outerEndExtent={0.9} />
</IgrBulletGraph>
API リファレンス
以下は上記のセクションで説明した API メンバーのリストです。
その他のリソース
その他のゲージ タイプの詳細については、以下のトピックを参照してください。