forked from AuroraMiddleware/gtk
317 lines
9.9 KiB
C
317 lines
9.9 KiB
C
/* GTK - The GIMP Toolkit
|
|
* Copyright (C) 2011 Alberto Ruiz <aruiz@gnome.org>
|
|
* Copyright (C) 1995-1997 Peter Mattis, Spencer Kimball and Josh MacDonald
|
|
*
|
|
* Massively updated to rework the user interface by Alberto Ruiz, 2011
|
|
* Massively updated for Pango by Owen Taylor, May 2000
|
|
* GtkFontChooser widget for Gtk+, by Damon Chaplin, May 1998.
|
|
* Based on the GnomeFontSelector widget, by Elliot Lee, but major changes.
|
|
* The GnomeFontSelector was derived from app/text_tool.c in the GIMP.
|
|
*
|
|
* This library is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
* License as published by the Free Software Foundation; either
|
|
* version 2 of the License, or (at your option) any later version.
|
|
*
|
|
* This library is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
* Lesser General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
* License along with this library; if not, write to the
|
|
* Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
* Boston, MA 02111-1307, USA.
|
|
*/
|
|
|
|
#include "config.h"
|
|
|
|
#include <stdlib.h>
|
|
#include <glib/gprintf.h>
|
|
#include <string.h>
|
|
|
|
#include <atk/atk.h>
|
|
|
|
#include "gtkfontchooserdialog.h"
|
|
#include "gtkfontchooser.h"
|
|
#include "gtkstock.h"
|
|
#include "gtkintl.h"
|
|
#include "gtkaccessible.h"
|
|
#include "gtkbuildable.h"
|
|
#include "gtkprivate.h"
|
|
#include "gtkwidget.h"
|
|
|
|
struct _GtkFontChooserDialogPrivate
|
|
{
|
|
GtkWidget *fontchooser;
|
|
|
|
GtkWidget *select_button;
|
|
GtkWidget *cancel_button;
|
|
};
|
|
|
|
/**
|
|
* SECTION:gtkfontchooserdlg
|
|
* @Short_description: A dialog box for selecting fonts
|
|
* @Title: GtkFontChooserDialog
|
|
* @See_also: #GtkFontChooser, #GtkDialog
|
|
*
|
|
* The #GtkFontChooserDialog widget is a dialog box for selecting a font.
|
|
*
|
|
* To set the font which is initially selected, use
|
|
* gtk_font_chooser_dialog_set_font_name().
|
|
*
|
|
* To get the selected font use gtk_font_chooser_dialog_get_font_name().
|
|
*
|
|
* To change the text which is shown in the preview area, use
|
|
* gtk_font_chooser_dialog_set_preview_text().
|
|
*
|
|
* <refsect2 id="GtkFontChooserDialog-BUILDER-UI">
|
|
* <title>GtkFontChooserDialog as GtkBuildable</title>
|
|
* The GtkFontChooserDialog implementation of the GtkBuildable interface
|
|
* exposes the embedded #GtkFontChooser as internal child with the
|
|
* name "font_chooser". It also exposes the buttons with the names
|
|
* "select_button" and "cancel_button.
|
|
* </refsect2>
|
|
*
|
|
* Since: 3.2
|
|
*/
|
|
|
|
static void gtk_font_chooser_dialog_buildable_interface_init (GtkBuildableIface *iface);
|
|
static GObject* gtk_font_chooser_dialog_buildable_get_internal_child (GtkBuildable *buildable,
|
|
GtkBuilder *builder,
|
|
const gchar *childname);
|
|
|
|
G_DEFINE_TYPE_WITH_CODE (GtkFontChooserDialog, gtk_font_chooser_dialog,
|
|
GTK_TYPE_DIALOG,
|
|
G_IMPLEMENT_INTERFACE (GTK_TYPE_BUILDABLE,
|
|
gtk_font_chooser_dialog_buildable_interface_init))
|
|
|
|
static GtkBuildableIface *parent_buildable_iface;
|
|
|
|
static void
|
|
gtk_font_chooser_dialog_class_init (GtkFontChooserDialogClass *klass)
|
|
{
|
|
g_type_class_add_private (klass, sizeof (GtkFontChooserDialogPrivate));
|
|
}
|
|
|
|
static void
|
|
gtk_font_chooser_dialog_init (GtkFontChooserDialog *fontchooserdiag)
|
|
{
|
|
GtkFontChooserDialogPrivate *priv;
|
|
GtkDialog *dialog = GTK_DIALOG (fontchooserdiag);
|
|
GtkWidget *action_area, *content_area;
|
|
|
|
fontchooserdiag->priv = G_TYPE_INSTANCE_GET_PRIVATE (fontchooserdiag,
|
|
GTK_TYPE_FONT_CHOOSER_DIALOG,
|
|
GtkFontChooserDialogPrivate);
|
|
priv = fontchooserdiag->priv;
|
|
|
|
content_area = gtk_dialog_get_content_area (dialog);
|
|
action_area = gtk_dialog_get_action_area (dialog);
|
|
|
|
gtk_container_set_border_width (GTK_CONTAINER (dialog), 5);
|
|
gtk_box_set_spacing (GTK_BOX (content_area), 2); /* 2 * 5 + 2 = 12 */
|
|
gtk_container_set_border_width (GTK_CONTAINER (action_area), 5);
|
|
gtk_box_set_spacing (GTK_BOX (action_area), 6);
|
|
|
|
gtk_widget_push_composite_child ();
|
|
|
|
gtk_window_set_resizable (GTK_WINDOW (fontchooserdiag), TRUE);
|
|
|
|
/* Create the content area */
|
|
priv->fontchooser = gtk_font_chooser_new ();
|
|
gtk_container_set_border_width (GTK_CONTAINER (priv->fontchooser), 5);
|
|
gtk_widget_show (priv->fontchooser);
|
|
gtk_box_pack_start (GTK_BOX (content_area),
|
|
priv->fontchooser, TRUE, TRUE, 0);
|
|
|
|
/* Create the action area */
|
|
priv->cancel_button = gtk_dialog_add_button (dialog,
|
|
GTK_STOCK_CANCEL,
|
|
GTK_RESPONSE_CANCEL);
|
|
priv->select_button = gtk_dialog_add_button (dialog,
|
|
_("Select"),
|
|
GTK_RESPONSE_OK);
|
|
gtk_widget_grab_default (priv->select_button);
|
|
|
|
gtk_dialog_set_alternative_button_order (GTK_DIALOG (fontchooserdiag),
|
|
GTK_RESPONSE_OK,
|
|
GTK_RESPONSE_CANCEL,
|
|
-1);
|
|
|
|
gtk_window_set_title (GTK_WINDOW (fontchooserdiag),
|
|
_("Font Selection"));
|
|
|
|
gtk_widget_pop_composite_child ();
|
|
}
|
|
|
|
/**
|
|
* gtk_font_chooser_dialog_new:
|
|
* @title: (allow-none): the title of the dialog window
|
|
*
|
|
* Creates a new #GtkFontChooserDialog.
|
|
*
|
|
* Return value: a new #GtkFontChooserDialog
|
|
*
|
|
* Since: 3.2
|
|
*/
|
|
GtkWidget*
|
|
gtk_font_chooser_dialog_new (const gchar *title)
|
|
{
|
|
GtkFontChooserDialog *fontchooserdiag;
|
|
|
|
fontchooserdiag = g_object_new (GTK_TYPE_FONT_CHOOSER_DIALOG, NULL);
|
|
|
|
if (title)
|
|
gtk_window_set_title (GTK_WINDOW (fontchooserdiag), title);
|
|
|
|
return GTK_WIDGET (fontchooserdiag);
|
|
}
|
|
|
|
/**
|
|
* gtk_font_chooser_dialog_get_font_chooser:
|
|
* @fcd: a #GtkFontChooserDialog
|
|
*
|
|
* Retrieves the #GtkFontChooser widget embedded in the dialog.
|
|
*
|
|
* Returns: (transfer none): the embedded #GtkFontChooser
|
|
*
|
|
* Since: 3.2
|
|
**/
|
|
GtkWidget*
|
|
gtk_font_chooser_dialog_get_font_chooser (GtkFontChooserDialog *fcd)
|
|
{
|
|
g_return_val_if_fail (GTK_IS_FONT_CHOOSER_DIALOG (fcd), NULL);
|
|
|
|
return fcd->priv->fontchooser;
|
|
}
|
|
|
|
static void
|
|
gtk_font_chooser_dialog_buildable_interface_init (GtkBuildableIface *iface)
|
|
{
|
|
parent_buildable_iface = g_type_interface_peek_parent (iface);
|
|
iface->get_internal_child = gtk_font_chooser_dialog_buildable_get_internal_child;
|
|
}
|
|
|
|
static GObject *
|
|
gtk_font_chooser_dialog_buildable_get_internal_child (GtkBuildable *buildable,
|
|
GtkBuilder *builder,
|
|
const gchar *childname)
|
|
{
|
|
GtkFontChooserDialogPrivate *priv;
|
|
|
|
priv = GTK_FONT_CHOOSER_DIALOG (buildable)->priv;
|
|
|
|
if (g_strcmp0 (childname, "select_button") == 0)
|
|
return G_OBJECT (priv->select_button);
|
|
else if (g_strcmp0 (childname, "cancel_button") == 0)
|
|
return G_OBJECT (priv->cancel_button);
|
|
else if (g_strcmp0 (childname, "font_chooser") == 0)
|
|
return G_OBJECT (priv->fontchooser);
|
|
|
|
return parent_buildable_iface->get_internal_child (buildable, builder, childname);
|
|
}
|
|
|
|
/**
|
|
* gtk_font_chooser_dialog_get_font_name:
|
|
* @fcd: a #GtkFontChooserDialog
|
|
*
|
|
* Gets the currently-selected font name.
|
|
*
|
|
* Note that this can be a different string than what you set with
|
|
* gtk_font_chooser_dialog_set_font_name(), as the font chooser widget
|
|
* may normalize font names and thus return a string with a different
|
|
* structure. For example, "Helvetica Italic Bold 12" could be normalized
|
|
* to "Helvetica Bold Italic 12". Use pango_font_description_equal()
|
|
* if you want to compare two font descriptions.
|
|
*
|
|
* Return value: A string with the name of the current font, or %NULL if no
|
|
* font is selected. You must free this string with g_free().
|
|
*
|
|
* Since: 3.2
|
|
*/
|
|
gchar*
|
|
gtk_font_chooser_dialog_get_font_name (GtkFontChooserDialog *fcd)
|
|
{
|
|
GtkFontChooserDialogPrivate *priv;
|
|
|
|
g_return_val_if_fail (GTK_IS_FONT_CHOOSER_DIALOG (fcd), NULL);
|
|
|
|
priv = fcd->priv;
|
|
|
|
return gtk_font_chooser_get_font_name (GTK_FONT_CHOOSER (priv->fontchooser));
|
|
}
|
|
|
|
/**
|
|
* gtk_font_chooser_dialog_set_font_name:
|
|
* @fcd: a #GtkFontChooserDialog
|
|
* @fontname: a font name like "Helvetica 12" or "Times Bold 18"
|
|
*
|
|
* Sets the currently selected font.
|
|
*
|
|
* Return value: %TRUE if the font selected in @fcd is now the
|
|
* @fontname specified, %FALSE otherwise.
|
|
*
|
|
* Since: 3.2
|
|
*/
|
|
gboolean
|
|
gtk_font_chooser_dialog_set_font_name (GtkFontChooserDialog *fcd,
|
|
const gchar *fontname)
|
|
{
|
|
GtkFontChooserDialogPrivate *priv;
|
|
|
|
g_return_val_if_fail (GTK_IS_FONT_CHOOSER_DIALOG (fcd), FALSE);
|
|
g_return_val_if_fail (fontname, FALSE);
|
|
|
|
priv = fcd->priv;
|
|
|
|
return gtk_font_chooser_set_font_name (GTK_FONT_CHOOSER (priv->fontchooser), fontname);
|
|
}
|
|
|
|
/**
|
|
* gtk_font_chooser_dialog_get_preview_text:
|
|
* @fcd: a #GtkFontChooserDialog
|
|
*
|
|
* Gets the text displayed in the preview area.
|
|
*
|
|
* Return value: the text displayed in the preview area.
|
|
* This string is owned by the widget and should not be
|
|
* modified or freed
|
|
*
|
|
* Since: 3.2
|
|
*/
|
|
G_CONST_RETURN gchar*
|
|
gtk_font_chooser_dialog_get_preview_text (GtkFontChooserDialog *fcd)
|
|
{
|
|
GtkFontChooserDialogPrivate *priv;
|
|
|
|
g_return_val_if_fail (GTK_IS_FONT_CHOOSER_DIALOG (fcd), NULL);
|
|
|
|
priv = fcd->priv;
|
|
|
|
return gtk_font_chooser_get_preview_text (GTK_FONT_CHOOSER (priv->fontchooser));
|
|
}
|
|
|
|
/**
|
|
* gtk_font_chooser_dialog_set_preview_text:
|
|
* @fcd: a #GtkFontChooserDialog
|
|
* @text: the text to display in the preview area
|
|
*
|
|
* Sets the text displayed in the preview area.
|
|
*
|
|
* Since: 3.2
|
|
*/
|
|
void
|
|
gtk_font_chooser_dialog_set_preview_text (GtkFontChooserDialog *fcd,
|
|
const gchar *text)
|
|
{
|
|
GtkFontChooserDialogPrivate *priv;
|
|
|
|
g_return_if_fail (GTK_IS_FONT_CHOOSER_DIALOG (fcd));
|
|
g_return_if_fail (text != NULL);
|
|
|
|
priv = fcd->priv;
|
|
|
|
gtk_font_chooser_set_preview_text (GTK_FONT_CHOOSER (priv->fontchooser), text);
|
|
}
|