summaryrefslogtreecommitdiff
path: root/gtk/gtkfontsel.h
diff options
context:
space:
mode:
Diffstat (limited to 'gtk/gtkfontsel.h')
-rw-r--r--gtk/gtkfontsel.h147
1 files changed, 108 insertions, 39 deletions
diff --git a/gtk/gtkfontsel.h b/gtk/gtkfontsel.h
index b54d8762e8..70e822e722 100644
--- a/gtk/gtkfontsel.h
+++ b/gtk/gtkfontsel.h
@@ -68,10 +68,41 @@ typedef struct _GtkFontSelectionDialogClass GtkFontSelectionDialogClass;
/* Used to determine whether we are using point or pixel sizes. */
typedef enum
{
- PIXELS_METRIC,
- POINTS_METRIC
+ GTK_FONT_METRIC_PIXELS,
+ GTK_FONT_METRIC_POINTS
} GtkFontMetricType;
+/* Used for determining the type of a font style, and also for setting filters.
+ These can be combined if a style has bitmaps and scalable fonts available.*/
+typedef enum
+{
+ GTK_FONT_BITMAP = 1 << 0,
+ GTK_FONT_SCALABLE = 1 << 1,
+ GTK_FONT_SCALABLE_BITMAP = 1 << 2,
+
+ GTK_FONT_ALL = 0x07
+} GtkFontType;
+
+/* These are the two types of filter available - base and user. The base
+ filter is set by the application and can't be changed by the user. */
+#define GTK_NUM_FONT_FILTERS 2
+typedef enum
+{
+ GTK_FONT_FILTER_BASE,
+ GTK_FONT_FILTER_USER
+} GtkFontFilterType;
+
+/* These hold the arrays of current filter settings for each property.
+ If nfilters is 0 then all values of the property are OK. If not the
+ filters array contains the indexes of the valid property values. */
+typedef struct _GtkFontFilter GtkFontFilter;
+struct _GtkFontFilter
+{
+ gint font_type;
+ guint16 *property_filters[GTK_NUM_FONT_PROPERTIES];
+ guint16 property_nfilters[GTK_NUM_FONT_PROPERTIES];
+};
+
struct _GtkFontSelection
{
@@ -89,7 +120,6 @@ struct _GtkFontSelection
GtkWidget *pixels_button;
GtkWidget *points_button;
GtkWidget *filter_button;
- GtkWidget *scaled_bitmaps_button;
GtkWidget *preview_entry;
GtkWidget *message_label;
@@ -101,6 +131,9 @@ struct _GtkFontSelection
/* These are on the filter page. */
GtkWidget *filter_vbox;
+ GtkWidget *type_bitmaps_button;
+ GtkWidget *type_scalable_button;
+ GtkWidget *type_scaled_bitmaps_button;
GtkWidget *filter_clists[GTK_NUM_FONT_PROPERTIES];
GdkFont *font;
@@ -114,22 +147,12 @@ struct _GtkFontSelection
fonts we try to find the nearest size to this. */
gint selected_size;
- /* This flag determines if scaled bitmapped fonts are acceptable. */
- gboolean scale_bitmapped_fonts;
-
/* These are the current property settings. They are indexes into the
strings in the GtkFontSelInfo properties array. */
guint16 property_values[GTK_NUM_STYLE_PROPERTIES];
- /* These hold the arrays of current filter settings for each property.
- If nfilters is 0 then all values of the property are OK. If not the
- filters array contains the indexes of the valid property values. */
- guint16 *property_filters[GTK_NUM_FONT_PROPERTIES];
- guint16 property_nfilters[GTK_NUM_FONT_PROPERTIES];
-
- /* This flags is set to scroll the clist to the selected value as soon as
- it appears. There might be a better way of doing this. */
- gboolean scroll_on_expose;
+ /* These are the base and user font filters. */
+ GtkFontFilter filters[GTK_NUM_FONT_FILTERS];
};
@@ -164,52 +187,98 @@ struct _GtkFontSelectionDialogClass
-/* FontSelection */
+/*****************************************************************************
+ * GtkFontSelection functions.
+ * see the comments in the GtkFontSelectionDialog functions.
+ *****************************************************************************/
GtkType gtk_font_selection_get_type (void);
GtkWidget* gtk_font_selection_new (void);
-
-/* This returns the X Logical Font Description fontname, or NULL if no font
- is selected. Note that there is a slight possibility that the font might not
- have been loaded OK. You should call gtk_font_selection_get_font() to see
- if it has been loaded OK.
- You should g_free() the returned font name after you're done with it. */
gchar* gtk_font_selection_get_font_name (GtkFontSelection *fontsel);
-
-/* This will return the current GdkFont, or NULL if none is selected or there
- was a problem loading it. Remember to use gdk_font_ref/unref() if you want
- to use the font (in a style, for example). */
GdkFont* gtk_font_selection_get_font (GtkFontSelection *fontsel);
-
-/* This sets the currently displayed font. It should be a valid X Logical
- Font Description font name (anything else will be ignored), e.g.
- "-adobe-courier-bold-o-normal--25-*-*-*-*-*-*-*"
- It returns TRUE on success. */
gboolean gtk_font_selection_set_font_name (GtkFontSelection *fontsel,
const gchar *fontname);
-
-/* This returns the text in the preview entry. You should copy the returned
- text if you need it. */
+void gtk_font_selection_set_filter (GtkFontSelection *fontsel,
+ GtkFontFilterType filter_type,
+ GtkFontType font_type,
+ gchar **foundries,
+ gchar **weights,
+ gchar **slants,
+ gchar **setwidths,
+ gchar **spacings,
+ gchar **charsets);
gchar* gtk_font_selection_get_preview_text (GtkFontSelection *fontsel);
-
-/* This sets the text in the preview entry. It will be copied by the entry,
- so there's no need to g_strdup() it first. */
void gtk_font_selection_set_preview_text (GtkFontSelection *fontsel,
const gchar *text);
-/* FontSelectionDialog */
+/*****************************************************************************
+ * GtkFontSelectionDialog functions.
+ * most of these functions simply call the corresponding function in the
+ * GtkFontSelection.
+ *****************************************************************************/
GtkType gtk_font_selection_dialog_get_type (void);
GtkWidget* gtk_font_selection_dialog_new (const gchar *title);
-/* These simply call the corresponding FontSelection function. */
+/* This returns the X Logical Font Description fontname, or NULL if no font
+ is selected. Note that there is a slight possibility that the font might not
+ have been loaded OK. You should call gtk_font_selection_dialog_get_font()
+ to see if it has been loaded OK.
+ You should g_free() the returned font name after you're done with it. */
gchar* gtk_font_selection_dialog_get_font_name (GtkFontSelectionDialog *fsd);
+
+/* This will return the current GdkFont, or NULL if none is selected or there
+ was a problem loading it. Remember to use gdk_font_ref/unref() if you want
+ to use the font (in a style, for example). */
GdkFont* gtk_font_selection_dialog_get_font (GtkFontSelectionDialog *fsd);
+
+/* This sets the currently displayed font. It should be a valid X Logical
+ Font Description font name (anything else will be ignored), e.g.
+ "-adobe-courier-bold-o-normal--25-*-*-*-*-*-*-*"
+ It returns TRUE on success. */
gboolean gtk_font_selection_dialog_set_font_name (GtkFontSelectionDialog *fsd,
const gchar *fontname);
+
+/* This sets one of the font filters, to limit the fonts shown. The filter_type
+ is GTK_FONT_FILTER_BASE or GTK_FONT_FILTER_USER. The font type is a
+ combination of the bit flags GTK_FONT_BITMAP, GTK_FONT_SCALABLE and
+ GTK_FONT_SCALABLE_BITMAP (or GTK_FONT_ALL for all font types).
+ The foundries, weights etc. are arrays of strings containing property
+ values, e.g. 'bold', 'demibold', and *MUST* finish with a NULL.
+ Standard long names are also accepted, e.g. 'italic' instead of 'i'.
+
+ e.g. to allow only fixed-width fonts ('char cell' or 'monospaced') to be
+ selected use:
+
+ gchar *spacings[] = { "c", "m", NULL };
+ gtk_font_selection_dialog_set_filter (GTK_FONT_SELECTION_DIALOG (fontsel),
+ GTK_FONT_FILTER_BASE, GTK_FONT_ALL,
+ NULL, NULL, NULL, NULL, spacings, NULL);
+
+ to allow only true scalable fonts to be selected use:
+
+ gtk_font_selection_dialog_set_filter (GTK_FONT_SELECTION_DIALOG (fontsel),
+ GTK_FONT_FILTER_BASE, GTK_FONT_SCALABLE,
+ NULL, NULL, NULL, NULL, NULL, NULL);
+*/
+void gtk_font_selection_dialog_set_filter (GtkFontSelectionDialog *fsd,
+ GtkFontFilterType filter_type,
+ GtkFontType font_type,
+ gchar **foundries,
+ gchar **weights,
+ gchar **slants,
+ gchar **setwidths,
+ gchar **spacings,
+ gchar **charsets);
+
+/* This returns the text in the preview entry. You should copy the returned
+ text if you need it. */
gchar* gtk_font_selection_dialog_get_preview_text (GtkFontSelectionDialog *fsd);
+
+/* This sets the text in the preview entry. It will be copied by the entry,
+ so there's no need to g_strdup() it first. */
void gtk_font_selection_dialog_set_preview_text (GtkFontSelectionDialog *fsd,
const gchar *text);