mirror of
https://github.com/Ryujinx/GtkSharp.git
synced 2025-01-25 20:00:57 +00:00
sample: Update CustomWidget sample and add it to the build
This commit is contained in:
parent
75f9a8acb7
commit
2656a5220c
|
@ -5,7 +5,7 @@ using System;
|
||||||
class CustomWidgetTest {
|
class CustomWidgetTest {
|
||||||
public static int Main (string[] args)
|
public static int Main (string[] args)
|
||||||
{
|
{
|
||||||
Application.Init ();
|
Gtk.Application.Init ();
|
||||||
Window win = new Window ("Custom Widget Test");
|
Window win = new Window ("Custom Widget Test");
|
||||||
win.DeleteEvent += new DeleteEventHandler (OnQuit);
|
win.DeleteEvent += new DeleteEventHandler (OnQuit);
|
||||||
|
|
||||||
|
@ -30,18 +30,17 @@ class CustomWidgetTest {
|
||||||
|
|
||||||
win.Add (paned);
|
win.Add (paned);
|
||||||
win.ShowAll ();
|
win.ShowAll ();
|
||||||
Application.Run ();
|
Gtk.Application.Run ();
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void OnQuit (object sender, DeleteEventArgs args)
|
static void OnQuit (object sender, DeleteEventArgs args)
|
||||||
{
|
{
|
||||||
Application.Quit ();
|
Gtk.Application.Quit ();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
class CustomWidget : Bin {
|
class CustomWidget : Bin {
|
||||||
internal static GType customWidgetGType;
|
|
||||||
private Gdk.Pixbuf icon;
|
private Gdk.Pixbuf icon;
|
||||||
private string label;
|
private string label;
|
||||||
private Pango.Layout layout;
|
private Pango.Layout layout;
|
||||||
|
@ -54,13 +53,13 @@ class CustomWidget : Bin {
|
||||||
layout = null;
|
layout = null;
|
||||||
stockid = Stock.Execute;
|
stockid = Stock.Execute;
|
||||||
|
|
||||||
WidgetFlags |= WidgetFlags.NoWindow;
|
HasWindow = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
private Gdk.Pixbuf Icon {
|
private Gdk.Pixbuf Icon {
|
||||||
get {
|
get {
|
||||||
if (icon == null)
|
if (icon == null)
|
||||||
icon = RenderIcon (stockid, IconSize.Menu, "");
|
icon = RenderIconPixbuf (stockid, IconSize.Menu);
|
||||||
return icon;
|
return icon;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -89,7 +88,7 @@ class CustomWidget : Bin {
|
||||||
}
|
}
|
||||||
set {
|
set {
|
||||||
stockid = value;
|
stockid = value;
|
||||||
icon = RenderIcon (stockid, IconSize.Menu, "");
|
icon = RenderIconPixbuf (stockid, IconSize.Menu);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -108,39 +107,24 @@ class CustomWidget : Bin {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
protected override bool OnExposeEvent (Gdk.EventExpose args)
|
protected override bool OnDrawn (Cairo.Context cr)
|
||||||
{
|
{
|
||||||
Gdk.Rectangle exposeArea;
|
|
||||||
Gdk.Rectangle titleArea = TitleArea;
|
Gdk.Rectangle titleArea = TitleArea;
|
||||||
|
|
||||||
if (args.Area.Intersect (titleArea, out exposeArea))
|
Gdk.CairoHelper.SetSourcePixbuf (cr, Icon, 0, 0);
|
||||||
GdkWindow.DrawPixbuf (Style.BackgroundGC (State), Icon, 0, 0,
|
cr.Paint ();
|
||||||
titleArea.X, titleArea.Y, Icon.Width,
|
|
||||||
Icon.Height, Gdk.RgbDither.None, 0, 0);
|
|
||||||
|
|
||||||
titleArea.X += icon.Width + 1;
|
int layout_x = icon.Width + 1;
|
||||||
titleArea.Width -= icon.Width - 1;
|
titleArea.Width -= icon.Width - 1;
|
||||||
|
|
||||||
if (args.Area.Intersect (titleArea, out exposeArea)) {
|
|
||||||
int layoutWidth, layoutHeight;
|
int layoutWidth, layoutHeight;
|
||||||
Layout.GetPixelSize (out layoutWidth, out layoutHeight);
|
Layout.GetPixelSize (out layoutWidth, out layoutHeight);
|
||||||
|
|
||||||
titleArea.Y += (titleArea.Height - layoutHeight) / 2;
|
int layout_y = (titleArea.Height - layoutHeight) / 2;
|
||||||
|
|
||||||
Style.PaintLayout (Style, GdkWindow, State,
|
StyleContext.RenderLayout (cr, layout_x, layout_y, Layout);
|
||||||
true, exposeArea, this, null,
|
|
||||||
titleArea.X, titleArea.Y, Layout);
|
|
||||||
}
|
|
||||||
|
|
||||||
return base.OnExposeEvent (args);
|
return base.OnDrawn (cr);
|
||||||
}
|
|
||||||
|
|
||||||
protected override void OnRealized ()
|
|
||||||
{
|
|
||||||
WidgetFlags |= WidgetFlags.Realized;
|
|
||||||
|
|
||||||
GdkWindow = ParentWindow;
|
|
||||||
Style = Style.Attach (GdkWindow);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected override void OnSizeAllocated (Gdk.Rectangle allocation)
|
protected override void OnSizeAllocated (Gdk.Rectangle allocation)
|
||||||
|
@ -161,22 +145,39 @@ class CustomWidget : Bin {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
protected override void OnSizeRequested (ref Requisition requisition)
|
protected override void OnGetPreferredWidth (out int minimum_width, out int natural_width)
|
||||||
{
|
{
|
||||||
requisition.Width = requisition.Height = (int)BorderWidth * 2;
|
minimum_width = natural_width = (int)BorderWidth * 2 + Icon.Width + 1;
|
||||||
requisition.Width += Icon.Width + 1;
|
int layoutWidth, layoutHeight;
|
||||||
|
Layout.GetPixelSize (out layoutWidth, out layoutHeight);
|
||||||
|
|
||||||
|
if (Child != null && Child.Visible) {
|
||||||
|
int child_min_width, child_nat_width;
|
||||||
|
Child.GetPreferredWidth (out child_min_width, out child_nat_width);
|
||||||
|
|
||||||
|
minimum_width += Math.Max (layoutWidth, child_min_width);
|
||||||
|
natural_width += Math.Max (layoutWidth, child_nat_width);
|
||||||
|
} else {
|
||||||
|
minimum_width += layoutWidth;
|
||||||
|
natural_width += layoutWidth;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
protected override void OnGetPreferredHeight (out int minimum_height, out int natural_height)
|
||||||
|
{
|
||||||
|
minimum_height = natural_height = (int)BorderWidth * 2;
|
||||||
|
|
||||||
int layoutWidth, layoutHeight;
|
int layoutWidth, layoutHeight;
|
||||||
Layout.GetPixelSize (out layoutWidth, out layoutHeight);
|
Layout.GetPixelSize (out layoutWidth, out layoutHeight);
|
||||||
requisition.Height += layoutHeight;
|
minimum_height += layoutHeight;
|
||||||
|
natural_height += layoutHeight;
|
||||||
|
|
||||||
if (Child != null && Child.Visible) {
|
if (Child != null && Child.Visible) {
|
||||||
Requisition childReq = Child.SizeRequest ();
|
int child_min_height, child_nat_height;
|
||||||
requisition.Height += childReq.Height;
|
Child.GetPreferredHeight (out child_min_height, out child_nat_height);
|
||||||
|
|
||||||
requisition.Width += Math.Max (layoutWidth, childReq.Width);
|
minimum_height += Math.Max (layoutHeight, child_min_height);
|
||||||
} else {
|
natural_height += Math.Max (layoutHeight, child_nat_height);
|
||||||
requisition.Width += layoutWidth;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -8,7 +8,7 @@ DOTNET_TARGETS=
|
||||||
DOTNET_ASSEMBLY=
|
DOTNET_ASSEMBLY=
|
||||||
endif
|
endif
|
||||||
|
|
||||||
TARGETS = gtk-hello-world.exe button.exe calendar.exe subclass.exe menu.exe treeviewdemo.exe managedtreeviewdemo.exe nodeviewdemo.exe treemodeldemo.exe actions.exe spawn.exe assistant.exe registerprop.exe gexceptiontest.exe native-instantiation.exe polarfixed.exe cairo-sample.exe scribble.exe testdnd.exe custom-cellrenderer.exe #custom-widget.exescribble-xinput.exe $(DOTNET_TARGETS)
|
TARGETS = gtk-hello-world.exe button.exe calendar.exe subclass.exe menu.exe treeviewdemo.exe managedtreeviewdemo.exe nodeviewdemo.exe treemodeldemo.exe actions.exe spawn.exe assistant.exe registerprop.exe gexceptiontest.exe native-instantiation.exe polarfixed.exe cairo-sample.exe scribble.exe testdnd.exe custom-cellrenderer.exe custom-widget.exe #scribble-xinput.exe $(DOTNET_TARGETS)
|
||||||
|
|
||||||
DEBUGS = $(addsuffix .mdb, $(TARGETS))
|
DEBUGS = $(addsuffix .mdb, $(TARGETS))
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue