//######################################################################################### //★★★★★★★ 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 CheckBox /// [DesignTimeVisible(false), ToolboxItem(false)] public class CheckBoxColumn : Column { #region Class Data /// /// The size of the checkbox /// private Size checkSize; /// /// Specifies whether any text contained in the Cell should be drawn /// private bool drawText; /// /// The style of the checkboxes /// private CheckBoxColumnStyle checkStyle; #endregion #region Constructor /// /// Creates a new CheckBoxColumn with default values /// public CheckBoxColumn() : base() { this.Init(); } /// /// Creates a new CheckBoxColumn with the specified header text /// /// The text displayed in the column's header public CheckBoxColumn(string text) : base(text) { this.Init(); } /// /// Creates a new CheckBoxColumn with the specified header text and width /// /// The text displayed in the column's header /// The column's width public CheckBoxColumn(string text, int width) : base(text, width) { this.Init(); } /// /// Creates a new CheckBoxColumn 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 CheckBoxColumn(string text, int width, bool visible) : base(text, width, visible) { this.Init(); } /// /// Creates a new CheckBoxColumn with the specified header text and image /// /// The text displayed in the column's header /// The image displayed on the column's header public CheckBoxColumn(string text, Image image) : base(text, image) { this.Init(); } /// /// Creates a new CheckBoxColumn 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 CheckBoxColumn(string text, Image image, int width) : base(text, image, width) { this.Init(); } /// /// Creates a new CheckBoxColumn 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 CheckBoxColumn(string text, Image image, int width, bool visible) : base(text, image, width, visible) { this.Init(); } /// /// Initializes the CheckBoxColumn with default values /// private void Init() { this.checkSize = new Size(13, 13); this.drawText = true; this.checkStyle = CheckBoxColumnStyle.CheckBox; } #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 "CHECKBOX"; } /// /// Gets the Column's default CellRenderer /// /// The Column's default CellRenderer public override ICellRenderer CreateDefaultRenderer() { return new CheckBoxCellRenderer(); } /// /// 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 size of the checkboxes /// [Category("Appearance"), Description("Specifies the size of the checkboxes")] public Size CheckSize { get { return this.checkSize; } set { if (value.Width < 0 || value.Height < 0) { value = new Size(13, 13); } if (this.checkSize != value) { this.checkSize = value; this.OnPropertyChanged(new ColumnEventArgs(this, ColumnEventType.RendererChanged, null)); } } } /// /// Specifies whether the CheckSize property should be serialized at /// design time /// /// true if the CheckSize property should be serialized, /// false otherwise private bool ShouldSerializeCheckSize() { return (this.checkSize.Width != 13 || this.checkSize.Height != 13); } /// /// Gets or sets whether any text contained in the Cell should be drawn /// [Category("Appearance"), DefaultValue(true), Description("Specifies whether any text contained in the Cell should be drawn")] public bool DrawText { get { return this.drawText; } set { if (this.drawText != value) { this.drawText = value; this.OnPropertyChanged(new ColumnEventArgs(this, ColumnEventType.RendererChanged, null)); } } } /// /// Gets or sets whether any text contained in the Cell should be drawn /// [Category("Appearance"), DefaultValue(CheckBoxColumnStyle.CheckBox), Description("Specifies the style of the checkboxes")] public CheckBoxColumnStyle CheckStyle { get { return this.checkStyle; } set { if (!Enum.IsDefined(typeof(CheckBoxColumnStyle), value)) { throw new InvalidEnumArgumentException("value", (int) value, typeof(CheckBoxColumnStyle)); } if (this.checkStyle != value) { this.checkStyle = value; this.OnPropertyChanged(new ColumnEventArgs(this, ColumnEventType.RendererChanged, null)); } } } /// /// 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(CheckBoxComparer); } } #endregion } }