//######################################################################################### //★★★★★★★ 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 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 Button /// [DesignTimeVisible(false), ToolboxItem(false)] public class ButtonColumn : Column { #region Class Data /// /// Specifies the alignment of the Image displayed on the button /// private ContentAlignment imageAlignment; #endregion #region Constructor /// /// Creates a new ButtonColumn with default values /// public ButtonColumn() : base() { this.Init(); } /// /// Creates a new ButtonColumn with the specified header text /// /// The text displayed in the column's header public ButtonColumn(string text) : base(text) { this.Init(); } /// /// Creates a new ButtonColumn with the specified header text and width /// /// The text displayed in the column's header /// The column's width public ButtonColumn(string text, int width) : base(text, width) { this.Init(); } /// /// Creates a new ButtonColumn 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 ButtonColumn(string text, int width, bool visible) : base(text, width, visible) { this.Init(); } /// /// Creates a new ButtonColumn with the specified header text and image /// /// The text displayed in the column's header /// The image displayed on the column's header public ButtonColumn(string text, Image image) : base(text, image) { this.Init(); } /// /// Creates a new ButtonColumn 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 ButtonColumn(string text, Image image, int width) : base(text, image, width) { this.Init(); } /// /// Creates a new ButtonColumn 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 ButtonColumn(string text, Image image, int width, bool visible) : base(text, image, width, visible) { this.Init(); } /// /// Initializes the ButtonColumn with default values /// private void Init() { this.Alignment = ColumnAlignment.Center; this.imageAlignment = ContentAlignment.MiddleCenter; this.Editable = false; this.Selectable = false; } #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 "BUTTON"; } /// /// Gets the Column's default CellRenderer /// /// The Column's default CellRenderer public override ICellRenderer CreateDefaultRenderer() { return new ButtonCellRenderer(); } /// /// 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 null; } /// /// Gets the Column's default CellEditor /// /// The Column's default CellEditor public override ICellEditor CreateDefaultEditor() { return null; } #endregion #region Properties /// /// Gets or sets the horizontal alignment of the Column's Cell contents /// [Category("Appearance"), DefaultValue(ColumnAlignment.Center), Description("The horizontal alignment of the column's cell contents.")] public override ColumnAlignment Alignment { get { return base.Alignment; } set { base.Alignment = value; } } /// /// Gets or sets the alignment of the Image displayed on the buttons /// [Category("Appearance"), DefaultValue(ContentAlignment.MiddleCenter), Description("The alignment of the Image displayed on the buttons")] public ContentAlignment ImageAlignment { get { return this.imageAlignment; } set { if (!Enum.IsDefined(typeof(ContentAlignment), value)) { throw new InvalidEnumArgumentException("value", (int) value, typeof(ContentAlignment)); } if (this.imageAlignment != value) { this.imageAlignment = value; this.OnPropertyChanged(new ColumnEventArgs(this, ColumnEventType.RendererChanged, null)); } } } /// /// Gets or sets a value indicating whether the Column's Cells contents /// are able to be edited /// [Category("Appearance"), DefaultValue(false), Description("Controls whether the column's cell contents are able to be changed by the user")] public override bool Editable { get { return base.Editable; } set { base.Editable = value; } } /// /// Gets or sets a value indicating whether the Column's Cells can be selected /// [Category("Appearance"), DefaultValue(false), Description("Indicates whether the column's cells can be selected")] public override bool Selectable { get { return base.Selectable; } set { base.Selectable = 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(TextComparer); } } #endregion } }