/* GDK - The GIMP Drawing Kit * Copyright (C) 1995-1997 Peter Mattis, Spencer Kimball and Josh MacDonald * * 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. */ /* * Modified by the GTK+ Team and others 1997-2000. See the AUTHORS * file for a list of people on the GTK+ Team. See the ChangeLog * files for a list of changes. These files are distributed with * GTK+ at ftp://ftp.gtk.org/pub/gtk/. */ #include "gdkdisplay.h" #include "gdkfont.h" #include "gdkinternals.h" GType gdk_font_get_type (void) { static GType our_type = 0; if (our_type == 0) our_type = g_boxed_type_register_static ("GdkFont", (GBoxedCopyFunc)gdk_font_ref, (GBoxedFreeFunc)gdk_font_unref); return our_type; } GdkFont* gdk_font_ref (GdkFont *font) { GdkFontPrivate *private; g_return_val_if_fail (font != NULL, NULL); private = (GdkFontPrivate*) font; private->ref_count += 1; return font; } void gdk_font_unref (GdkFont *font) { GdkFontPrivate *private; private = (GdkFontPrivate*) font; g_return_if_fail (font != NULL); g_return_if_fail (private->ref_count > 0); private->ref_count -= 1; if (private->ref_count == 0) _gdk_font_destroy (font); } gint gdk_string_width (GdkFont *font, const gchar *string) { g_return_val_if_fail (font != NULL, -1); g_return_val_if_fail (string != NULL, -1); return gdk_text_width (font, string, _gdk_font_strlen (font, string)); } gint gdk_char_width (GdkFont *font, gchar character) { g_return_val_if_fail (font != NULL, -1); return gdk_text_width (font, &character, 1); } gint gdk_char_width_wc (GdkFont *font, GdkWChar character) { g_return_val_if_fail (font != NULL, -1); return gdk_text_width_wc (font, &character, 1); } gint gdk_string_measure (GdkFont *font, const gchar *string) { g_return_val_if_fail (font != NULL, -1); g_return_val_if_fail (string != NULL, -1); return gdk_text_measure (font, string, _gdk_font_strlen (font, string)); } void gdk_string_extents (GdkFont *font, const gchar *string, gint *lbearing, gint *rbearing, gint *width, gint *ascent, gint *descent) { g_return_if_fail (font != NULL); g_return_if_fail (string != NULL); gdk_text_extents (font, string, _gdk_font_strlen (font, string), lbearing, rbearing, width, ascent, descent); } gint gdk_text_measure (GdkFont *font, const gchar *text, gint text_length) { gint rbearing; g_return_val_if_fail (font != NULL, -1); g_return_val_if_fail (text != NULL, -1); gdk_text_extents (font, text, text_length, NULL, &rbearing, NULL, NULL, NULL); return rbearing; } gint gdk_char_measure (GdkFont *font, gchar character) { g_return_val_if_fail (font != NULL, -1); return gdk_text_measure (font, &character, 1); } gint gdk_string_height (GdkFont *font, const gchar *string) { g_return_val_if_fail (font != NULL, -1); g_return_val_if_fail (string != NULL, -1); return gdk_text_height (font, string, _gdk_font_strlen (font, string)); } gint gdk_text_height (GdkFont *font, const gchar *text, gint text_length) { gint ascent, descent; g_return_val_if_fail (font != NULL, -1); g_return_val_if_fail (text != NULL, -1); gdk_text_extents (font, text, text_length, NULL, NULL, NULL, &ascent, &descent); return ascent + descent; } gint gdk_char_height (GdkFont *font, gchar character) { g_return_val_if_fail (font != NULL, -1); return gdk_text_height (font, &character, 1); } /** * gdk_font_from_description: * @font_desc: a #PangoFontDescription. * * Load a #GdkFont based on a Pango font description. This font will * only be an approximation of the Pango font, and * internationalization will not be handled correctly. This function * should only be used for legacy code that cannot be easily converted * to use Pango. Using Pango directly will produce better results. * * Return value: the newly loaded font, or %NULL if the font * cannot be loaded. **/ GdkFont* gdk_font_from_description (PangoFontDescription *font_desc) { return gdk_font_from_description_for_display (gdk_get_default_display (),font_desc); } GdkFont* gdk_font_load (const gchar *font_name) { return gdk_font_load_for_display (gdk_get_default_display(), font_name); }