still removing gnome tutorial...
svn path=/trunk/gtk-sharp/; revision=9882
This commit is contained in:
parent
b24d8bbd03
commit
066adcd286
6 changed files with 0 additions and 284 deletions
Binary file not shown.
Before Width: | Height: | Size: 10 KiB |
Binary file not shown.
Before Width: | Height: | Size: 13 KiB |
Binary file not shown.
Before Width: | Height: | Size: 11 KiB |
|
@ -1,284 +0,0 @@
|
||||||
<html>
|
|
||||||
<head>
|
|
||||||
<title>The Gnome.NET Tutorial</title>
|
|
||||||
|
|
||||||
<link rel="stylesheet" type="text/css" href="../../style.css" />
|
|
||||||
|
|
||||||
</head>
|
|
||||||
<body>
|
|
||||||
|
|
||||||
<table bgcolor=#BEBAA8 width=100% >
|
|
||||||
<tr><td><a href="../../../index.html"><img src="../../../mg.png" border=0></a><a href="../../index.html"><img src="../../gn.png" border=0></a></td></tr>
|
|
||||||
</table>
|
|
||||||
<table bgcolor=#efefef width=100% >
|
|
||||||
<tr><td class="navbar"><a href="../../../index.html">Monkeyguide</a> > <a href="../../index.html">GNOME.NET</a> > C# bindings > <b>Glade#</b></tr>
|
|
||||||
</table>
|
|
||||||
<p>
|
|
||||||
|
|
||||||
<table>
|
|
||||||
<tr>
|
|
||||||
<td><img src="icon.png" /></td>
|
|
||||||
<td>
|
|
||||||
<h1>Glade - Rapid Application Development with Gnome 2</h1>
|
|
||||||
|
|
||||||
by Johannes Roith (<a
|
|
||||||
href="mailto:johannes@jroith.de">johannes@jroith.de</a>)</td>
|
|
||||||
</tr>
|
|
||||||
</table>
|
|
||||||
|
|
||||||
<h2>Introduction</h2>
|
|
||||||
|
|
||||||
In the previous chapter, you learned how create a Gnome GUI. If
|
|
||||||
you've worked with Visual Studio, Delphi/Kylix or Visual Basic
|
|
||||||
you might be missing the easy way of dragging widgets on
|
|
||||||
forms.<br />
|
|
||||||
<br />
|
|
||||||
You're right, after all, what we want to do is creating good
|
|
||||||
applications <u>faster</u> with mono. Development , where the
|
|
||||||
programmer gets assistance in non-coding tasks from (visual)
|
|
||||||
tools and focuses on the real work is called RAD - Rapid
|
|
||||||
Application Development. Gnome offers a set of such technologies,
|
|
||||||
known as Glade. <br />
|
|
||||||
<br />
|
|
||||||
Glade consists of 2 part:<br />
|
|
||||||
<ul>
|
|
||||||
<li>Glade - a grafical editor to create forms and save them in
|
|
||||||
XML files.</li>
|
|
||||||
|
|
||||||
<li>libglade (called Glade# in Gtk#) - a library to load the XML
|
|
||||||
at runtime<br />
|
|
||||||
and dynamically create the form.</li>
|
|
||||||
</ul>
|
|
||||||
|
|
||||||
That means, the user will need have libglade installed, and the
|
|
||||||
xml file must be distributed with the application. Glade# is the
|
|
||||||
C# binding for libglade and even offers some advanced features -
|
|
||||||
like self-contained glade files - that are only available in
|
|
||||||
Gtk#.<br />
|
|
||||||
<br />
|
|
||||||
Language independence has always been a goal in Gnome
|
|
||||||
Development. For that reason the Glade Interface Builder exports
|
|
||||||
xml, that can be used with any language with glade bindings. This
|
|
||||||
benefit is bought with little more effort compared to Visual
|
|
||||||
Studio, as the code can't be generated automatically. <br />
|
|
||||||
<br />
|
|
||||||
<h2>Creating the UI</h2>
|
|
||||||
|
|
||||||
<table cellpadding="5" border="0">
|
|
||||||
<tr>
|
|
||||||
<td valign="top"><img src="glade-palette.png" border="0" /></td>
|
|
||||||
<td valign="top">Before we try to use glade with our Project,
|
|
||||||
first get some experience with it. Fire up the Glade Interface
|
|
||||||
Designer. You will be greeted by three windows: the main window,
|
|
||||||
a properites and a palette window, containing icons. Click
|
|
||||||
Project - New and select "Gnome Project".<br />
|
|
||||||
<br />
|
|
||||||
To create a new window click on the first icon in the
|
|
||||||
palette-window. The new window is shown in the list. You can
|
|
||||||
modify Type, Position, Caption, and other things in the
|
|
||||||
Properties window.<br />
|
|
||||||
<br />
|
|
||||||
If you want your application to quit, if the window is closed
|
|
||||||
you'll have to connect a signal with an event handler. Select
|
|
||||||
"Signals" and add a handler for "delete_event" and call it
|
|
||||||
"OnWindowDeleteEvent".<br />
|
|
||||||
<br />
|
|
||||||
Take a button and drop it on the window. As you know, gtk+ has
|
|
||||||
the concept of invisible boxes, to position widgets, and for that
|
|
||||||
reason the button will fill the whole window. Modify some
|
|
||||||
properties and add a signal handler for "clicked" and call it
|
|
||||||
"OnButton1Clicked".<br />
|
|
||||||
<br />
|
|
||||||
Save to a new directory. Glade will put 2 files there:
|
|
||||||
[projectname].glade and [projectname].gladep, wich does only save
|
|
||||||
some information for the Interface Builder. The "interesting"
|
|
||||||
file is the .glade file, that you can open in any text editor.
|
|
||||||
It's plain XML and looks like that:<br />
|
|
||||||
<br />
|
|
||||||
</td>
|
|
||||||
<td valign="top"><img src="glade-m.png" border="0" /><br />
|
|
||||||
<img src="glade-properties.png" border="0" /></td>
|
|
||||||
</tr>
|
|
||||||
</table>
|
|
||||||
|
|
||||||
<pre class="code">
|
|
||||||
<?xml version="1.0" standalone="no"?> <!--*- mode: xml -*-->
|
|
||||||
<!DOCTYPE glade-interface SYSTEM "http://glade.gnome.org/glade-2.0.dtd">
|
|
||||||
|
|
||||||
<glade-interface>
|
|
||||||
|
|
||||||
<widget class="GtkWindow" id="window2">
|
|
||||||
<property name="visible">True</property>
|
|
||||||
<property name="title" translatable="yes">window2</property>
|
|
||||||
<property name="type">GTK_WINDOW_TOPLEVEL</property>
|
|
||||||
<property name="window_position">GTK_WIN_POS_NONE</property>
|
|
||||||
<property name="modal">False</property>
|
|
||||||
<property name="resizable">True</property>
|
|
||||||
<property name="destroy_with_parent">False</property>
|
|
||||||
|
|
||||||
<child>
|
|
||||||
<widget class="GtkButton" id="button1">
|
|
||||||
<property name="border_width">10</property>
|
|
||||||
<property name="visible">True</property>
|
|
||||||
<property name="can_focus">True</property>
|
|
||||||
<property name="label" translatable="yes">button1</property>
|
|
||||||
<property name="use_underline">True</property>
|
|
||||||
<property name="relief">GTK_RELIEF_NORMAL</property>
|
|
||||||
</widget>
|
|
||||||
</child>
|
|
||||||
</widget>
|
|
||||||
|
|
||||||
</glade-interface>
|
|
||||||
</pre>
|
|
||||||
|
|
||||||
<br />
|
|
||||||
<h2>It's time to start coding</h2>
|
|
||||||
|
|
||||||
The code is similiar to previous chapters. What has changed is,
|
|
||||||
that most of the code is move to the GladeTest constructor.
|
|
||||||
That's because the main-method is <b>static</b> and therefor
|
|
||||||
doesn't belong to any class. Altough possible, moving code to
|
|
||||||
Main() would only lead to more complicated code.<br />
|
|
||||||
<pre class="code">
|
|
||||||
namespace GladeSamples {
|
|
||||||
using System;
|
|
||||||
|
|
||||||
using Gtk;
|
|
||||||
using Gnome;
|
|
||||||
using Glade;
|
|
||||||
using GtkSharp;
|
|
||||||
|
|
||||||
public class GladeTest
|
|
||||||
{
|
|
||||||
|
|
||||||
public static void Main (string[] args)
|
|
||||||
{
|
|
||||||
new GladeTest(args);
|
|
||||||
}
|
|
||||||
public GladeTest (string[] args)
|
|
||||||
{
|
|
||||||
|
|
||||||
Application.Init();
|
|
||||||
|
|
||||||
/* This loads the glade file glade.glade, selects window2 and connects it to the current object,
|
|
||||||
* which is the class GladeTest here. */
|
|
||||||
|
|
||||||
<b>Glade.XML gxml = new Glade.XML ("file.glade", "window2", null);
|
|
||||||
gxml.Autoconnect (this);</b>
|
|
||||||
|
|
||||||
Application.Run();
|
|
||||||
|
|
||||||
/* If you want to access the glade objects you have to "import" them.
|
|
||||||
* This is not required, but else you can only work with the pre-defined signal handlers */
|
|
||||||
|
|
||||||
Button button1 = (Gtk.Button) gxml["button1"];
|
|
||||||
|
|
||||||
button1.BorderWidth=10;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* Connect the Signals defined in Glade */
|
|
||||||
|
|
||||||
|
|
||||||
public void OnWindowDeleteEvent (object o, DeleteEventArgs args)
|
|
||||||
{
|
|
||||||
Application.Quit ();
|
|
||||||
args.RetVal = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void OnButton1Clicked (System.Object obj, EventArgs e)
|
|
||||||
{
|
|
||||||
Console.WriteLine ("Button 1 clicked");
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
</pre>
|
|
||||||
|
|
||||||
<br />
|
|
||||||
compile with:
|
|
||||||
<table border="0">
|
|
||||||
<tr>
|
|
||||||
<td><img src="sample1.png" border="border" /></td>
|
|
||||||
<td>
|
|
||||||
<pre>
|
|
||||||
mcs /unsafe -r gtk-sharp.dll -r glade-sharp.dll glade.cs
|
|
||||||
</pre>
|
|
||||||
</td>
|
|
||||||
</tr>
|
|
||||||
</table>
|
|
||||||
|
|
||||||
<br />
|
|
||||||
Of course, include the Gnome and Glade namespaces.
|
|
||||||
<pre class="code">
|
|
||||||
using Gnome;
|
|
||||||
using Glade;
|
|
||||||
</pre>
|
|
||||||
|
|
||||||
The first part inits the Application.<br />
|
|
||||||
Then the glade xml file is connected. The first param is the
|
|
||||||
file, the second the main widget (here: the window). The second
|
|
||||||
line connects gxml to the current object.
|
|
||||||
<pre class="code">
|
|
||||||
Glade.XML gxml = new Glade.XML ("file.glade", "window2", null);
|
|
||||||
gxml.Autoconnect (this);
|
|
||||||
</pre>
|
|
||||||
|
|
||||||
Altough glade will show all widgets and cares about the events
|
|
||||||
defined, most likely you will want to change properties, or add
|
|
||||||
events during the runtime. For that to work you have to connect a
|
|
||||||
new object to the glade widget. This example also sets the
|
|
||||||
BorderWidth.
|
|
||||||
<pre class="code">
|
|
||||||
Button button1 = (Gtk.Button) gxml["button1"];
|
|
||||||
button1.BorderWidth=10;
|
|
||||||
</pre>
|
|
||||||
|
|
||||||
That's it.<br />
|
|
||||||
<br />
|
|
||||||
|
|
||||||
<h2>Available Widgets</h2>
|
|
||||||
|
|
||||||
All available widgets are devided in 4 categories. If you want
|
|
||||||
your application to be independent of gnome and portable to
|
|
||||||
windows, or Mac OS X, use only Gtk+ and Gtk+ Additional. If you
|
|
||||||
don't need that flexibility I strongly encourage you to make also
|
|
||||||
use of the Gnome category. That includes Font-Selector, Druids,
|
|
||||||
Iconlists and other useful things.<br />
|
|
||||||
<br />
|
|
||||||
Glade can be extened, for example gnome-db extensions are
|
|
||||||
available.
|
|
||||||
<h2>Using Glade in our Project</h2>
|
|
||||||
|
|
||||||
After explaining how it works, like in the other chapters we want
|
|
||||||
to go on with our little Project, introducing the new learned
|
|
||||||
technology and extending the knowledge. This chapter removes the
|
|
||||||
few UI bits, done by hand and adds an Interface using Glade.
|
|
||||||
<br />
|
|
||||||
<br />
|
|
||||||
[TODO] <br />
|
|
||||||
<br />
|
|
||||||
|
|
||||||
<h2>Didn't you say something about this self-contained
|
|
||||||
thing?</h2>
|
|
||||||
|
|
||||||
Yes, I did. And it's quite a good feature. Now, that we're using
|
|
||||||
Glade our application consists not only of 1, but 2 files.
|
|
||||||
Luckily, the CLR has a way, to embedd any file in the executable,
|
|
||||||
like images or text files. Glade offer an additional constructor
|
|
||||||
to load the glade file from a resource, so you don't have to
|
|
||||||
distribute it. The only difference is the "null" before the
|
|
||||||
filename.
|
|
||||||
<pre class="code">
|
|
||||||
Glade.XML gxml = new Glade.XML (<b>null</b>, "file.glade", "window2", null);
|
|
||||||
gxml.Autoconnect (this);
|
|
||||||
</pre>
|
|
||||||
|
|
||||||
You have then to compile the file in, with the resource switch.
|
|
||||||
<pre>
|
|
||||||
mcs /unsafe /resource:glade.glade -r gtk-sharp.dll -r glade-sharp.dll glade.cs
|
|
||||||
</pre>
|
|
||||||
</body>
|
|
||||||
</html>
|
|
||||||
|
|
Binary file not shown.
Before Width: | Height: | Size: 3.7 KiB |
Binary file not shown.
Before Width: | Height: | Size: 1.9 KiB |
Loading…
Add table
Reference in a new issue