2005-04-26 Miguel de Icaza <miguel@novell.com>

* gtkdotnet/Graphics.cs: Contribution from Sebastian Faltoni
	<sebastian.faltoni@gmail.com> that implements support for using
	System.Drawing on Windows.


svn path=/trunk/gtk-sharp/; revision=43619
This commit is contained in:
Miguel de Icaza 2005-04-26 19:54:31 +00:00
parent f88799c77e
commit 01b62e8572
2 changed files with 60 additions and 19 deletions

View file

@ -1,3 +1,9 @@
2005-04-26 Miguel de Icaza <miguel@novell.com>
* gtkdotnet/Graphics.cs: Contribution from Sebastian Faltoni
<sebastian.faltoni@gmail.com> that implements support for using
System.Drawing on Windows.
2005-04-26 Mike Kestner <mkestner@novell.com> 2005-04-26 Mike Kestner <mkestner@novell.com>
* gtk/NodeStore.cs : implement IEnumerable. * gtk/NodeStore.cs : implement IEnumerable.

View file

@ -33,6 +33,15 @@ namespace Gtk.DotNet {
private Graphics () {} private Graphics () {}
[DllImport("libgdk-win32-2.0-0.dll")]
internal static extern IntPtr gdk_win32_drawable_get_handle(IntPtr raw);
[DllImport("libgdk-win32-2.0-0.dll")]
internal static extern IntPtr gdk_win32_hdc_get(IntPtr drawable, IntPtr gc, int usage);
[DllImport("libgdk-win32-2.0-0.dll")]
internal static extern void gdk_win32_hdc_release(IntPtr drawable,IntPtr gc,int usage);
[DllImport("libgdk-win32-2.0-0.dll")] [DllImport("libgdk-win32-2.0-0.dll")]
internal static extern IntPtr gdk_x11_drawable_get_xdisplay (IntPtr raw); internal static extern IntPtr gdk_x11_drawable_get_xdisplay (IntPtr raw);
@ -40,29 +49,55 @@ namespace Gtk.DotNet {
internal static extern IntPtr gdk_x11_drawable_get_xid (IntPtr raw); internal static extern IntPtr gdk_x11_drawable_get_xid (IntPtr raw);
public static System.Drawing.Graphics FromDrawable (Gdk.Drawable drawable) public static System.Drawing.Graphics FromDrawable (Gdk.Drawable drawable)
{
return FromDrawable (drawable, true);
}
public static System.Drawing.Graphics FromDrawable(Gdk.Drawable drawable, bool double_buffered)
{ {
IntPtr x_drawable; IntPtr x_drawable;
int x_off = 0, y_off = 0; int x_off = 0, y_off = 0;
PlatformID osversion = Environment.OSVersion.Platform;
if (drawable is Gdk.Window) if (osversion == PlatformID.Win32Windows || osversion == PlatformID.Win32NT ||
((Gdk.Window) drawable).GetInternalPaintInfo(out drawable, out x_off, out y_off); osversion == PlatformID.Win32S || osversion == PlatformID.WinCE){
if (drawable is Gdk.Window && double_buffered)
((Gdk.Window)drawable).GetInternalPaintInfo(out drawable, out x_off, out y_off);
x_drawable = drawable.Handle; Gdk.GC gcc = new Gdk.GC(drawable);
IntPtr display = gdk_x11_drawable_get_xdisplay (x_drawable); IntPtr windc = gdk_win32_hdc_get(drawable.Handle, gcc.Handle, 0);
Type graphics = typeof (System.Drawing.Graphics); System.Drawing.Graphics g = System.Drawing.Graphics.FromHdc(windc);
MethodInfo mi = graphics.GetMethod ("FromXDrawable", BindingFlags.Static | BindingFlags.NonPublic);
if (mi == null)
throw new NotImplementedException ("In this implementation I can not get a graphics from a drawable");
object [] args = new object [2] { (IntPtr) gdk_x11_drawable_get_xid (drawable.Handle), (IntPtr) display };
object r = mi.Invoke (null, args);
System.Drawing.Graphics g = (System.Drawing.Graphics) r;
g.TranslateTransform (-x_off, -y_off); if (double_buffered) {
gdk_win32_hdc_release(drawable.Handle, gcc.Handle, 0);
}
return g; g.TranslateTransform(-x_off, -y_off);
return g;
} else {
if (drawable is Gdk.Window && double_buffered)
((Gdk.Window) drawable).GetInternalPaintInfo(out drawable, out x_off, out y_off);
x_drawable = drawable.Handle;
IntPtr display = gdk_x11_drawable_get_xdisplay (x_drawable);
Type graphics = typeof (System.Drawing.Graphics);
MethodInfo mi = graphics.GetMethod ("FromXDrawable", BindingFlags.Static | BindingFlags.NonPublic);
if (mi == null)
throw new NotImplementedException ("In this implementation I can not get a graphics from a drawable");
object [] args = new object [2] { (IntPtr) gdk_x11_drawable_get_xid (drawable.Handle), (IntPtr) display };
object r = mi.Invoke (null, args);
System.Drawing.Graphics g = (System.Drawing.Graphics) r;
g.TranslateTransform (-x_off, -y_off);
return g;
}
} }
} }