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();
}
}
}