TreeMapコントロールでは、コントロールに同時に表示するレベルの数を定義することができます。必要な数の階層レベルを表示することができます。表示するレベルの数を引数としてMaxDepthメソッドを使用します。表示するレベルの数が大きいと、TreeMapがわかりにくくなる可能性があります(レベルの数とそれらが表す値による)。この例では、MaxDepthプロパティを2 に設定します。
次の図は、MaxDepthプロパティを2に設定した後のTreeMapコントロールを示しています。
次のコード例は、TreeMapでMaxDepthプロパティを設定する方法を示します。この例では、ThingSale.csモデルを使用します。
ThingSale.cs
C# |
コードのコピー
|
---|---|
public class ThingSale { private static List<string> Categories = new List<string> { "Music", "Video", "Books", "Electronics", "Computers & Tablets" }; private static Dictionary<string, List<string>> AllCategories = new Dictionary<string, List<string>>(); public string Category { get; set; } public double? Sales { get; set; } public List<ThingSale> Items { get; set; } public static void EnsureInitAllCategories() { if (AllCategories.Count > 0) { return; } AllCategories.Add("音楽の種類", new List<string> { "カントリー", "ロック", "クラシック", "サウンドトラック", "ジャズ", "エレクトロニック" }); AllCategories.Add("カントリー", new List<string> { "クラシックカントリー", "カウボーイカントリー", "アウトローカントリー", "ウェスタンスイング", "ロードハウスカントリー" }); AllCategories.Add("ロック", new List<string> { "ハードロック", "ブルースロック", "ファンクロック", "ラップロック", "ギターロック", "プログレッシブロック" }); AllCategories.Add("クラシック", new List<string> { "交響曲", "室内楽" }); AllCategories.Add("サウンドトラック", new List<string> { "映画サウンドトラック", "ミュージカルサウンドトラック" }); AllCategories.Add("ジャズ", new List<string> { "スムーズジャズ", "ボーカルジャズ", "ジャズフュージョン", "スイングジャズ", "クールジャズ", "トラッドジャズ" }); AllCategories.Add("エレクトロニック", new List<string> { "エレクトロニカ", "ディスコ", "ハウスミュージック" }); AllCategories.Add("ビデオ", new List<string> { "映画", "テレビ" }); AllCategories.Add("映画", new List<string> { "児童", "アクション", "アニメーション", "コメディ", "連続活劇", "恋愛" }); AllCategories.Add("テレビ", new List<string> { "サイエンス・フィクション", "ドキュメンタリー", "ファンタジー", "戦争", "ホラー" }); AllCategories.Add("本", new List<string> { "アート・アンド・フォタグラフィ", "児童書", "歴史", "ミステリー", "ロマンス", "SF&ファンタジー" }); AllCategories.Add("アート・アンド・フォタグラフィ", new List<string> { "建築", "グラフィックデザイン", "ドローイング", "フォタグラフィ", "舞台芸術" }); AllCategories.Add("児童書", new List<string> { "学習図鑑", "童話", "章本", "塗り絵の本", "絵本", "学習まんが" }); AllCategories.Add("歴史", new List<string> { "古代史", "中世史", "ルネサンス" }); AllCategories.Add("ミステリー", new List<string> { "スリラー&サスペンス", "ミステリー" }); AllCategories.Add("ロマンス", new List<string> { "アクションアドベンチャー", "ロマンチックコメディ", "ロマンチックサスペンス", "西部劇", "歴史" }); AllCategories.Add("SF&ファンタジー", new List<string> { "ファンタジー", "ゲーム", "サイエンスフィクション" }); AllCategories.Add("電子デバイス", new List<string> { "カメラ", "ヘッドフォン", "携帯電話", "ウェアブルデバイス" }); AllCategories.Add("カメラ", new List<string> { "デジタルカメラ", "フィルムカメラ", "レンズ", "ビデオ", "アクセサリー" }); AllCategories.Add("ヘッドフォン", new List<string> { "イヤホンヘッドホン", "オーバーイヤーヘッドフォン", "Bluetoothヘッドフォン", "ノイズキャンセリングヘッドフォン", "オーディオファイルヘッドフォン" }); AllCategories.Add("携帯電話", new List<string> { "携帯電話", "アクセサリー" }); AllCategories.Add("アクセサリー", new List<string> { "バッテリー", "Bluetoothヘッドセット", "Bluetoothスピーカー", "充電器", "スクリーンプロテクター" }); AllCategories.Add("ウェアブルデバイス", new List<string> { "アクティビティトラッカー", "スマートウォッチ", "スポーツとGPS対応の時計", "3D VRゴーグルヘッドセット", "ウェアラブルカメラ", "スマートグラス" }); AllCategories.Add("コンピュータ/タブレット", new List<string> { "デスクトップ", "パソコン", "タブレット" }); AllCategories.Add("デスクトップ", new List<string> { "オールインワンPC", "ミニPC", "タワーPC" }); AllCategories.Add("パソコン", new List<string> { "2in1パソコン", "通常のパソコン" }); AllCategories.Add("タブレット", new List<string> { "IOS", "Android", "Fire OS", "Windows" }); } public static IEnumerable<ThingSale> GetData() { EnsureInitAllCategories(); var result = new List<ThingSale>(); Categories.ForEach(cat => { result.Add(Create(cat)); }); return result; } private static ThingSale Create(string category) { var rand = new Random(0); var item = new ThingSale { Category = category }; if (!AllCategories.ContainsKey(category)) { item.Sales = rand.NextDouble() * 100; } else { item.Items = new List<ThingSale>(); AllCategories[category].ForEach(subCat => { item.Items.Add(Create(subCat)); }); } return item; } } |
TreeMapController.cs
C# |
コードのコピー
|
---|---|
public class TreeMapController : Controller { // GET: TreeMap public ActionResult Index() { return View(ThingSale.GetData()); } } |
MaxDepth.cshtml
Razor |
コードのコピー
|
---|---|
@using <ApplicationName.Models> @using System.Drawing; @model IEnumerable<ThingSale> <c1-tree-map id="TreeMap" binding="Sales" binding-name="Category" child-items-path="Items" max-depth="2"> <c1-items-source source-collection="Model"></c1-items-source> <c1-flex-chart-datalabel position="Center" content="{name}"></c1-flex-chart-datalabel> </c1-tree-map> |