using System; using System.Collections.Generic; using System.Text; namespace CPF.Windows { public class CreateParams { string className; string caption; int style; int exStyle; int classStyle; int x; int y; int width; int height; IntPtr parent; object param; /// /// /// Name of the window class to subclass. The default value for this field /// is null, indicating that the window is not a subclass of an existing /// window class. To subclass an existing window class, store the window /// class name in this field. For example, to subclass the standard edit /// control, set this field to "EDIT". /// public string ClassName { get { return className; } set { className = value; } } /// /// /// The initial caption your control will have. /// public string Caption { get { return caption; } set { caption = value; } } /// /// /// Window style bits. This must be a combination of WS_XXX style flags and /// other control-specific style flags. /// public int Style { get { return style; } set { style = value; } } /// /// /// Extended window style bits. This must be a combination of WS_EX_XXX /// style flags. /// public int ExStyle { get { return exStyle; } set { exStyle = value; } } /// /// /// Class style bits. This must be a combination of CS_XXX style flags. This /// field is ignored if the className field is not null. /// public int ClassStyle { get { return classStyle; } set { classStyle = value; } } /// /// /// The left portion of the initial proposed location. /// public int X { get { return x; } set { x = value; } } /// /// /// The top portion of the initial proposed location. /// public int Y { get { return y; } set { y = value; } } /// /// /// The initially proposed width. /// public int Width { get { return width; } set { width = value; } } /// /// /// The initially proposed height. /// public int Height { get { return height; } set { height = value; } } /// /// /// The controls parent. /// public IntPtr Parent { get { return parent; } set { parent = value; } } /// /// /// Any extra information that the underlying handle might want. /// public object Param { get { return param; } set { param = value; } } /// /// /// [To be supplied.] /// public override string ToString() { StringBuilder sb = new StringBuilder(64); sb.Append("CreateParams {'"); sb.Append(className); sb.Append("', '"); sb.Append(caption); sb.Append("', 0x"); sb.Append(Convert.ToString(style, 16)); sb.Append(", 0x"); sb.Append(Convert.ToString(exStyle, 16)); sb.Append(", {"); sb.Append(x); sb.Append(", "); sb.Append(y); sb.Append(", "); sb.Append(width); sb.Append(", "); sb.Append(height); sb.Append("}"); sb.Append("}"); return sb.ToString(); } } }