2003-02-12 02:00:12 +00:00
<Type Name= "Bin" FullName= "Gtk.Bin" >
2005-05-23 20:41:51 +00:00
<TypeSignature Language= "C#" Maintainer= "Lee Mallabone, Miguel de Icaza" Value= "public class Bin : Gtk.Container" />
2011-11-09 10:01:51 -06:00
<TypeSignature Language= "ILAsm" Value= ".class public auto ansi beforefieldinit Bin extends Gtk.Container" />
2003-02-12 02:00:12 +00:00
<AssemblyInfo >
<AssemblyName > gtk-sharp</AssemblyName>
2003-12-24 01:35:30 +00:00
<AssemblyPublicKey >
</AssemblyPublicKey>
2003-02-12 02:00:12 +00:00
</AssemblyInfo>
2003-02-23 07:26:30 +00:00
<ThreadSafetyStatement > Gtk# is thread aware, but not thread safe; See the <link location= "node:gtk-sharp/programming/threads" > Gtk# Thread Programming</link> for details.</ThreadSafetyStatement>
2011-11-09 10:01:51 -06:00
<Base >
<BaseTypeName > Gtk.Container</BaseTypeName>
</Base>
<Interfaces >
</Interfaces>
2003-02-12 02:00:12 +00:00
<Docs >
2003-03-15 10:41:15 +00:00
<summary > A container with just one child.</summary>
2003-03-15 22:50:24 +00:00
<remarks >
2003-07-15 02:34:04 +00:00
<para >
A Bin widget is a <see cref= "T:Gtk.Container" /> with just one
child. It is used to create subclasses, since it provides
2003-07-17 06:38:40 +00:00
common code needed for handling a single child <see cref= "T:Gtk.Widget" /> .
2003-07-15 02:34:04 +00:00
</para>
<para >
2003-07-17 06:38:40 +00:00
Many GTK+ widgets are subclasses of Bin, including <see cref= "T:Gtk.Window" /> , <see cref= "T:Gtk.Button" /> , <see cref= "T:Gtk.Frame" /> , <see cref= "T:Gtk.HandleBox" /> , and
2003-07-15 02:34:04 +00:00
<see cref= "T:Gtk.ScrolledWindow" /> .</para>
<para >
To place a child widget inside this container, use the
standard <see cref= "M:Gtk.Container.Add" /> method.</para>
<para >
For the widget to be useful, it should participate in size
2003-07-17 06:38:40 +00:00
negotiation and size allocation using the events <see cref= "E:Gtk.Widget.SizeAllocated" /> and <see cref= "E:Gtk.Widget.SizeRequested" /> .</para>
2003-07-15 02:34:04 +00:00
<para >
2004-06-19 18:25:02 +00:00
Sample follows.
2003-07-15 02:34:04 +00:00
</para>
<example >
<code lang= "C#" >
using System;
using Gtk;
//
// A simple Bin class: a simple container that adds padding.
//
class MyPadder : Bin {
int pad = 50;
Widget child;
2004-06-19 18:25:02 +00:00
public MyPadder ()
2003-07-15 02:34:04 +00:00
{
// To track our child widget.
Added += new AddedHandler (MyAdded);
// Participate in size negotiation
SizeRequested += new SizeRequestedHandler (OnSizeRequested);
SizeAllocated += new SizeAllocatedHandler (OnSizeAllocated);
}
//
// Invoked to query our size
//
void OnSizeRequested (object o, SizeRequestedArgs args)
{
if (child != null){
2004-06-19 18:25:02 +00:00
int width = args.Requisition.Width;
int height = args.Requisition.Height;
2003-07-15 02:34:04 +00:00
child.GetSizeRequest (out width, out height);
if (width == -1 || height == -1)
width = height = 80;
SetSizeRequest (width + pad * 2, height + pad * 2);
}
}
//
// Invoked to propagate our size
//
void OnSizeAllocated (object o, SizeAllocatedArgs args)
{
if (child != null){
Gdk.Rectangle mine = args.Allocation;
Gdk.Rectangle his = mine;
2004-06-19 18:25:02 +00:00
his.X += pad;
his.Y += pad;
his.Width -= pad * 2;
his.Height -= pad * 2;
2003-07-15 02:34:04 +00:00
child.SizeAllocate (his);
}
}
//
// Public property of the Padding widget
//
public int Pad {
get {
return pad;
}
set {
pad = value;
QueueResize ();
}
}
void MyAdded (object o, AddedArgs args)
{
child = args.Widget;
}
}
class Y {
static void Main ()
{
Application.Init ();
Window w = new Window ("Hello");
MyPadder x = new MyPadder ();
x.Pad = 100;
Button b = new Button ("Hola");
w.Add (x);
x.Add (b);
w.ShowAll ();
Application.Run ();
}
}
2003-07-17 06:38:40 +00:00
</code>
2003-07-15 02:34:04 +00:00
</example>
2003-03-15 22:50:24 +00:00
</remarks>
2003-02-12 02:00:12 +00:00
</Docs>
<Members >
<Member MemberName= ".ctor" >
2011-11-09 10:01:51 -06:00
<MemberSignature Language= "C#" Value= "protected Bin ();" />
<MemberSignature Language= "ILAsm" Value= ".method familyhidebysig specialname rtspecialname instance void .ctor() cil managed" />
2003-02-12 02:00:12 +00:00
<MemberType > Constructor</MemberType>
<ReturnValue />
2003-12-24 01:35:30 +00:00
<Parameters />
<Docs >
2011-11-09 10:01:51 -06:00
<summary > Protected constructor.</summary>
<remarks > Chain to this constructor if you have not manually registered a native <see cref= "T:GLib.GType" /> value for your subclass.</remarks>
2003-12-24 01:35:30 +00:00
</Docs>
</Member>
<Member MemberName= ".ctor" >
2011-11-09 10:01:51 -06:00
<MemberSignature Language= "C#" Value= "public Bin (IntPtr raw);" />
<MemberSignature Language= "ILAsm" Value= ".method public hidebysig specialname rtspecialname instance void .ctor(native int raw) cil managed" />
2003-12-24 01:35:30 +00:00
<MemberType > Constructor</MemberType>
<ReturnValue />
<Parameters >
2011-11-09 10:01:51 -06:00
<Parameter Name= "raw" Type= "System.IntPtr" />
2003-12-24 01:35:30 +00:00
</Parameters>
<Docs >
2011-11-09 10:01:51 -06:00
<param name= "raw" > Pointer to the C object.</param>
<summary > Internal constructor</summary>
<remarks >
<para > This is an internal constructor, and should not be used by user code.</para>
</remarks>
2004-06-01 18:05:26 +00:00
</Docs>
</Member>
2004-09-24 15:58:05 +00:00
<Member MemberName= "Child" >
2011-11-09 10:01:51 -06:00
<MemberSignature Language= "C#" Value= "public Gtk.Widget Child { get; set; }" />
<MemberSignature Language= "ILAsm" Value= ".property instance class Gtk.Widget Child" />
2004-09-24 15:58:05 +00:00
<MemberType > Property</MemberType>
<ReturnValue >
<ReturnType > Gtk.Widget</ReturnType>
</ReturnValue>
<Parameters />
<Docs >
<summary > Accesses the one and only child widget of this Bin object.</summary>
2005-05-23 20:41:51 +00:00
<value > a <see cref= "T:Gtk.Widget" /> </value>
2004-09-24 15:58:05 +00:00
<remarks >
</remarks>
</Docs>
</Member>
2011-11-09 10:01:51 -06:00
<Member MemberName= "GType" >
<MemberSignature Language= "C#" Value= "public static GLib.GType GType { get; }" />
<MemberSignature Language= "ILAsm" Value= ".property valuetype GLib.GType GType" />
<MemberType > Property</MemberType>
<ReturnValue >
<ReturnType > GLib.GType</ReturnType>
</ReturnValue>
<Parameters />
<Docs >
<summary > GType Property.</summary>
<value > a <see cref= "T:GLib.GType" /> </value>
<remarks > Returns the native <see cref= "T:GLib.GType" /> value for <see cref= "T:Gtk.Bin" /> .</remarks>
</Docs>
</Member>
2003-02-12 02:00:12 +00:00
</Members>
2005-05-23 20:41:51 +00:00
</Type>