Sophie

Sophie

distrib > Mandriva > 2010.0 > i586 > media > contrib-release > by-pkgid > 1bbf51ece72e40a5f40ad48678e7c5a5 > files > 653

libgnome32-devel-1.4.2-22mdv2009.1.i586.rpm

<!-- ##### SECTION Title ##### -->
GnomePropertyBox

<!-- ##### SECTION Short_Description ##### -->

Standarized dialog box for handling configuration

<!-- ##### SECTION Long_Description ##### -->
  <para>
    The <type>GnomePropertyBox</type> widget simplifies coding a
    consistent dialog box for configuring properties of any kind.
  </para>
  
  <para>
    The <type>GnomePropertyBox</type> is a toplevel widget (it will
    create its own window), inside it contains a <type>GtkNotebook</type>
    which is used to hold the various property pages.
  </para>
  
  <para>
    The box will include ok, cancel, apply and help buttons (the
    actual buttons depends on the settings the user has, for example,
    apply can be hidden).  The ok and apply buttons will start up in
    non-sensitive state, the programmer needs to configure the widgets
    inserted into the property box to inform the widget of any state
    changes to enable the ok and apply buttons.  This is done by
    calling the gnome_property_box_changed() function.
  </para>

  <para>
    To use this widget, you create the widget using
    gnome_property_box_new() and then you call
    gnome_property_box_append_page() for each property page you want
    in the property box.
  </para>

  <para>
    The widget emits two signals: "apply" and "help".  To make a
    functional dialog box you will want to connect to at least the
    "apply" signal. Your function will be invoked once for each page
    and one more time at the end, passing a special value of -1 for
    the page number.
  </para>

  <para>Here is a sample callback routine layout

    <example>
      <title>Sample callback for the "apply" signal</title>
      <programlisting>
void
dialog_apply_callback (GnomePropertyBox *property_box, gint page_num)
{
        switch (page_num){
	case 0:
	        apply_changes_page_0 (property_box);
		break;
	case 1:
	        apply_changes_page_1 (property_box);
		break;
	default:
	}
}
      </programlisting>
    </example>
  </para>

  <para>Some people just check for the last condition like this:
    <example>
      <title>Sample callback for the "apply" signal</title>
      <programlisting>
void
dialog_apply_callback (GnomePropertyBox *property_box, gint page_num)
{
        if (page_num != -1)
                return;

        apply_all_changes (property_box);
}
      </programlisting>
    </example>
  </para>
  
  <para>
    A fully finished program should also hook up to the "help" signal
    to provide context sensitive help in the dialog box.  This signal
    also receives the page number in which the help is invoked, so you
    can provide different help nodes for each page if you desire to do
    so.
  </para>

  <para>
    The GNOME libraries include a number of helper routines that will
    help you provide help in your application.  Here is a sample piece
    of code:

    <example>
      <title>Sample callback for the "help" signal</title>
      <programlisting>
void
dialog_help_callback (GnomePropertyBox *property_box, gint page_num)
{
        GnomeHelpMenuEntry help_entry_page_0 = { "application-id", "page-0-help" };
	GnomeHelpMenuEntry help_entry_page_1 = { "application-id", "page-1-help" };

	switch (page_num){
	case 0:
	       gnome_help_display (0, help_entry_page_0);
	       break;

	case 1:
	       gnome_help_display (0, help_entry_page_1);
	       break;
        }
}
      </programlisting>
    </example>

    The value "0" in the example above is ignored by the
    gnome_help_display routines.  This is done so that you can use a
    hack to connect to help in simpler situations without having to
    provide a full callback (like in this example).
  </para>

  <para>
    You can actually save some time if you use the
    gnome_help_pbox_display() routine.  This routine is designed to
    work side-by-side with the <type>GnomePropertyBox</type> object.
    It works like this:

    <example>
      <title>Connecting the "help" signal using the
	gnome_help_pbox_display() routine</title>
      <programlisting>
void
property_dialog_do_connections (GnomePropertyBox *property_box)
{
        static GnomeHelpMenuEntry help_entry = { "application-id", "base-name" };

	gtk_signal_connect (GTK_OBJECT (property_box), "help",
	                    GTK_SIGNAL_FUNC(gnome_help_pbox_display), &amp;help_entry);
}
      </programlisting>
    </example>

    This will use the "base-name" as a template to create the
    fully-qualified name of the help file using the page number as
    part of the filename component (the result is in the form
    "base-name-$pagenum.html", where $pagenum is substituted with the
    page number).
  </para>

  <para>
    See the documentation for gnome_help_pbox_display() for more information
  </para>

<!-- Documentation author, Miguel de Icaza -->

<!-- ##### SECTION See_Also ##### -->
<para>
gnome_help_pbox_display(), gnome_help_display(), #GnomeDialog
</para>

<!-- ##### STRUCT GnomePropertyBox ##### -->
<para>

</para>


<!-- ##### MACRO GNOME_PROPERTY_BOX_DIRTY ##### -->
<para>

</para>



<!-- ##### FUNCTION gnome_property_box_new ##### -->
<para>

</para>

@Returns: 


<!-- ##### FUNCTION gnome_property_box_changed ##### -->
<para>

</para>

@property_box: 


<!-- ##### FUNCTION gnome_property_box_set_state ##### -->
<para>

</para>

@property_box: 
@state: 


<!-- ##### FUNCTION gnome_property_box_append_page ##### -->
<para>

</para>

@property_box: 
@child: 
@tab_label: 
@Returns: 


<!-- ##### SIGNAL GnomePropertyBox::apply ##### -->
<para>
This signal is invoked with the page number that is being applied.
The signal is emited with the special page number -1 when it has
finished emiting the signals for all of the property pages.</para>

@propertybox: the object which received the signal.
@arg1: The page number.

<!-- ##### SIGNAL GnomePropertyBox::help ##### -->
<para>
This signal is invoked when the user clicks on the help button in the
property box.  An argument is passed that identifies the currently
active page number.</para>

<para>
There are a number of utility functions in the module gnome-help that
can help you hook help into your application: gnome_help_pbox_goto()
and gnome_help_pbox_display provide two different ways to hook the
help into this signal.
</para>

@propertybox: the object which received the signal.
@arg1: <!--
Local variables:
mode: sgml
sgml-parent-document: ("../gnomeui-docs.sgml" "book" "sect1" "")
End:
-->