//#########################################################################################
//★★★★★★★ 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
}
}