|
using System;
using System.Collections;
using System.Text;
using System.Windows.Forms;
using System.Globalization;
namespace ExportToExcel
{
public partial class DataGridColumnFactory
{
#region [TextBox]
public static DataGridViewColumn BuildTextColumnStyle(String pDataPropertyName, String pHeaderText, int pWidth)
{
return BuildTextColumnStyle(pDataPropertyName, pHeaderText, pWidth, "", DataGridViewContentAlignment.MiddleLeft, "", true);
}
public static DataGridViewColumn BuildTextColumnStyle(String pDataPropertyName, String pHeaderText, int pWidth, string ToolTipText)
{
DataGridViewColumn col = BuildTextColumnStyle(pDataPropertyName, pHeaderText, pWidth, "", DataGridViewContentAlignment.MiddleLeft, "", true);
col.ToolTipText = ToolTipText;
return col;
}
public static DataGridViewColumn BuildTextColumnStyle(String pDataPropertyName, String pHeaderText, int pWidth, String pNullText, DataGridViewContentAlignment pAlignment, String pFormat, bool bVisible)
{
DataGridViewTextBoxColumn oTextColumnStyle = new DataGridViewTextBoxColumn();
oTextColumnStyle.HeaderText = pHeaderText;
oTextColumnStyle.Name = pDataPropertyName;
oTextColumnStyle.DataPropertyName = pDataPropertyName;
oTextColumnStyle.Width = pWidth;
oTextColumnStyle.CellTemplate.Style.Format = pFormat;
oTextColumnStyle.CellTemplate.Style.NullValue = pNullText;
oTextColumnStyle.CellTemplate.Style.Alignment = pAlignment;
oTextColumnStyle.Visible = bVisible;
oTextColumnStyle.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
return oTextColumnStyle;
}
#endregion [TextBox]
#region [DateTime]
public static DataGridViewTextBoxColumn BuildDateTimeColumnStyle(String pDataPropertyName, String pHeaderText)
{
return BuildDateTimeColumnStyle(pDataPropertyName, pHeaderText, pHeaderText);
}
public static DataGridViewTextBoxColumn BuildDateTimeColumnStyle(String pDataPropertyName, string pHeaderText, string ToolTipText)
{
DataGridViewTextBoxColumn oTextBoxColumnStyle = new DataGridViewTextBoxColumn();
oTextBoxColumnStyle.HeaderText = pHeaderText;
oTextBoxColumnStyle.ToolTipText = ToolTipText;
oTextBoxColumnStyle.DataPropertyName = pDataPropertyName;
oTextBoxColumnStyle.Name = pDataPropertyName;
oTextBoxColumnStyle.Width = 85;
oTextBoxColumnStyle.CellTemplate.Style.Format = "yyyy/MM/dd";
oTextBoxColumnStyle.CellTemplate.Style.NullValue = string.Empty;
oTextBoxColumnStyle.CellTemplate.Style.Alignment = DataGridViewContentAlignment.MiddleRight;
oTextBoxColumnStyle.ReadOnly = true;
return oTextBoxColumnStyle;
}
#endregion [DateTime]
#region [Numeric]
public static DataGridViewTextBoxColumn BuildNumericColumnStyle(String pDataPropertyName, String pHeaderText, int pWidth, bool visible)
{
DataGridViewTextBoxColumn oTextBoxColumnStyle = BuildNumericColumnStyle(pDataPropertyName, pHeaderText, pWidth);
oTextBoxColumnStyle.Visible = visible;
return oTextBoxColumnStyle;
}
public static DataGridViewTextBoxColumn BuildNumericColumnStyle(String pDataPropertyName, String pHeaderText, int pWidth, string tooltip)
{
DataGridViewTextBoxColumn oTextBoxColumnStyle = BuildNumericColumnStyle(pDataPropertyName, pHeaderText, pWidth);
oTextBoxColumnStyle.ToolTipText = tooltip;
return oTextBoxColumnStyle;
}
public static DataGridViewTextBoxColumn BuildNumericColumnStyle(String pDataPropertyName, String pHeaderText, int pWidth)
{
DataGridViewTextBoxColumn oTextBoxColumnStyle = new DataGridViewTextBoxColumn();
oTextBoxColumnStyle.HeaderText = pHeaderText;
oTextBoxColumnStyle.DataPropertyName = pDataPropertyName;
oTextBoxColumnStyle.Name = pDataPropertyName;
oTextBoxColumnStyle.Width = pWidth;
oTextBoxColumnStyle.CellTemplate.Style.Format = "N";
oTextBoxColumnStyle.CellTemplate.Style.FormatProvider = AppNumberFormat(NUMFORMAT.STDNUMBER);
oTextBoxColumnStyle.CellTemplate.Style.NullValue = string.Empty;
oTextBoxColumnStyle.CellTemplate.Style.Alignment = DataGridViewContentAlignment.MiddleRight;
oTextBoxColumnStyle.ReadOnly = true;
return oTextBoxColumnStyle;
}
public enum NUMFORMAT { STDNUMBER, TCNUMBER, INTEGER };
public static NumberFormatInfo AppNumberFormat(NUMFORMAT nf)
{
NumberFormatInfo nfi = (NumberFormatInfo)CultureInfo.CurrentCulture.NumberFormat.Clone();
if (nf == NUMFORMAT.STDNUMBER)
{
nfi.CurrencyDecimalDigits = 2;
nfi.CurrencyDecimalSeparator = ".";
nfi.NumberDecimalSeparator = ".";
nfi.NumberDecimalDigits = 2;
}
else if (nf == NUMFORMAT.TCNUMBER)
{
nfi.CurrencyDecimalDigits = 3;
nfi.CurrencyDecimalSeparator = ".";
nfi.NumberDecimalSeparator = ".";
nfi.NumberDecimalDigits = 3;
}
else if (nf == NUMFORMAT.INTEGER)
{
nfi.CurrencyDecimalDigits = 0;
nfi.CurrencyDecimalSeparator = ".";
nfi.NumberDecimalSeparator = ".";
nfi.NumberDecimalDigits = 0;
}
return nfi;
}
#endregion [Numeric]
}
}
|
By viewing downloads associated with this article you agree to the Terms of Service and the article's licence.
If a file you wish to view isn't highlighted, and is a text file (not binary), please
let us know and we'll add colourisation support for it.