方法: グラフ ドキュメントを編集およびカスタマイズする
Visual Studio Ultimate では、ノードとリンクを編集することにより、有向グラフの編集の主要な関係および領域に絞って表示できます。 これは、グラフに大量の情報が表示される場合に特に便利です。 たとえば、既存のソフトウェア システム内の主要なコンポーネントとそれらの関係を特定できます。 その後、絞り込んだこれらの領域をチーム メンバーと共有し、議論することができます。 コードからのグラフの生成の詳細については、「方法: .NET コードに対する依存関係グラフを生成する」を参照してください。
関心のある領域を強調して表示するために、ノードの選択およびフィルター処理、ノードおよびリンクへの定義済みスタイルの適用、およびノードのグループへの編成を実行できます。 グラフの DGML (Directed Graph Markup Language) ファイルを編集すると、グラフをさらに詳細にカスタマイズできます。 たとえば、ファイルの DGML 要素を編集して、カスタム スタイルを指定したり、ノードおよびリンクにプロパティおよびカテゴリを割り当てたり、ドキュメント、URL、その他の .dgml ファイルなどのアイテムにノードをリンクしたりすることができます。 DGML 要素の詳細については、「Directed Graph Markup Language (DGML) について」を参照してください。
注意
.dgml ファイルを保存すると、Visual Studio により、未使用の DGML 要素および属性が削除されクリーンアップされます。 また、新しいリンクを手動で追加すると、自動的にノード要素が生成されます。.dgml ファイルを保存すると、要素に追加した属性がアルファベット順に並べ替えられる場合があります。
グラフは次の方法で編集できます。
ノードを選択する
ノードの表示/非表示を切り替える
リンクの表示/非表示を切り替える
グラフのスタイルを変更する
ノードおよびリンクのスタイルを変更する
一方のグラフから他方のグラフにスタイルをコピーする
ノードをグループに編成する
ノードおよびリンクにプロパティを割り当てる
ノードおよびリンクにカテゴリを割り当てる
アイテムをノードにリンクする
よく使用されるパスのエイリアスを作成する
ノードを選択する
目的 |
実行する手順 |
---|---|
特定のカテゴリからノードを選択する |
カスタム カテゴリを作成し割り当てる方法については、「ノードおよびリンクにカテゴリを割り当てる」を参照してください。 |
特定のプロパティまたは特定のプロパティ値を持つノードを選択する |
|
関連するノードを選択したノードに追加する |
選択したノードを右クリックし、[選択] をポイントし、次のいずれかをクリックします。
|
すべての選択されていないノードを選択する |
選択したノードを右クリックし、[選択] をポイントし、[切り替え] をクリックします。 |
ノードの表示/非表示を切り替える
グラフ上のノードを非表示にすると、そのノードはグラフに表示されなくなり、配置アルゴリズムから削除されます。
目的 |
実行する手順 |
---|---|
選択したノードを非表示にする |
|
特定のカテゴリまたは特定のプロパティを持つノードを非表示にする |
|
選択されていないノードを非表示にする |
|
すべての非表示のノードを表示する |
グラフを右クリックし、[選択] をポイントし、[すべて再表示] をクリックします。 |
.dgml ファイルを編集してノードを非表示にするには
グラフを右クリックし、[DGML の表示] をクリックします。
Visual Studio で、グラフの .dgml ファイルが開きます。
<Node/> 要素に、ノードを非表示にするための次の属性を追加します。
Visibility="Hidden"
次に例を示します。
<Nodes> <Node Id="MyNode" Visibility="Hidden"/> </Nodes>
リンクの表示/非表示を切り替える
表示するリンクの種類を指定することで、グラフ上の詳細情報の量を制御できます。 グラフには、ノード間の直接リンクと、既定では非表示のグループ間リンクの 2 種類のリンクが表示されます。 グループ間リンクは、異なるグループにまたがってノードを接続するすべての個別リンクです。
グループを折りたたむと、すべてのグループ間リンクが、グループ間の単一リンクにまとめられます。 グループを展開すると、グループ内のノードを選択でき、グループ間リンクが新たに表示されて、そのグループ内の実際の依存関係が示されます。
リンクの表示/非表示を切り替えるには
グラフ ツール バーが表示されていない場合は、[ビュー] メニューの [ツール バー] をポイントし、[有向グラフ] をクリックします。
次の表からタスクを選択します。
目的
クリック対象
すべてのグループ間リンクを常時表示する
[すべてのグループ間リンクを表示]
選択したノードに接続されているグループ間リンクのみを表示する
[選択したノードのグループ間リンクを表示]
すべてのグループ間リンクを常時非表示にする
[すべてのグループ間リンクを非表示]
すべてのリンクを非表示にする (またはすべてのリンクを表示する)
[すべてのリンクを非表示]
すべてのリンクを表示するには、[すべてのリンクを非表示] を再度クリックして、このモードをオフにします。
グラフのスタイルを変更する
グラフの .dgml ファイルを編集することで、グラフの背景色および境界線の色を変更できます。 ノードおよびリンクのスタイルを変更する方法については、「ノードおよびリンクのスタイルを変更する」を参照してください。
グラフのスタイルを変更するには
グラフを右クリックし、[DGML の表示] をクリックします。
Visual Studio で、グラフの .dgml ファイルが開きます。
<DirectedGraph> 要素に次の任意の属性を追加して、グラフのスタイルを変更します。
変更対象
追加する属性
背景色
Background="ColorNameOrHexadecimalValue"
境界線の色
Stroke="StrokeValue"
次に例を示します。
<DirectedGraph Background="Green" xmlns="https://schemas.microsoft.com/vs/2009/dgml" > ... ... </DirectedGraph>
ノードおよびリンクのスタイルを変更する
ノードのアイコン、およびノードとリンクの色を変更できます。 定義済みの色およびアイコンを使用することも、グラフの .dgml ファイルを編集してカスタム カラーおよびカスタム アイコンを指定することもできます。 詳細については、「ノードおよびリンクにカスタム スタイルを適用する」を参照してください。
たとえば、色を選択することで、特定のカテゴリまたは特定のプロパティを持つノードおよびリンクを強調して表示できます。 これにより、グラフの特定の領域を特定し、目立たせることができます。
特定のカテゴリまたは特定のプロパティを持つノードに定義済みの色またはアイコンを適用するには
[凡例] ボックスが表示されていない場合は、グラフを右クリックし、[凡例の表示] をクリックします。
[凡例] ボックスで、ノードのカテゴリまたはプロパティがリストに表示されているかどうかを確認します。
リストにカテゴリまたはプロパティが含まれていない場合は、[追加] をクリックし、[ノード カテゴリ] または [ノード プロパティ] をポイントし、カテゴリまたはプロパティをクリックします。
注意
カテゴリを作成してノードに割り当てる方法については、「ノードおよびリンクにカテゴリを割り当てる」を参照してください。 プロパティを作成してノードに割り当てる方法については、「ノードおよびリンクにプロパティを割り当てる」を参照してください。
[凡例] ボックスで、カテゴリまたはプロパティの横のドロップダウン リストをクリックします。
次の表を使用して、変更するスタイルを選択します。
変更対象
選択
背景色
背景
外枠の色
ストローク
テキストの色
前景
アイコン
アイコン
ピッカー ダイアログ ボックスで、次のいずれかのオプションを選択します。
適用対象
手順
色 (またはアイコン) のセット
[カラー設定 (アイコン セット) の選択] ドロップダウン リストをクリックし、色 (またはアイコン) のセットをクリックします。
既定の色 (またはアイコン) に戻すには、[カラー設定 (アイコン セット) の選択] ドロップダウン リストで、[なし] をクリックします。
特定の色 (またはアイコン)
カテゴリまたはプロパティ値のドロップダウン リストをクリックし、色 (またはアイコン) を選択します。
終了したら、[OK] をクリックします。
注意
[凡例] ボックス内のスタイルを再整列、削除、または一時的に無効化できます。 詳細については、「[凡例] ボックスを変更する」を参照してください。
特定のカテゴリまたは特定のプロパティを持つリンクに定義済みの色を適用するには
[凡例] ボックスが表示されていない場合は、グラフを右クリックし、[凡例の表示] をクリックします。
[凡例] ボックスで、カテゴリまたはプロパティがリストに表示されているかどうかを確認します。
リストにカテゴリまたはプロパティが含まれていない場合、[追加] をクリックし、[リンク カテゴリ] または [リンク プロパティ] をポイントし、カテゴリまたはプロパティをクリックします。
注意
カテゴリを作成してリンクに割り当てる方法については、「ノードおよびリンクにカテゴリを割り当てる」を参照してください。 プロパティを作成してリンクに割り当てる方法については、「ノードおよびリンクにプロパティを割り当てる」を参照してください。
[凡例] ボックスで、カテゴリまたはプロパティの横のドロップダウン リストをクリックします。
次の表を使用して、変更するスタイルを選択します。
変更対象
選択
矢じりの色
背景
外枠の色
ストローク
[カラー セット ピッカー] ボックスで、次のいずれかのオプションを選択します。
適用対象
手順
色のセット
[カラー設定の選択] ドロップダウン リストをクリックし、色のセットをクリックします。
既定の色に戻すには、[カラー設定の選択] ドロップダウン リストで、[なし] をクリックします。
特定の色
種類またはプロパティ値のドロップダウン リストをクリックして、色を選択します。
終了したら、[OK] をクリックします。
注意
[凡例] ボックス内のスタイルを再整列、削除、または一時的に無効化できます。 詳細については、「[凡例] ボックスを変更する」を参照してください。
ノードおよびリンクにカスタム スタイルを適用する
次のアイテムにカスタム スタイルを適用できます。
単一のノードおよびリンク
ノードのグループおよびリンクのグループ
特定の条件に基づくノードのグループおよびリンクのグループ
単一のノードにカスタム スタイルを適用するには
スタイルをカスタマイズするノードを右クリックし、[DGML の表示] をクリックします。
Visual Studio で、グラフの .dgml ファイルが開き、そのノードに対応する <Node/> 要素が強調表示されます。
<Node/> 要素に次の属性を追加して、スタイルをカスタマイズします。
変更対象
追加する属性
背景色
Background="ColorNameOrHexadecimalValue"
外枠
Stroke="ColorNameOrHexadecimalValue"
外枠の太さ
StrokeThickness="StrokeValue"
テキストの色
Foreground="ColorNameOrHexadecimalValue"
アイコン
Icon="IconFilePathLocation"
テキストのサイズ
FontSize="FontSizeValue"
テキストの種類
FontFamily="FontFamilyName"
テキストの太さ
FontWeight="FontWeightValue"
テキストのスタイル
FontStyle="FontStyleName"
たとえば、テキストのスタイルとして Italic を指定できます。
テクスチャ
Style="Glass"
または
Style="Plain"
形
Shape
次に例を示します。
<Nodes> <Node Id="MyNode" Background="Green" Stroke="#FF000000" Foreground="White" Icon="...\Graph Icons\MyNodeIcon.jpg"/> </Nodes>
単一のリンクにカスタム スタイルを適用するには
グラフで、マウス ポインターをリンクの上へ移動してツールヒントを表示し、リンク元ノードとリンク先ノードを確認します。
グラフを右クリックし、[DGML の表示] をクリックします。
Visual Studio で、グラフの .dgml ファイルが開きます。
リンク元ノードとリンク先ノードの両方の名前を含む <Link/> 要素を探します。
<Link/> 要素に次の属性を追加して、スタイルをカスタマイズします。
変更対象
追加する属性
矢じりの色
Background="ColorNameOrHexadecimalValue"
外枠の色
Stroke="ColorNameOrHexadecimalValue"
外枠の太さ
StrokeThickness="StrokeValue"
外枠のスタイル
StrokeDashArray="StrokeArrayValues"
次に例を示します。
<Links> <Link Source="MyFirstNode" Target="MySecondNode" Background="Green" Stroke="#FF000000" /> </Links>
ノードのグループまたはリンクのグループにカスタム スタイルを適用するには
ノードまたはリンクに、目的のカテゴリまたはプロパティを割り当てます。
詳細については、「ノードおよびリンクにカテゴリを割り当てる」および「ノードおよびリンクにプロパティを割り当てる」を参照してください。
グラフを右クリックし、[DGML の表示] をクリックします。
Visual Studio で、グラフの .dgml ファイルが開きます。
<Styles></Styles> 要素が存在しない場合、<Links></Links> 要素の後の <DirectedGraph></DirectedGraph> 要素の下位に、この要素を追加します。
<Styles></Styles> 要素で、<Style/> 要素の下位に次の属性を指定します。
TargetType="Node | Link | Graph"
GroupLabel="NameInLegendBox"
ValueLabel="NameInStylePickerBox"
全種類の対象にカスタム スタイルを適用する場合、条件は使用しません。
ノードのグループまたはリンクのグループに条件付きスタイルを適用するには
<Style/> 要素に、Expression 属性を含む <Condition/> 要素を追加して、ブール値を返す式を指定します。
次に例を示します。
<Condition Expression="MyCategory"/>
または
<Condition Expression="MyCategory > 100"/>
または
<Condition Expression="HasCategory('MyCategory')"/>
この式では、次のバッカス・ナウア記法 (BNF: Backus-Naur Form) 構文を使用します。
<Expression> ::= <BinaryExpression> | <UnaryExpression> | "("<Expression>")" | <MemberBindings> | <Literal> | <Number>
<BinaryExpression> ::= <Expression> <Operator> <Expression>
<UnaryExpression> ::= "!" <Expression> | "+" <Expression> | "-" <Expression>
<Operator> ::= "<" | "<=" | "=" | ">=" | ">" | "!=" | "or" | "and" | "+" | "*" | "/" | "-"
<MemberBindings> ::= <MemberBindings> | <MemberBinding> "." <MemberBinding>
<MemberBinding> ::= <MethodCall> | <PropertyGet>
<MethodCall> ::= <Identifier> "(" <MethodArgs> ")"
<PropertyGet> ::= Identifier
<MethodArgs> ::= <Expression> | <Expression> "," <MethodArgs> | <empty>
<Identifier> ::= [^. ]*
<Literal> ::= 一重引用符または二重引用符で囲んだリテラル文字列
<Number> ::= 数字の文字列 (小数点も可)
複数の <Condition/> 要素を指定できます。スタイルを適用するには、それらがすべて true である必要があります。
<Condition/> 要素の後の次の行に、1 つ以上の <Setter/> 要素を追加して、条件を満たすグラフ、ノード、またはリンクに適用する Property 属性と、固定の Value 属性または計算される Expression 属性を指定します。
次に例を示します。
<Setter Property="BackGround" Value="Green"/>
以下に簡単な完成例を示します。この例の条件では、ノードの Passed カテゴリが True に設定されているか、または False に設定されているかに基づいて、ノードが緑色または赤色で表示されます。
<?xml version="1.0" encoding="utf-8"?>
<DirectedGraph xmlns="https://schemas.microsoft.com/vs/2009/dgml">
<Nodes>
<Node Id="MyFirstNode" Passed="True" />
<Node Id="MySecondNode" Passed="False" />
</Nodes>
<Links>
</Links>
<Styles>
<Style TargetType="Node" GroupLabel="Passed" ValueLabel="True">
<Condition Expression="Passed='True'"/>
<Setter Property="Background" Value="Green"/>
</Style>
<Style TargetType="Node" GroupLabel="Passed" ValueLabel="False">
<Condition Expression="Passed='False'"/>
<Setter Property="Background" Value="Red"/>
</Style>
</Styles>
</DirectedGraph>
次の表に、実際に使用できる条件例をいくつか示します。
目的 |
DGML の例 |
---|---|
コード行数の関数に従ってフォント サイズを設定し、ノードのサイズも変更する。 この例では、単一の条件式を使用して、複数のプロパティ (FontSize および FontFamily) を設定しています。 |
|
Coverage プロパティに基づいて、ノードの背景色を設定する。 スタイルは、if-else ステートメントと同様に、出現する順番で評価されます。 この例では、次のように記述されています。
|
|
Shape プロパティを None に設定して、図形をアイコンで置き換える。 Icon プロパティを使用して、アイコンの場所を指定します。 |
|
[凡例] ボックスを変更する
[凡例] ボックス内のスタイルを、次のように再整列、削除、または一時的に無効化できます。
[凡例] ボックス内で右クリックします。
次のいずれかのタスクを実行します。
目的
クリック対象
アイテムを上へ移動する
[上へ移動]
アイテムを下へ移動する
[下へ移動]
アイテムを削除する
[削除]
アイテムを無効にする
[無効化]
アイテムを再度有効にする
[有効化]
一方のグラフから他方のグラフにスタイルをコピーする
- コピー元のグラフの空白領域を右クリックし、[凡例のコピー] をクリックし、コピー先のグラフにスタイルを貼り付けます。
ノードをグループに編成する
目的 |
実行する手順 |
---|---|
コンテインメント関係があるノードをグループまたはリンクとして表示する |
リンクをグループとして表示するには、コンテナー ノードを選択し、選択内容を右クリックします。次に、[グループ] をポイントし、[グループとして表示] をクリックします。 グループをリンクとして表示するには、コンテナー ノードを選択し、選択内容を右クリックし、[グループ] をポイントし、[リンクとして表示] をクリックします。 すべてのグループをリンクとして表示するには、グラフを右クリックし、[グループ] をポイントし、[すべてをリンクとして表示] をクリックします。 すべてのリンクをグループとして表示するには、グラフを右クリックし、[グループ] をポイントし、[すべてをグループとして表示] をクリックします。 |
選択したノードを含む新しいグループを追加する |
|
特定のカテゴリまたは特定のプロパティを持つノードを含む新しいグループを追加する |
|
コンテナーに基づいてノードをグループ化する |
|
プロパティ値に基づいてノードをグループ化する |
|
グループを削除する |
削除する 1 つ以上のグループを選択し、選択内容を右クリックします。次に、[グループ] をポイントし、[グループの削除] をクリックします。 |
親グループから祖父母グループにノードを移動する (祖父母グループがない場合は、グループの外部にノードを移動する) |
移動するノードを選択し、選択内容を右クリックします。次に、[グループ] をポイントし、[親から削除] をクリックします。 |
グラフの .dgml ファイルを編集する方法を使用して、ノードをグループに編成することもできます。
既存のノードをグループとして使用するか、新しいグループを追加するには
既存のノードをグループとして使用するには、グループ ノードとして使用するノードを右クリックし、[DGML の表示] をクリックします。
Visual Studio で、グラフの .dgml ファイルが開き、そのノードに対応する <Node/> 要素が強調表示されます。
または
新しいグループを追加するには、グラフの空白領域を右クリックし、[DGML を表示] をクリックします。
<Nodes> セクションに、新たに <Node/> 要素を追加します。
<Node/> 要素に、Group 属性を追加して、グループを展開した状態で表示するか、折りたたんだ状態で表示するかを指定します。 次に例を示します。
<Nodes> <Node Id="MyFirstGroup" Group="Expanded" /> <Node Id="MySecondGroup" Group="Collapsed" /> </Nodes>
<Links> セクションで、グループ ノードとその子ノードとの間の関係ごとに、次の属性を持つ <Link/> 要素が存在していることを確認します。
グループ ノードを指定する Source 属性
子ノードを指定する Target 属性
グループ ノードとその子ノードとの間の Contains 関係を指定する Category 属性
次に例を示します。
<Links> <Link Category="Contains" Source="MyFirstNewGroup" Target="FirstGroupChildOne" /> <Link Category ="Contains" Source="MyFirstNewGroup" Target="FirstGroupChildTwo" /> <Link Category ="Contains" Source="MySecondNewGroup" Target="SecondGroupChildOne" /> <Link Category="Contains" Source="MySecondNewGroup" Target="SecondGroupChildTwo" /> </Links>
Category 属性の詳細については、「ノードおよびリンクにカテゴリを割り当てる」を参照してください。
ノードおよびリンクにプロパティを割り当てる
ノードおよびリンクにプロパティを割り当てることで、ノードおよびリンクを編成できます。 たとえば、特定のプロパティを持つノードを選択して、それらのグループ化、スタイルの変更、または非表示化を実行できます。
ノードにプロパティを割り当てるには
ノードを右クリックし、[DGML の表示] をクリックします。
Visual Studio で、グラフの .dgml ファイルが開き、そのノードに対応する <Node/> 要素が強調表示されます。
<Node/> 要素で、プロパティの名前とその値を指定します。 次に例を示します。
<Nodes> <Node Id="MyNode" MyPropertyName="PropertyValue" /> </Nodes>
<Property/> 要素を <Properties> セクションに追加して、属性 (要素の表示名、データ型など) を指定します。
<Properties> <Property Id="MyPropertyName" Label="My Property" DataType="System.DataType"/> </Properties>
リンクにプロパティを割り当てるには
グラフで、マウス ポインターをリンクの上へ移動してツールヒントを表示し、リンク元ノードとリンク先ノードを確認します。
グラフを右クリックし、[DGML の表示] をクリックします。
Visual Studio で、グラフの .dgml ファイルが開きます。
リンク元ノードとリンク先ノードの両方の名前を含む <Link/> 要素を探します。
<Node/> 要素で、プロパティの名前とその値を指定します。 次に例を示します。
<Links> <Link Source="MyFirstNode" Target="MySecondNode" MyPropertyName="PropertyValue" /> </Links>
<Property/> 要素を <Properties> セクションに追加して、属性 (要素の表示名、データ型など) を指定します。
<Properties> <Property Id="MyPropertyName" Label="My Property Name" DataType="System.DataType"/> </Properties>
ノードおよびリンクにカテゴリを割り当てる
ノードにカテゴリを割り当てることで、ノードを編成できます。 たとえば、特定のカテゴリに属するノードを選択して、それらのグループ化、スタイルの変更、または非表示化を実行できます。 特定のカテゴリを持つリンクは強調表示できます。 詳細については、以下のセクションを参照してください。
ノードをグループに編成する
ノードおよびリンクのスタイルを変更する
ノードの表示/非表示を切り替える
ノードにカテゴリを割り当てるには
- [カテゴリ 1] などの定義済みのカテゴリを割り当てるには、ノードを右クリックし、[カテゴリ] をポイントし、定義済みのカテゴリをクリックします。
または
カスタム カテゴリを作成して割り当てるには
- カテゴリを割り当てるノードをクリックし、F4 キーを押して [プロパティ] ウィンドウを開きます。次に、ノードの [新しいカテゴリ] プロパティにカテゴリの名前を入力し、Enter キーを押します。
または
ノードを右クリックし、[DGML の表示] をクリックします。
Visual Studio で、グラフの .dgml ファイルが開き、そのノードに対応する <Node/> 要素が強調表示されます。
<Node/> 要素に Category 属性を追加して、カテゴリの名前を指定します。 次に例を示します。
<Nodes> <Node Id="MyNode" Category="MyCategory" /> </Nodes>
<Categories> セクションに <Category/> 要素を追加することで、Label 属性を使用してそのカテゴリの表示テキストを指定できます。
<Categories> <Category Id="MyCategory" Label="My Category" /> </Categories>
リンクにカテゴリを割り当てるには
グラフで、マウス ポインターをリンクの上へ移動してツールヒントを表示し、リンク元ノードとリンク先ノードを確認します。
グラフを右クリックし、[DGML の表示] をクリックします。
Visual Studio で、グラフの .dgml ファイルが開きます。
リンク元ノードとリンク先ノードの両方の名前を含む <Link/> 要素を探します。
<Link/> 要素に Category 属性を追加して、カテゴリの名前を指定します。 次に例を示します。
<Links> <Link Source="MyFirstNode" Target="MySecondNode" Category="MyCategory" </Links>
<Categories> セクションに <Category/> 要素を追加することで、Label 属性を使用してそのカテゴリの表示テキストを指定できます。
<Categories> <Category Id="MyCategory" Label="My Category" /> </Categories>
階層構造のカテゴリを作成すると、継承を使用してノードの編成および子カテゴリへの属性の追加を行う際に便利です。
階層構造のカテゴリを作成するには
親カテゴリを示す <Category/> 要素を追加し、次に子カテゴリの <Category/> 要素に BasedOn 属性を追加します。
次に例を示します。
<Nodes> <Node Id="MyFirstNode" Label="My First Node" Category= "MyCategory" /> <Node Id="MySecondNode" Label="My Second Node" /> </Nodes> <Links> <Link Source="MyFirstNode" Target="MySecondNode" /> </Links> <Categories> <Category Id="MyCategory" Label="My Category" BasedOn="MyParentCategory"/> <Category Id="MyParentCategory" Label="My Parent Category" Background="Green"/> </Categories>
この例では、MyFirstNode の背景は緑色になります。これは、その Category 属性が MyParentCategory の Background 属性を継承するためです。
アイテムをノードにリンクする
ドキュメントや URL などのアイテムをノードにリンクするには、グラフの .dgml ファイルを編集し、そのノードの <Node/> 要素に Reference 属性を追加します。 Reference 属性では、そのコンテンツのパスを指定します。 これには、.dgml ファイルの場所に対する相対パス、または絶対パスを使用できます。 これで、グラフ上のノードからそのコンテンツを開いて参照できるようになります。
注意
1 つ以上の参照先アイテムを表示するには、それらが存在している必要があります。
たとえば、次のアイテムをリンクできます。
クラスに対する変更を示すには、クラスを示すノードに、作業項目、ドキュメント、または別の .dgml ファイルの URL をリンクします。
ソフトウェアの論理アーキテクチャのレイヤーを表すグループ ノードにレイヤー図をリンクします。
インターフェイスを公開するコンポーネントに関する詳細情報を表示するには、そのインターフェイスを示すノードにコンポーネント図をリンクします。
ノードを、ノードに関連する Team Foundation Server の作業項目やバグ、またはその他の情報にリンクします。
アイテムからノードへのリンクを設定するには
グラフ上のノードを右クリックし、[DGML の表示] をクリックします。
Visual Studio で、グラフの .dgml ファイルが開き、そのノードに対応する <Node/> 要素が強調表示されます。
次の表にあるタスクのいずれかを実行します。
リンク対象
手順
単一のアイテム
<Node/> 要素に Reference 属性を追加して、アイテムの場所を指定します。
メモ<Node/> 要素 1 つに対して 1 つの Reference 属性のみを使用できます。
次に例を示します。
<Nodes> <Node Id="MyNode" Reference="MyDocument.txt" /> </Nodes> <Properties> <Property Id="Reference" Label="My Document" DataType="System.String" IsReference="True" /> </Properties>
複数のアイテム
<Node/> 要素に、各参照の場所を指定する新しい属性を追加します。
<Properties> セクションで、次の操作を行います。
新しい種類の参照ごとに <Property/> 要素を追加します。
新しい参照属性の名前に Id 属性を設定します。
IsReference 属性を追加し、それを True に設定して、参照がノードの [移動先] ショートカット メニューに表示されるようにします。
Label 属性を使用して、ノードの [移動先] ショートカット メニューの表示テキストを指定します。
次に例を示します。
<Nodes> <Node Id="MyNode" SequenceDiagram="MySequenceDiagram.sequencediagram" ActiveBugs="MyActiveBugs.wiq"/> </Nodes> <Properties> <Property Id="SequenceDiagram" Label="My Sequence Diagram" DataType="System.String" IsReference="True" /> <Property Id="ActiveBugs" Label="Active Bugs" DataType="System.String" IsReference="True" /> </Properties>
グラフでは、ノードの名前は下線付きで表示されます。
参照で文字列を繰り返し使用する代わりに、ReferenceTemplate 属性を使用して、複数の参照で使用する共通の文字列 (URL など) を指定します。
ReferenceTemplate 属性では、参照の値のプレースホルダーを指定します。 次の例では、ReferenceTemplate 属性の {0} プレースホルダーは、<Node/> 要素の MyFirstReference 属性および MySecondReference 属性の値に置換され、完全なパスが生成されます。
<Nodes> <Node Id="MyNode" MyFirstReference="MyFirstDocument" MySecondReference="MySecondDocument"/> <Node Id="MySecondNode" MyFirstReference="AnotherFirstDocument" MySecondReference="AnotherSecondDocument"/> </Nodes> <Properties> <Property Id="MyFirstReference" Label="My First Document" DataType="System.String" IsReference="True" ReferenceTemplate="http://www.Fabrikam.com/FirstDocuments/{0}.asp"/> <Property Id="MySecondReference" Label="My Second Document" DataType="System.String" IsReference="True" ReferenceTemplate=" http://www.Fabrikam.com/SecondDocuments/{0}.asp"/> </Properties>
参照先のアイテムを表示するには、次のいずれかの操作を実行します。
表示される項目
実行する手順
単一のアイテム
ノードをダブルクリックします。
または
ノードを右クリックし、[移動先] をポイントして、アイテムをクリックします。
複数のアイテム
ノードを右クリックし、[移動先] をポイントして、アイテムをクリックします。
よく使用されるパスのエイリアスを作成する
よく使用されるパスをエイリアスに置き換えると、.dgml ファイルのサイズを小さくして、ファイルの読み込みまたは保存に必要な時間を短縮することができます。 エイリアスを作成するには、.dgml ファイルの末尾に <Paths></Paths> セクションを追加します。 このセクションには、パスのエイリアスを定義する <Path/> 要素を追加します。
<Paths>
<Path Id="MyPathAlias" Value="C:\...\..." />
</Paths>
.dgml ファイル内の要素からエイリアスを参照するには、<Path/> 要素の Id 値をドル記号 ($) とかっこ (()) で囲みます。
<Nodes>
<Node Id="MyNode" Reference="$(MyPathAlias)MyDocument.txt" />
</Nodes>
<Properties>
<Property Id="Reference" Label="My Document" DataType="System.String" IsReference="True" />
</Properties>
Directed Graph Markup Language (DGML) について
DGML では、単純な XML を使用して、循環および非循環の有向グラフを記述します。 有向グラフは、リンク (エッジ) によって接続されている一連のノードです。 ノードとリンクを使用すると、ネットワーク構造 (ソフトウェア プロジェクトの要素など) を表すことができます。 情報の視覚化、複雑性解析の実行、または単に有向グラフの参照および編集を行うには、DGML を使用します。
ノードとリンクはグラフ要素、または単に要素と呼ばれます。 DGML で使用される要素の種類を次の表に示します。
注意
.dgml ファイルを編集するときは、各要素とその値に使用できる属性が IntelliSense によって識別されます。 属性で色を指定するには、一般的な色の名前 ("Blue" など) または ARGB 16 進値 ("#ffa0b1c3" など) を使用してください。 DGML では、WPF (Windows Presentation Foundation) 色定義形式の小さいサブセットを使用します。 詳細については、「Colors クラス」を参照してください。
要素 |
サンプルの形式 |
---|---|
<DirectedGraph></DirectedGraph> この要素は、有向グラフ (.dgml) ドキュメントのルート要素です。 他のすべての DGML 要素は、この要素のスコープ内に表示されます。 追加できる属性 (省略可能) は次のとおりです。
|
|
<Nodes></Nodes> この省略可能な要素には、グラフ上のノードを定義する <Node/> 要素の一覧が含まれます。 詳細については、<Node/> 要素を参照してください。
メモ
<Link/> 要素内の未定義のノードを参照する場合、グラフでは <Node/> 要素が自動的に作成されます。
|
|
<Node/> この要素は、単一のノードを定義します。 この要素は、<Nodes><Nodes/> 要素の一覧内に表示されます。 この要素には、次の属性が必要です。
追加できる属性 (省略可能) の一部を次に示します。
|
|
<Links></Links> この要素には、ノード間のリンクを定義する <Link> 要素の一覧が含まれます。 詳細については、<Link/> 要素を参照してください。 |
|
<Link/> この要素は、リンク元ノードをリンク先ノードに接続する単一のリンクを定義します。 この要素は、<Links></Links> 要素の一覧内に表示されます。
メモ
この要素が未定義のノードを参照する場合、グラフ ドキュメントでは、指定された属性を含むノードが自動的に作成されます。
この要素には、次の属性が必要です。
追加できる属性 (省略可能) の一部を次に示します。
|
|
<Categories></Categories> この要素には、<Category/> 要素の一覧が含まれます。 詳細については、<Category/> 要素を参照してください。 |
|
<Category/> この要素は、この属性を共有する要素を識別するために使用される Category 属性を定義します。 Category 属性を使用すると、グラフ要素の整理、継承による共有属性の提供、または追加のメタデータの定義が可能になります。 この要素には、次の属性が必要です。
追加できる属性 (省略可能) の一部を次に示します。
また、カテゴリでは、グラフに表示されるノードおよびリンクの外観を制御するいくつかの基本的なテンプレート動作が指定されます。 詳細については、「ノードおよびリンクにカスタム スタイルを適用する」を参照してください。 |
|
<Properties></Properties> この要素には、<Property/> 要素の一覧が含まれます。 詳細については、<Property/> 要素を参照してください。 |
|
<Property/> この要素は、カテゴリおよびその他のプロパティを含む任意の DGML 要素または属性に値を代入する際に使用できる Property 属性を定義します。 この要素には、次の属性が必要です。
[プロパティ] ウィンドウにプロパティを表示する場合は、Label プロパティを使用して、対象のプロパティの表示名を指定します。 詳細については、「ノードおよびリンクにプロパティを割り当てる」を参照してください。 |
|