//######################################################################################### //★★★★★★★ http://www.cnpopsoft.com [华普软件] ★★★★★★★ //★★★★★★★ 华普软件 - VB & C#.NET 专业论文与源码荟萃! ★★★★★★★ //######################################################################################### /* * Copyright ?2005, Mathew Hall * All rights reserved. * * Redistribution and use in source and binary forms, with or without modification, * are permitted provided that the following conditions are met: * * - Redistributions of source code must retain the above copyright notice, * this list of conditions and the following disclaimer. * * - Redistributions in binary form must reproduce the above copyright notice, * this list of conditions and the following disclaimer in the documentation * and/or other materials provided with the distribution. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. * IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, * OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY * OF SUCH DAMAGE. */ using System; using System.ComponentModel; using System.Drawing; using System.Windows.Forms; using XPTable.Editors; using XPTable.Events; using XPTable.Models.Design; using XPTable.Renderers; using XPTable.Sorting; namespace XPTable.Models { /// /// Represents a Column whose Cells are displayed as a numbers /// [DesignTimeVisible(false), ToolboxItem(false)] public class NumberColumn : Column { #region Class Data /// /// The value to increment or decrement a Cell when its up or down buttons are clicked /// private decimal increment; /// /// The maximum value for a Cell /// private decimal maximum; /// /// The minimum value for a Cell /// private decimal minimum; /// /// The alignment of the up and down buttons in the Column /// private LeftRightAlignment upDownAlignment; /// /// Specifies whether the up and down buttons should be drawn /// private bool showUpDownButtons; #endregion #region Constructor /// /// Creates a new NumberColumn with default values /// public NumberColumn() : base() { this.Init(); } /// /// Creates a new NumberColumn with the specified header text /// /// The text displayed in the column's header public NumberColumn(string text) : base(text) { this.Init(); } /// /// Creates a new NumberColumn with the specified header text and width /// /// The text displayed in the column's header /// The column's width public NumberColumn(string text, int width) : base(text, width) { this.Init(); } /// /// Creates a new NumberColumn with the specified header text, width and visibility /// /// The text displayed in the column's header /// The column's width /// Specifies whether the column is visible public NumberColumn(string text, int width, bool visible) : base(text, width, visible) { this.Init(); } /// /// Creates a new TextColumn with the specified header text and image /// /// The text displayed in the column's header /// The image displayed on the column's header public NumberColumn(string text, Image image) : base(text, image) { this.Init(); } /// /// Creates a new TextColumn with the specified header text, image and width /// /// The text displayed in the column's header /// The image displayed on the column's header /// The column's width public NumberColumn(string text, Image image, int width) : base(text, image, width) { this.Init(); } /// /// Creates a new TextColumn with the specified header text, image, width /// and visibility /// /// The text displayed in the column's header /// The image displayed on the column's header /// The column's width /// Specifies whether the column is visible public NumberColumn(string text, Image image, int width, bool visible) : base(text, image, width, visible) { this.Init(); } /// /// Initializes the NumberColumn with default values /// private void Init() { this.Format = "G"; this.maximum = (decimal) 100; this.minimum = (decimal) 0; this.increment = (decimal) 1; this.showUpDownButtons = false; this.upDownAlignment = LeftRightAlignment.Right; } #endregion #region Methods /// /// Gets a string that specifies the name of the Column's default CellRenderer /// /// A string that specifies the name of the Column's default /// CellRenderer public override string GetDefaultRendererName() { return "NUMBER"; } /// /// Gets the Column's default CellRenderer /// /// The Column's default CellRenderer public override ICellRenderer CreateDefaultRenderer() { return new NumberCellRenderer(); } /// /// Gets a string that specifies the name of the Column's default CellEditor /// /// A string that specifies the name of the Column's default /// CellEditor public override string GetDefaultEditorName() { return "NUMBER"; } /// /// Gets the Column's default CellEditor /// /// The Column's default CellEditor public override ICellEditor CreateDefaultEditor() { return new NumberCellEditor(); } #endregion #region Properties /// /// Gets or sets the maximum value for Column's Cells /// [Category("Appearance"), Description("The maximum value for Column's Cells")] public decimal Maximum { get { return this.maximum; } set { this.maximum = value; if (this.minimum > this.maximum) { this.minimum = this.maximum; } this.OnPropertyChanged(new ColumnEventArgs(this, ColumnEventType.RendererChanged, null)); } } /// /// Specifies whether the Maximum property should be serialized at /// design time /// /// true if the Maximum property should be serialized, /// false otherwise private bool ShouldSerializeMaximum() { return this.maximum != (decimal) 100; } /// /// Gets or sets the minimum value for Column's Cells /// [Category("Appearance"), Description("The minimum value for Column's Cells")] public decimal Minimum { get { return this.minimum; } set { this.minimum = value; if (this.minimum > this.maximum) { this.maximum = value; } this.OnPropertyChanged(new ColumnEventArgs(this, ColumnEventType.RendererChanged, null)); } } /// /// Specifies whether the Minimum property should be serialized at /// design time /// /// true if the Minimum property should be serialized, /// false otherwise private bool ShouldSerializeMinimum() { return this.minimum != (decimal) 0; } /// /// Gets or sets the value to increment or decrement a Cell when its up or down /// buttons are clicked /// [Category("Appearance"), Description("The value to increment or decrement a Cell when its up or down buttons are clicked")] public decimal Increment { get { return this.increment; } set { if (value < new decimal(0)) { throw new ArgumentException("value must be greater than zero"); } this.increment = value; } } /// /// Specifies whether the Increment property should be serialized at /// design time /// /// true if the Increment property should be serialized, /// false otherwise private bool ShouldSerializeIncrement() { return this.increment != (decimal) 1; } /// /// Gets or sets whether the Column's Cells should draw up and down buttons /// [Category("Appearance"), DefaultValue(false), Description("Determines whether the Column's Cells draw up and down buttons")] public bool ShowUpDownButtons { get { return this.showUpDownButtons; } set { if (this.showUpDownButtons != value) { this.showUpDownButtons = value; this.OnPropertyChanged(new ColumnEventArgs(this, ColumnEventType.RendererChanged, null)); } } } /// /// Gets or sets the alignment of the up and down buttons in the Column /// [Category("Appearance"), DefaultValue(LeftRightAlignment.Right), Description("The alignment of the up and down buttons in the Column")] public LeftRightAlignment UpDownAlign { get { return this.upDownAlignment; } set { if (!Enum.IsDefined(typeof(LeftRightAlignment), value)) { throw new InvalidEnumArgumentException("value", (int) value, typeof(LeftRightAlignment)); } if (this.upDownAlignment != value) { this.upDownAlignment = value; this.OnPropertyChanged(new ColumnEventArgs(this, ColumnEventType.RendererChanged, null)); } } } /// /// Gets or sets the string that specifies how a Column's Cell contents /// are formatted /// [Category("Appearance"), DefaultValue("G"), Description("A string that specifies how a column's cell contents are formatted.")] public new string Format { get { return base.Format; } set { base.Format = value; } } /// /// Gets the Type of the Comparer used to compare the Column's Cells when /// the Column is sorting /// public override Type DefaultComparerType { get { return typeof(NumberComparer); } } #endregion } }