Data Formats
A very important feature in .Net Grid its ability to work directly with application business logic. Business logic is a set of classes that may have certain properties returning specific values, i.g. prices, quantities, dates, etc. Generally these values are represented by primitive types, such as System.Int32, System.Double, System.Decimal etc. To show this data in grid cells, it’s sufficient to convert the necessary values into the System.String type by calling Object.ToString() or String.Format("{0}", value). However, this approach is not flexible and doesn’t support parsing strings to objects. To fill in for this, the .Net Grid provides a very powerful system of formats to convert values into strings and vice-versa. These formats are fully customizable. For instance, the grid can display empty strings instead of "0" when a value equals 0 or add a separator between thousands or some prefix or suffix like "$". These formats can also parse strings back into values. For application programming it’s better to have a set of format classes, where data presentation is centralized.
In programming, formats can be defined in the following places:
- As an attribute of a class property. For example: FormatAttribute, DoubleFormatAttribute, EmptyFormatAttribute, etc.
- In a column: Column.Format = 'your format';
- Directly in a cell (this method requires a lot of memory): Cell.Format = 'your format';
The .Net Grid looks for
IFofmat object to format values or parse strings in the following order:
- In a cell
- In a column returned by the Cell.Column property
- In a IDataField object, returned by the Cell.DataField property.
- If the format is still not found, the grid uses default format for the specified object type.
Some formats greatly simplify application development. For example,
StringFormat, enables use of standard patterns for formatting values through String.Format():
column.Format = new StringFormat("### ### ### ###", string.Empty, " $");
You can also write your own formats for more complex formatting and
parsing. Below you will find an example of a hexadecimal format:
class HexFormat : IFormat
{
public string Format(IDataField dataField)
{
return string.Format("0x{0:X}", dataField.Value);
}
public bool CanParse(string text, IDataField dataField)
{
text = text.Replace("0x", "");
text = text.Trim();
int value;
return string.IsNullOrEmpty(text) ||
int.TryParse(text, NumberStyles.HexNumber, CultureInfo.InvariantCulture,
out value);
}
public void Parse(string text, IDataField dataField)
{
text = text.Replace("0x", "");
text = text.Trim();
int value = 0;
if (string.IsNullOrEmpty(text))
{
dataField.Value = value;
}
else if (int.TryParse(text, NumberStyles.HexNumber,
CultureInfo.InvariantCulture, out value))
{
dataField.Value = value;
}
}
}
column.Format = new HexFormat();
grid.Rows.Add(new object[]{123}});
class SomeClass
{
private int intValue;
[Format(typeof(HexFormat))]
public int SomeHexdecimalValue
{
get { return intValue; }
set { intValue = value; }
}
}
.NET Framework has similar system of type conversion based on the
System.ComponentModel.TypeConverter class that enables conversion of values to strings and vice versa. This conversion system is more complete, but a little bit cumbersome in the context of formating and data parsing. Althrough converters are bulky, such approach enables development of a business logic independently from data presentation. In a perfect case all these mechanisms can be completely based on
Microsoft's component model and therefore have no physical dependencies on libraries of other vendors and on the Dapfor libraries as well.
Here is an example of using System.ComponentModel.TypeConverter:
class HexTypeConverter : TypeConverter
{
public override bool CanConvertFrom(ITypeDescriptorContext context, Type sourceType)
{
return sourceType == typeof(string) || base.CanConvertFrom(context, sourceType);
}
public override bool CanConvertTo(ITypeDescriptorContext context,
Type destinationType)
{
return destinationType == typeof(string) || base.CanConvertTo(context,
destinationType);
}
public override object ConvertFrom(ITypeDescriptorContext context,
CultureInfo culture, object value)
{
if (value is string)
{
string text = (string) value;
text = text.Replace("0x", "");
text = text.Trim();
int result = 0;
if (string.IsNullOrEmpty(text) ||
int.TryParse(text, NumberStyles.HexNumber,
CultureInfo.InvariantCulture, out result))
{
return result;
}
}
return base.ConvertFrom(context, culture, value);
}
public override object ConvertTo(ITypeDescriptorContext context,
CultureInfo culture, object value, Type destinationType)
{
if (value != null && destinationType == typeof(string))
{
return string.Format("0x{0:X}", value);
}
return base.ConvertTo(context, culture, value, destinationType);
}
}
class SomeClass
{
private int intValue;
[TypeConverter(typeof(HexTypeConverter))]
int SomeHexdecimalValue
{
get { return intValue; }
set { intValue = value; }
}
}
Back to .Net Grid Features