summaryrefslogtreecommitdiff
path: root/gtk/gtkfontchooserdialog.c
diff options
context:
space:
mode:
authorAlberto Ruiz <aruiz@gnome.org>2011-05-11 22:52:39 +0200
committerMatthias Clasen <mclasen@redhat.com>2011-08-15 18:57:55 -0400
commit4add47946bf225ae6c1a9d51808c5e561faef68d (patch)
tree9cde30348ade33bdffdf51a914816ea2dd491020 /gtk/gtkfontchooserdialog.c
parent8e621f593e4a61c95c93d0f7dcfcd1eed15194e5 (diff)
downloadgtk+-4add47946bf225ae6c1a9d51808c5e561faef68d.tar.gz
GtkFontChooserDialog: Split the dialog out of gtkfontchooser.[ch] to gtkfontchooserdialog.[ch]
Diffstat (limited to 'gtk/gtkfontchooserdialog.c')
-rw-r--r--gtk/gtkfontchooserdialog.c312
1 files changed, 312 insertions, 0 deletions
diff --git a/gtk/gtkfontchooserdialog.c b/gtk/gtkfontchooserdialog.c
new file mode 100644
index 0000000000..1df7fbbd6f
--- /dev/null
+++ b/gtk/gtkfontchooserdialog.c
@@ -0,0 +1,312 @@
+/* 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>
+ */
+
+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
+ */
+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);
+}