//The MIT License(MIT) //Copyright(c) 2016 Alberto Rodriguez & LiveCharts Contributors //Permission is hereby granted, free of charge, to any person obtaining a copy //of this software and associated documentation files (the "Software"), to deal //in the Software without restriction, including without limitation the rights //to use, copy, modify, merge, publish, distribute, sublicense, and/or sell //copies of the Software, and to permit persons to whom the Software is //furnished to do so, subject to the following conditions: //The above copyright notice and this permission notice shall be included in all //copies or substantial portions of the Software. //THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR //IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, //FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE //AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER //LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, //OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE //SOFTWARE. using System; using System.Linq; using System.Windows; using LiveCharts.Charts; using LiveCharts.Definitions.Charts; using LiveCharts.Helpers; namespace LiveCharts.Wpf { /// /// /// /// /// public class DateAxis : WindowAxis, IDateAxisView { #region Constructors /// /// Initializes a new instance of the class. /// public DateAxis() { // Initialize the axis with date windows var collection = new AxisWindowCollection(); collection.AddRange(DateAxisWindows.GetDateAxisWindows()); SetCurrentValue(WindowsProperty, collection); } #endregion #region Properties /// /// The initial date time property /// public static readonly DependencyProperty InitialDateTimeProperty = DependencyProperty.Register( "InitialDateTime", typeof(DateTime), typeof(DateAxis), new PropertyMetadata(DateTime.UtcNow, UpdateChart())); /// /// Gets or sets the Initial Date Time. /// public DateTime InitialDateTime { get { return (DateTime)GetValue(InitialDateTimeProperty); } set { SetValue(InitialDateTimeProperty, value); } } /// /// The period property /// public static readonly DependencyProperty PeriodProperty = DependencyProperty.Register( "Period", typeof(PeriodUnits), typeof(DateAxis), new PropertyMetadata(PeriodUnits.Milliseconds, UpdateChart())); /// /// Gets or sets the period that represents every unit in the axis. /// public PeriodUnits Period { get { return (PeriodUnits)GetValue(PeriodProperty); } set { SetValue(PeriodProperty, value); } } #endregion /// /// Maps as core element. /// /// The chart. /// The source. /// public override AxisCore AsCoreElement(ChartCore chart, AxisOrientation source) { if (Model == null) Model = new DateAxisCore(this); Model.ShowLabels = ShowLabels; Model.Chart = chart; Model.IsMerged = IsMerged; Model.Labels = Labels; Model.LabelFormatter = LabelFormatter; Model.MaxValue = MaxValue; Model.MinValue = MinValue; Model.Title = Title; Model.Position = Position; Model.Separator = Separator.AsCoreElement(Model, source); Model.DisableAnimations = DisableAnimations; Model.Sections = Sections.Select(x => x.AsCoreElement(Model, source)).ToList(); ((DateAxisCore)Model).Windows = Windows.ToList(); ((DateAxisCore)Model).Windows.ForEach(w => ((DateAxisWindow)w).DateAxisCore = (DateAxisCore)Model); return Model; } } }