如何使用LightningChart制作一個簡單的甘特圖

該示例是使用7.2.3版本的不可綁定的WPF圖表編寫的。

代碼:

using System;

using System.Collections.Generic;

using System.Linq;

using System.Text;

using System.Windows;

using System.Windows.Controls;

using System.Windows.Data;

using System.Windows.Documents;

using System.Windows.Input;

using System.Windows.Media;

using System.Windows.Media.Imaging;

using System.Windows.Navigation;

using System.Windows.Shapes;

using Arction.Wpf.Charting;

using Arction.Wpf.Charting.Axes;

using Arction.Wpf.Charting.SeriesXY;

using Arction.Wpf.Charting.Views;

using Arction.Wpf.Charting.Views.ViewXY;

using Arction.Wpf.Charting.Annotations;

namespace WpfApplication1

{

///

/// Interaction logic for MainWindow.xaml

///

public partial class MainWindow : Window

{

LightningChartUltimate _chart;

public MainWindow()

{

InitializeComponent();

CreateChart();

}

void CreateChart()

{

_chart = new LightningChartUltimate();

_chart.BeginUpdate();

gridMain.Children.Add(_chart);

_chart.ChartRenderOptions.FontsQuality = FontsRenderingQuality.High;

ViewXY v = _chart.ViewXY;

AxisX xAxis = v.XAxes[0];

AxisY yAxis = v.YAxes[0];

//Set X axis properties

xAxis.ValueType = AxisValueType.DateTime;

xAxis.AutoFormatLabels = false;

xAxis.LabelsTimeFormat = "MM/dd/yyyy";

xAxis.LabelsAngle = 90;

xAxis.SetDateOrigin(new DateTime(2000, 1, 1));//Note, do not give or show X axis values less than this

xAxis.AutoDivSpacing = false;

xAxis.MajorDiv = 24 * 60 * 60;//one day

xAxis.Title.Text = "Time";

v.ZoomPanOptions.RightToLeftZoomAction = RightToLeftZoomActionXY.ZoomOut;

const int DeveloperCount = 5;

//Categories: Developer 1 ... DeveloperN

//Create custom axis ticks for Y axis

for (int dev = 0; dev < DeveloperCount; dev++)

{

yAxis.CustomTicks.Add(new CustomAxisTick(xAxis,dev,"Dev "+dev.ToString(), 10, true, Colors.White, CustomTickStyle.TickAndGrid));

}

yAxis.CustomTicksEnabled = true;

yAxis.AutoFormatLabels = false;

Random rand = new Random();

for (int dev = 0; dev < DeveloperCount; dev++)

{

int taskCount = rand.Next(6, 10);

DateTime dtStart = DateTime.Now;

for (int task = 0; task < taskCount; task++)

{

if(dtStart.DayOfWeek == DayOfWeek.Saturday)

dtStart += TimeSpan.FromDays(2);

else if(dtStart.DayOfWeek == DayOfWeek.Sunday)

dtStart += TimeSpan.FromDays(1);

DateTime dtStop = dtStart + TimeSpan.FromDays((double)rand.Next(1,6));

string title = "Task " + task.ToString();

AddGanttBar(dtStart, dtStop, dev, 0.5, title,

DefaultColors.SeriesForBlackBackgroundWpf[task % DefaultColors.SeriesForBlackBackgroundWpf.Length]);

dtStart = dtStop;

}

}

//Seek min and max values for X and Y axis

double xMax = double.MinValue;

double xMin = double.MaxValue;

double yMax = double.MinValue;

double yMin = double.MaxValue;

foreach (AnnotationXY ganttBar in _chart.ViewXY.Annotations)

{

if (ganttBar.AxisValuesBoundaries.XMin < xMin)

xMin = ganttBar.AxisValuesBoundaries.XMin;

if (ganttBar.AxisValuesBoundaries.XMax > xMax)

xMax = ganttBar.AxisValuesBoundaries.XMax;

if (ganttBar.AxisValuesBoundaries.YMin < yMin)

yMin = ganttBar.AxisValuesBoundaries.YMin;

if (ganttBar.AxisValuesBoundaries.YMax > yMax)

yMax = ganttBar.AxisValuesBoundaries.YMax;

}

xAxis.SetRange(xMin, xMax);

yAxis.SetRange(yMin, yMax);

yAxis.Title.Text = "Assets";

v.LegendBox.Visible = false;

_chart.EndUpdate();

}

void AddGanttBar(DateTime start, DateTime stop, double yCenter, double yHeight, string title, Color color)

{

//Use Annotation as Gantt bar

ViewXY v = _chart.ViewXY;

AxisX xAxis = v.XAxes[0];

AxisY yAxis = v.YAxes[0];

AnnotationXY ganttBar = new AnnotationXY(v, xAxis, yAxis);

ganttBar.Style = AnnotationStyle.Rectangle;

ganttBar.Sizing = AnnotationXYSizing.AxisValuesBoundaries;

ganttBar.AxisValuesBoundaries.XMin = xAxis.DateTimeToAxisValue(start);

ganttBar.AxisValuesBoundaries.XMax = xAxis.DateTimeToAxisValue(stop);

ganttBar.AxisValuesBoundaries.YMin = yCenter - yHeight / 2.0;

ganttBar.AxisValuesBoundaries.YMax = yCenter + yHeight / 2.0;

ganttBar.Fill.GradientFill = GradientFill.Solid;

ganttBar.Fill.Color = Color.FromArgb(200, color.R, color.G, color.B);

ganttBar.Text = title;

ganttBar.Shadow.Visible = false;

ganttBar.RotateByMouse = false;

ganttBar.AnchorAdjustByMouse = false;

ganttBar.ResizeByMouse = false;

ganttBar.MoveByMouse = false;

ganttBar.TargetMoveByMouse = false;

v.Annotations.Add(ganttBar);

}

}

}


甘特圖

The example uses Annotations. There's another ways to make Gantt chart as well, such as:

PolygonSeries, each bar composes of 4 corners. Text on each bar, like in annotation.

LineCollections, simplified output when lots of bars to show. No text on each bar.

?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市送火,隨后出現(xiàn)的幾起案子先匪,更是在濱河造成了極大的恐慌,老刑警劉巖呀非,帶你破解...
    沈念sama閱讀 216,496評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件岸裙,死亡現(xiàn)場離奇詭異,居然都是意外死亡哥桥,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,407評論 3 392
  • 文/潘曉璐 我一進店門判呕,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人辱挥,你說我怎么就攤上這事∥畹猓” “怎么了功蜓?”我有些...
    開封第一講書人閱讀 162,632評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長童社。 經常有香客問我著隆,道長,這世上最難降的妖魔是什么美浦? 我笑而不...
    開封第一講書人閱讀 58,180評論 1 292
  • 正文 為了忘掉前任浦辨,我火速辦了婚禮,結果婚禮上荤牍,老公的妹妹穿的比我還像新娘。我一直安慰自己劈榨,他們只是感情好晦嵌,可當我...
    茶點故事閱讀 67,198評論 6 388
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著旱函,像睡著了一般描滔。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上含长,一...
    開封第一講書人閱讀 51,165評論 1 299
  • 那天,我揣著相機與錄音纷纫,去河邊找鬼。 笑死烟瞧,一個胖子當著我的面吹牛染簇,可吹牛的內容都是我干的岩榆。 我是一名探鬼主播昼丑,決...
    沈念sama閱讀 40,052評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼请唱,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了十绑?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 38,910評論 0 274
  • 序言:老撾萬榮一對情侶失蹤扳躬,失蹤者是張志新(化名)和其女友劉穎甚亭,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體亏狰,經...
    沈念sama閱讀 45,324評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡暇唾,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,542評論 2 332
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了瘸味。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片够挂。...
    茶點故事閱讀 39,711評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖枯冈,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情霜幼,我是刑警寧澤,帶...
    沈念sama閱讀 35,424評論 5 343
  • 正文 年R本政府宣布铸题,位于F島的核電站琢感,受9級特大地震影響,放射性物質發(fā)生泄漏驹针。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,017評論 3 326
  • 文/蒙蒙 一饮六、第九天 我趴在偏房一處隱蔽的房頂上張望苛蒲。 院中可真熱鬧,春花似錦窟扑、人聲如沸漏健。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,668評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至忱辅,卻和暖如春谭溉,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背扮念。 一陣腳步聲響...
    開封第一講書人閱讀 32,823評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留巧勤,地道東北人。 一個月前我還...
    沈念sama閱讀 47,722評論 2 368
  • 正文 我出身青樓沽瞭,卻偏偏與公主長得像剩瓶,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子延曙,可洞房花燭夜當晚...
    茶點故事閱讀 44,611評論 2 353

推薦閱讀更多精彩內容

  • 畫心師岑歡因遭逢變故來到蒼城枝缔,被中醫(yī)鋪子的寧為玉和司馬空空救下。三人來到陸宅愿卸,結識了大小姐陸小曼與衛(wèi)道人士九思,...
    顧冰璃閱讀 468評論 3 2
  • 陪孩子長大·第一章 溫暖的港灣·6.無條件的愛 2017-11-28 中國心宇心理網 第一章 溫暖的港灣 培養(yǎng)親密...
    暖陽_1332閱讀 228評論 0 0
  • 張愛玲的散文大半自訴身邊感受菠劝。人生的赊舶、文化的描述赶诊,都深深透露著她的靈性。字里行間能充分體味到她是一個懂得享受生活之...
    山妖妙妙閱讀 2,662評論 6 22
  • 你的文字和靈感都在你的心里 在你所謂的未來里 你大概在拼命的珍惜時間 或許這種生活模式讓你從承重變得更加壓抑 就算...
    SayEstrus閱讀 217評論 0 0