summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorOwen Taylor <otaylor@redhat.com>2005-02-24 19:52:40 +0000
committerOwen Taylor <otaylor@src.gnome.org>2005-02-24 19:52:40 +0000
commita1d88c49c68f60982dd8301a913d2930728fc77d (patch)
tree601dac7acc0d6131a413c9ad23171515ca50c432
parentf0653b4131c0c2d811f662785a7b4d971d370bef (diff)
downloadpango-a1d88c49c68f60982dd8301a913d2930728fc77d.tar.gz
PangoCairoFontMap for win32 fonts.
2005-02-24 Owen Taylor <otaylor@redhat.com> * pango/pangocairo-win32.h pango/pangocairo-win32font.c pango/pangocairo-win32fontmap.c pango/Makefile.am: PangoCairoFontMap for win32 fonts. * pango/pangocairo-fontmap.c: Use PangoCairoWin32FontMap when available. * pango/pangowin32.h pango/pangowin32-fontmap.h pango/pangowin32.c: Add virtual pango_win32_font_select_font() to prepare a DC for use with a PangoWin32Font, and to release, pango_win32_font_scale_font() to get logical unit => Pango units scale, pango_win32_font_done_font() to release resources. * pango/pangowin32-fontmap.[ch]: Add a find_font() virtual method to allow subclasses that change how PangoFont lookup and creation happens. * pango/pangowin32-fontmap.c: Move initialization into pango_win32_font_map_init() to facilitate derivation. * pango/pangowin2.c pango/pangowin32-fontmap.c pango/pangowin32-private.h: Move PangoWin32Font/PangoWin32FontMap definitions into pangowin32-private.h to allow derivation for PangoCairoWin32Font. * modules/basic/basic-win32.c: Use pango_win32_font_select_font() and friends. * modules/basic/basic-win32.c: Use g_utf8_to_utf16 instead of g_convert for simplicity and speed. * pango/fonts.c (pango_font_get_font_map) pango/pango-font.h pango/pangofc-font.c pango/pangowin32.c pango/pango.c pango/pango.def docs/pango-sections.txt: Add a virtual function to get the fontmap for a font. * pango/pangocairo-render.c: Use pango_font_get_font_map() rather than PangoFcFontMap hack. * pango/pango-types.h: Move the declaration of PangoFontMap here to avoid interactions between pango-font.h and pango-fontmap.h. * pango/pangocairo.h: Remove accidental include of pangofc-fontmap.h.
-rw-r--r--.cvsignore6
-rw-r--r--ChangeLog47
-rw-r--r--ChangeLog.pre-1-1047
-rw-r--r--docs/pango-sections.txt1
-rw-r--r--modules/basic/basic-win32.c46
-rw-r--r--pango/Makefile.am11
-rw-r--r--pango/fonts.c17
-rw-r--r--pango/pango-font.h3
-rw-r--r--pango/pango-fontmap.h1
-rw-r--r--pango/pango-types.h3
-rw-r--r--pango/pango.def1
-rw-r--r--pango/pangocairo-fontmap.c12
-rw-r--r--pango/pangocairo-render.c4
-rw-r--r--pango/pangocairo-win32.h55
-rw-r--r--pango/pangocairo-win32font.c313
-rw-r--r--pango/pangocairo-win32fontmap.c108
-rw-r--r--pango/pangocairo.h2
-rw-r--r--pango/pangofc-font.c10
-rw-r--r--pango/pangowin32-fontmap.c212
-rw-r--r--pango/pangowin32-private.h69
-rw-r--r--pango/pangowin32.c132
-rw-r--r--pango/pangowin32.def5
-rw-r--r--pango/pangowin32.h5
-rw-r--r--pango/pangox.c9
24 files changed, 940 insertions, 179 deletions
diff --git a/.cvsignore b/.cvsignore
index 717c5eda..b6dbaf12 100644
--- a/.cvsignore
+++ b/.cvsignore
@@ -1,3 +1,4 @@
+compile
configure
config.h
config.h.in
@@ -6,6 +7,11 @@ config.guess
config.log
config.status
config.sub
+depcomp
+install-sh
+missing
+mkinstalldirs
+gtk-doc.make
pango.pc
pangocairo.pc
pangox.pc
diff --git a/ChangeLog b/ChangeLog
index ae2f8cf6..588b3230 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,50 @@
+2005-02-24 Owen Taylor <otaylor@redhat.com>
+
+ * pango/pangocairo-win32.h pango/pangocairo-win32font.c
+ pango/pangocairo-win32fontmap.c pango/Makefile.am:
+ PangoCairoFontMap for win32 fonts.
+
+ * pango/pangocairo-fontmap.c: Use PangoCairoWin32FontMap
+ when available.
+
+ * pango/pangowin32.h pango/pangowin32-fontmap.h pango/pangowin32.c:
+ Add virtual pango_win32_font_select_font()
+ to prepare a DC for use with a PangoWin32Font, and to release,
+ pango_win32_font_scale_font() to get logical unit => Pango units scale,
+ pango_win32_font_done_font() to release resources.
+
+ * pango/pangowin32-fontmap.[ch]: Add a find_font() virtual method
+ to allow subclasses that change how PangoFont lookup and
+ creation happens.
+
+ * pango/pangowin32-fontmap.c: Move initialization into
+ pango_win32_font_map_init() to facilitate derivation.
+
+ * pango/pangowin2.c pango/pangowin32-fontmap.c
+ pango/pangowin32-private.h: Move PangoWin32Font/PangoWin32FontMap
+ definitions into pangowin32-private.h to allow derivation for
+ PangoCairoWin32Font.
+
+ * modules/basic/basic-win32.c: Use pango_win32_font_select_font()
+ and friends.
+
+ * modules/basic/basic-win32.c: Use g_utf8_to_utf16 instead
+ of g_convert for simplicity and speed.
+
+ * pango/fonts.c (pango_font_get_font_map) pango/pango-font.h
+ pango/pangofc-font.c pango/pangowin32.c pango/pango.c pango/pango.def
+ docs/pango-sections.txt: Add a virtual function to get the fontmap
+ for a font.
+
+ * pango/pangocairo-render.c: Use pango_font_get_font_map()
+ rather than PangoFcFontMap hack.
+
+ * pango/pango-types.h: Move the declaration of PangoFontMap here
+ to avoid interactions between pango-font.h and pango-fontmap.h.
+
+ * pango/pangocairo.h: Remove accidental include
+ of pangofc-fontmap.h.
+
2005-02-21 Owen Taylor <otaylor@redhat.com>
* pango/fonts.c (pango_font_get_glyph_extents):
diff --git a/ChangeLog.pre-1-10 b/ChangeLog.pre-1-10
index ae2f8cf6..588b3230 100644
--- a/ChangeLog.pre-1-10
+++ b/ChangeLog.pre-1-10
@@ -1,3 +1,50 @@
+2005-02-24 Owen Taylor <otaylor@redhat.com>
+
+ * pango/pangocairo-win32.h pango/pangocairo-win32font.c
+ pango/pangocairo-win32fontmap.c pango/Makefile.am:
+ PangoCairoFontMap for win32 fonts.
+
+ * pango/pangocairo-fontmap.c: Use PangoCairoWin32FontMap
+ when available.
+
+ * pango/pangowin32.h pango/pangowin32-fontmap.h pango/pangowin32.c:
+ Add virtual pango_win32_font_select_font()
+ to prepare a DC for use with a PangoWin32Font, and to release,
+ pango_win32_font_scale_font() to get logical unit => Pango units scale,
+ pango_win32_font_done_font() to release resources.
+
+ * pango/pangowin32-fontmap.[ch]: Add a find_font() virtual method
+ to allow subclasses that change how PangoFont lookup and
+ creation happens.
+
+ * pango/pangowin32-fontmap.c: Move initialization into
+ pango_win32_font_map_init() to facilitate derivation.
+
+ * pango/pangowin2.c pango/pangowin32-fontmap.c
+ pango/pangowin32-private.h: Move PangoWin32Font/PangoWin32FontMap
+ definitions into pangowin32-private.h to allow derivation for
+ PangoCairoWin32Font.
+
+ * modules/basic/basic-win32.c: Use pango_win32_font_select_font()
+ and friends.
+
+ * modules/basic/basic-win32.c: Use g_utf8_to_utf16 instead
+ of g_convert for simplicity and speed.
+
+ * pango/fonts.c (pango_font_get_font_map) pango/pango-font.h
+ pango/pangofc-font.c pango/pangowin32.c pango/pango.c pango/pango.def
+ docs/pango-sections.txt: Add a virtual function to get the fontmap
+ for a font.
+
+ * pango/pangocairo-render.c: Use pango_font_get_font_map()
+ rather than PangoFcFontMap hack.
+
+ * pango/pango-types.h: Move the declaration of PangoFontMap here
+ to avoid interactions between pango-font.h and pango-fontmap.h.
+
+ * pango/pangocairo.h: Remove accidental include
+ of pangofc-fontmap.h.
+
2005-02-21 Owen Taylor <otaylor@redhat.com>
* pango/fonts.c (pango_font_get_glyph_extents):
diff --git a/docs/pango-sections.txt b/docs/pango-sections.txt
index 7ebd1991..20584dc5 100644
--- a/docs/pango-sections.txt
+++ b/docs/pango-sections.txt
@@ -192,6 +192,7 @@ pango_font_describe
pango_font_get_coverage
pango_font_get_glyph_extents
pango_font_get_metrics
+pango_font_get_font_map
<SUBSECTION>
PangoFontFamily
PANGO_TYPE_FONT_FAMILY
diff --git a/modules/basic/basic-win32.c b/modules/basic/basic-win32.c
index 236532c6..e4ee80c3 100644
--- a/modules/basic/basic-win32.c
+++ b/modules/basic/basic-win32.c
@@ -24,6 +24,7 @@
#define BASIC_WIN32_DEBUGGING
+#include <math.h>
#include <stdlib.h>
#include <glib.h>
@@ -713,6 +714,7 @@ itemize_shape_and_place (PangoFont *font,
SCRIPT_CONTROL control;
SCRIPT_STATE state;
SCRIPT_ITEM items[100];
+ double scale = pango_win32_font_get_scale_factor (font);
memset (&control, 0, sizeof (control));
memset (&state, 0, sizeof (state));
@@ -822,9 +824,9 @@ itemize_shape_and_place (PangoFont *font,
if (iglyphs[glyphix] != 0)
{
glyphs->glyphs[ng+glyphix].glyph = iglyphs[glyphix];
- glyphs->glyphs[ng+glyphix].geometry.width = PANGO_SCALE * advances[glyphix];
- glyphs->glyphs[ng+glyphix].geometry.x_offset = PANGO_SCALE * offsets[glyphix].du;
- glyphs->glyphs[ng+glyphix].geometry.y_offset = PANGO_SCALE * offsets[glyphix].dv;
+ glyphs->glyphs[ng+glyphix].geometry.width = floor (0.5 + scale * advances[glyphix]);
+ glyphs->glyphs[ng+glyphix].geometry.x_offset = floor (0.5 + scale * offsets[glyphix].du);
+ glyphs->glyphs[ng+glyphix].geometry.y_offset = floor (0.5 + scale * offsets[glyphix].dv);
}
else
{
@@ -865,40 +867,19 @@ uniscribe_shape (PangoFont *font,
PangoGlyphString *glyphs)
{
wchar_t *wtext;
- int wlen, i;
+ long wlen;
+ int i;
gboolean retval = TRUE;
- HGDIOBJ old_font = NULL;
- HFONT hfont = NULL;
- LOGFONT *lf;
SCRIPT_CACHE script_cache[100];
- wtext = (wchar_t *) g_convert (text, length, "UTF-16LE", "UTF-8",
- NULL, &wlen, NULL);
- if (wtext == NULL)
+ if (!pango_win32_font_select_font (font, hdc))
return FALSE;
- wlen /= 2;
-
- lf = pango_win32_font_logfont (font);
- hfont = pango_win32_font_cache_load (font_cache, lf);
- g_free (lf);
-
- if (hfont == NULL)
+ wtext = g_utf8_to_utf16 (text, length, NULL, &wlen, NULL);
+ if (wtext == NULL)
retval = FALSE;
if (retval)
- old_font = SelectObject (hdc, hfont);
-
- if (old_font == NULL)
- {
-#ifdef BASIC_WIN32_DEBUGGING
- if (pango_win32_debug)
- printf ("pango-basic-win32: SelectObject for font failed\n");
-#endif
- retval = FALSE;
- }
-
- if (retval)
{
memset (script_cache, 0, sizeof (script_cache));
retval = itemize_shape_and_place (font, hdc, wtext, wlen, analysis, glyphs, script_cache);
@@ -924,12 +905,9 @@ uniscribe_shape (PangoFont *font,
}
- g_free (wtext);
- if (old_font != NULL)
- SelectObject (hdc, old_font);
+ pango_win32_font_done_font (font);
- if (hfont != NULL)
- pango_win32_font_cache_unload (font_cache, hfont);
+ g_free (wtext);
return retval && glyphs->num_glyphs > 0;
}
diff --git a/pango/Makefile.am b/pango/Makefile.am
index 185900b9..25d383ae 100644
--- a/pango/Makefile.am
+++ b/pango/Makefile.am
@@ -222,7 +222,7 @@ lib_LTLIBRARIES += libpangocairo-1.0.la
endif
libpangocairo_1_0_la_LDFLAGS = -version-info $(LT_VERSION_INFO) $(no_undefined)
-libpangocairo_1_0_la_LIBADD = libpangoft2-$(PANGO_API_VERSION).la libpango-$(PANGO_API_VERSION).la $(CAIRO_LIBS) $(GLIB_LIBS)
+libpangocairo_1_0_la_LIBADD = libpango-$(PANGO_API_VERSION).la $(CAIRO_LIBS) $(GLIB_LIBS)
libpangocairo_1_0_la_DEPENDENCIES = libpango-$(PANGO_API_VERSION).la
libpangocairo_1_0_la_SOURCES = \
@@ -231,8 +231,15 @@ libpangocairo_1_0_la_SOURCES = \
pangocairo-render.c \
pangocairo-private.h
+if HAVE_CAIRO_WIN32
+libpangocairo_1_0_la_LIBADD += libpangowin32-$(PANGO_API_VERSION).la
+libpangocairo_1_0_la_DEPENDENCIES += libpangowin32-$(PANGO_API_VERSION).la
+
+libpangocairo_1_0_la_SOURCES += pangocairo-win32font.c pangocairo-win32fontmap.c pangocairo-win32.h
+endif
+
if HAVE_CAIRO_FREETYPE
-libpangocairo_1_0_la_LIBADD += $(FREETYPE_LIBS)
+libpangocairo_1_0_la_LIBADD += libpangoft2-$(PANGO_API_VERSION).la $(FREETYPE_LIBS)
libpangocairo_1_0_la_DEPENDENCIES += libpangoft2-$(PANGO_API_VERSION).la
libpangocairo_1_0_la_SOURCES += \
diff --git a/pango/fonts.c b/pango/fonts.c
index 12752762..b0b73f16 100644
--- a/pango/fonts.c
+++ b/pango/fonts.c
@@ -1185,6 +1185,23 @@ pango_font_get_metrics (PangoFont *font,
return PANGO_FONT_GET_CLASS (font)->get_metrics (font, language);
}
+/**
+ * pango_font_get_font_map:
+ * @font: a #PangoFont
+ *
+ * Gets the font map for which the font was created.
+ *
+ * Returns: the #PangoFontMap for the font
+ **/
+PangoFontMap *
+pango_font_get_font_map (PangoFont *font)
+{
+ if (PANGO_FONT_GET_CLASS (font)->get_font_map)
+ return PANGO_FONT_GET_CLASS (font)->get_font_map (font);
+ else
+ return NULL;
+}
+
GType
pango_font_metrics_get_type (void)
{
diff --git a/pango/pango-font.h b/pango/pango-font.h
index 5098350a..8717e3ee 100644
--- a/pango/pango-font.h
+++ b/pango/pango-font.h
@@ -315,6 +315,7 @@ void pango_font_get_glyph_extents (PangoFont *font,
PangoGlyph glyph,
PangoRectangle *ink_rect,
PangoRectangle *logical_rect);
+PangoFontMap *pango_font_get_font_map (PangoFont *font);
#ifdef PANGO_ENABLE_BACKEND
@@ -347,13 +348,13 @@ struct _PangoFontClass
PangoRectangle *logical_rect);
PangoFontMetrics * (*get_metrics) (PangoFont *font,
PangoLanguage *language);
+ PangoFontMap * (*get_font_map) (PangoFont *font);
/*< private >*/
/* Padding for future expansion */
void (*_pango_reserved1) (void);
void (*_pango_reserved2) (void);
void (*_pango_reserved3) (void);
- void (*_pango_reserved4) (void);
};
#endif /* PANGO_ENABLE_BACKEND */
diff --git a/pango/pango-fontmap.h b/pango/pango-fontmap.h
index 5fc5d78f..3823f94c 100644
--- a/pango/pango-fontmap.h
+++ b/pango/pango-fontmap.h
@@ -32,7 +32,6 @@ G_BEGIN_DECLS
#define PANGO_IS_FONT_MAP(object) (G_TYPE_CHECK_INSTANCE_TYPE ((object), PANGO_TYPE_FONT_MAP))
typedef struct _PangoContext PangoContext;
-typedef struct _PangoFontMap PangoFontMap;
GType pango_font_map_get_type (void) G_GNUC_CONST;
PangoFont * pango_font_map_load_font (PangoFontMap *fontmap,
diff --git a/pango/pango-types.h b/pango/pango-types.h
index 51eb456a..274dfac9 100644
--- a/pango/pango-types.h
+++ b/pango/pango-types.h
@@ -32,7 +32,8 @@ typedef struct _PangoLogAttr PangoLogAttr;
typedef struct _PangoEngineLang PangoEngineLang;
typedef struct _PangoEngineShape PangoEngineShape;
-typedef struct _PangoFont PangoFont;
+typedef struct _PangoFont PangoFont;
+typedef struct _PangoFontMap PangoFontMap;
typedef struct _PangoMatrix PangoMatrix;
typedef struct _PangoRectangle PangoRectangle;
diff --git a/pango/pango.def b/pango/pango.def
index b2a02ccf..e3cce5b2 100644
--- a/pango/pango.def
+++ b/pango/pango.def
@@ -128,6 +128,7 @@ EXPORTS
pango_font_find_shaper
pango_font_get_coverage
pango_font_get_glyph_extents
+ pango_font_get_font_map
pango_font_get_metrics
pango_font_get_type
pango_font_map_get_shape_engine_type
diff --git a/pango/pangocairo-fontmap.c b/pango/pangocairo-fontmap.c
index 692b7786..bdbb72f9 100644
--- a/pango/pangocairo-fontmap.c
+++ b/pango/pangocairo-fontmap.c
@@ -24,8 +24,10 @@
#include "pangocairo.h"
#include "pangocairo-private.h"
-#ifdef HAVE_CAIRO_FREETYPE
-#include "pangocairo-fc.h"
+#if defined (HAVE_CAIRO_FREETYPE)
+# include "pangocairo-fc.h"
+#elif defined (HAVE_CAIRO_WIN32)
+# include "pangocairo-win32.h"
#endif
GType
@@ -82,8 +84,12 @@ pango_cairo_font_map_new (void)
{
/* Make sure that the type system is initialized */
g_type_init ();
-
+
+#if defined(HAVE_CAIRO_WIN32)
+ return g_object_new (PANGO_TYPE_CAIRO_WIN32_FONT_MAP, NULL);
+#elif defined(HAVE_CAIRO_FREETYPE)
return g_object_new (PANGO_TYPE_CAIRO_FC_FONT_MAP, NULL);
+#endif
}
/**
diff --git a/pango/pangocairo-render.c b/pango/pangocairo-render.c
index a6c5a214..c1598c45 100644
--- a/pango/pangocairo-render.c
+++ b/pango/pangocairo-render.c
@@ -278,7 +278,7 @@ pango_cairo_show_glyph_string (cairo_t *cr,
g_return_if_fail (PANGO_IS_CAIRO_FONT (font));
g_return_if_fail (glyphs != NULL);
- fontmap = PANGO_FC_FONT (font)->fontmap;
+ fontmap = pango_font_get_font_map (font);
renderer = _pango_cairo_font_map_get_renderer (PANGO_CAIRO_FONT_MAP (fontmap));
crenderer = PANGO_CAIRO_RENDERER (renderer);
@@ -408,7 +408,7 @@ pango_cairo_glyph_string_path (cairo_t *cr,
g_return_if_fail (PANGO_IS_CAIRO_FONT (font));
g_return_if_fail (glyphs != NULL);
- fontmap = PANGO_FC_FONT (font)->fontmap;
+ fontmap = pango_font_get_font_map (font);
renderer = _pango_cairo_font_map_get_renderer (PANGO_CAIRO_FONT_MAP (fontmap));
crenderer = PANGO_CAIRO_RENDERER (renderer);
diff --git a/pango/pangocairo-win32.h b/pango/pangocairo-win32.h
new file mode 100644
index 00000000..cc458314
--- /dev/null
+++ b/pango/pangocairo-win32.h
@@ -0,0 +1,55 @@
+/* Pango
+ * pangocairo-win32.h: Private header file for Cairo/fontconfig combination
+ *
+ * Copyright (C) 2005 Red Hat, Inc.
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Library 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
+ * Library General Public License for more details.
+ *
+ * You should have received a copy of the GNU Library 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.
+ */
+
+#ifndef __PANGOCAIRO_WIN32_H__
+#define __PANGOCAIRO_WIN32_H__
+
+#include "pangowin32.h"
+#include "pangowin32-private.h"
+#include "pangocairo.h"
+
+G_BEGIN_DECLS
+
+#define PANGO_TYPE_CAIRO_WIN32_FONT_MAP (pango_cairo_win32_font_map_get_type ())
+#define PANGO_CAIRO_WIN32_FONT_MAP(object) (G_TYPE_CHECK_INSTANCE_CAST ((object), PANGO_TYPE_CAIRO_WIN32_FONT_MAP, PangoCairoWin32FontMap))
+#define PANGO_IS_CAIRO_WIN32_FONT_MAP(object) (G_TYPE_CHECK_INSTANCE_TYPE ((object), PANGO_TYPE_CAIRO_WIN32_FONT_MAP))
+
+typedef struct _PangoCairoWin32FontMap PangoCairoWin32FontMap;
+
+struct _PangoCairoWin32FontMap
+{
+ PangoWin32FontMap parent_instance;
+
+ double dpi;
+
+ PangoRenderer *renderer;
+};
+
+GType pango_cairo_win32_font_map_get_type (void);
+
+PangoFont *_pango_cairo_win32_font_new (PangoCairoWin32FontMap *cwfontmap,
+ PangoContext *context,
+ PangoWin32Face *face,
+ const PangoFontDescription *desc);
+G_END_DECLS
+
+#endif /* __PANGOCAIRO_WIN32_H__ */
+
diff --git a/pango/pangocairo-win32font.c b/pango/pangocairo-win32font.c
new file mode 100644
index 00000000..59b24ed2
--- /dev/null
+++ b/pango/pangocairo-win32font.c
@@ -0,0 +1,313 @@
+/* Pango
+ * pangocairowin32-font.c: Cairo font handling, fontconfig backend
+ *
+ * Copyright (C) 2000-2005 Red Hat Software
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Library 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
+ * Library General Public License for more details.
+ *
+ * You should have received a copy of the GNU Library 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 <math.h>
+#include <stdlib.h>
+#include <string.h>
+
+#include "pango-fontmap.h"
+#include "pangocairo-private.h"
+#include "pangocairo-win32.h"
+
+#include <cairo-win32.h>
+
+#define PANGO_TYPE_CAIRO_WIN32_FONT (pango_cairo_win32_font_get_type ())
+#define PANGO_CAIRO_WIN32_FONT(object) (G_TYPE_CHECK_INSTANCE_CAST ((object), PANGO_TYPE_CAIRO_WIN32_FONT, PangoCairoWin32Font))
+#define PANGO_CAIRO_WIN32_FONT_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), PANGO_TYPE_CAIRO_WIN32_FONT, PangoCairoWin32FontClass))
+#define PANGO_CAIRO_IS_FONT_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), PANGO_TYPE_CAIRO_WIN32_FONT))
+#define PANGO_CAIRO_WIN32_FONT_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), PANGO_TYPE_CAIRO_WIN32_FONT, PangoCairoWin32FontClass))
+
+typedef struct _PangoCairoWin32Font PangoCairoWin32Font;
+typedef struct _PangoCairoWin32FontClass PangoCairoWin32FontClass;
+
+struct _PangoCairoWin32Font
+{
+ PangoWin32Font font;
+
+ int size;
+
+ cairo_font_t *cairo_font;
+ cairo_matrix_t *font_matrix;
+ cairo_matrix_t *total_matrix;
+
+ PangoFontMetrics *metrics;
+};
+
+struct _PangoCairoWin32FontClass
+{
+ PangoWin32FontClass parent_class;
+};
+
+GType pango_cairo_win32_font_get_type (void);
+
+/*******************************
+ * Utility functions *
+ *******************************/
+
+static cairo_font_t *
+pango_cairo_win32_font_get_cairo_font (PangoCairoFont *font)
+{
+ PangoCairoWin32Font *cwfont = PANGO_CAIRO_WIN32_FONT (font);
+ PangoWin32Font *win32font = PANGO_WIN32_FONT (cwfont);
+
+ if (cwfont->cairo_font == NULL)
+ {
+ LOGFONTW logfontw;
+
+ /* Count here on the fact that all the struct fields are
+ * in the same place for LOGFONTW and LOGFONTA and LOGFONTA
+ * is smaller
+ */
+ memcpy (&logfontw, &win32font->logfont, sizeof (LOGFONTA));
+
+ if (!MultiByteToWideChar (CP_ACP, MB_ERR_INVALID_CHARS,
+ win32font->logfont.lfFaceName, strlen (win32font->logfont.lfFaceName),
+ logfontw.lfFaceName, sizeof(logfontw.lfFaceName)))
+ logfontw.lfFaceName[0] = 0; /* Hopefully this will select some font */
+
+ cwfont->cairo_font = cairo_win32_font_create_for_logfontw (&logfontw,
+ cwfont->total_matrix);
+
+ /* Failure of the above should only occur for out of memory,
+ * we can't proceed at that point
+ */
+ if (!cwfont->cairo_font)
+ g_error ("Unable create Cairo font");
+ }
+
+ return cwfont->cairo_font;
+}
+
+static void
+cairo_font_iface_init (PangoCairoFontIface *iface)
+{
+ iface->get_cairo_font = pango_cairo_win32_font_get_cairo_font;
+}
+
+G_DEFINE_TYPE_WITH_CODE (PangoCairoWin32Font, pango_cairo_win32_font, PANGO_TYPE_WIN32_FONT,
+ { G_IMPLEMENT_INTERFACE (PANGO_TYPE_CAIRO_FONT, cairo_font_iface_init) });
+
+/********************************
+ * Method implementations *
+ ********************************/
+
+static void
+pango_cairo_win32_font_finalize (GObject *object)
+{
+ PangoCairoWin32Font *cwfont = PANGO_CAIRO_WIN32_FONT (object);
+
+ if (cwfont->metrics)
+ pango_font_metrics_unref (cwfont->metrics);
+
+ if (cwfont->cairo_font)
+ cairo_font_destroy (cwfont->cairo_font);
+
+ cairo_matrix_destroy (cwfont->total_matrix);
+ cairo_matrix_destroy (cwfont->font_matrix);
+
+ G_OBJECT_CLASS (pango_cairo_win32_font_parent_class)->finalize (object);
+}
+
+static void
+pango_cairo_win32_font_get_glyph_extents (PangoFont *font,
+ PangoGlyph glyph,
+ PangoRectangle *ink_rect,
+ PangoRectangle *logical_rect)
+{
+ PangoCairoWin32Font *cwfont = PANGO_CAIRO_WIN32_FONT (font);
+ cairo_font_t *cairo_font;
+ cairo_text_extents_t extents;
+ cairo_glyph_t cairo_glyph;
+
+ cairo_font = pango_cairo_win32_font_get_cairo_font (PANGO_CAIRO_FONT (font));
+
+ cairo_glyph.index = glyph;
+ cairo_glyph.x = 0;
+ cairo_glyph.y = 0;
+
+ cairo_font_glyph_extents (cairo_font, cwfont->font_matrix,
+ &cairo_glyph, 1, &extents);
+
+ if (ink_rect)
+ {
+ ink_rect->x = extents.x_bearing * PANGO_SCALE;
+ ink_rect->y = extents.y_bearing * PANGO_SCALE;
+ ink_rect->width = extents.width * PANGO_SCALE;
+ ink_rect->height = extents.height * PANGO_SCALE;
+ }
+
+ if (logical_rect)
+ {
+ cairo_font_extents_t font_extents;
+
+ cairo_font_extents (cairo_font, cwfont->font_matrix,
+ &font_extents);
+
+ logical_rect->x = 0;
+ logical_rect->y = - font_extents.ascent * PANGO_SCALE;
+ logical_rect->width = extents.x_advance * PANGO_SCALE;
+ logical_rect->height = (font_extents.ascent + font_extents.descent) * PANGO_SCALE;
+ }
+}
+
+static PangoFontMetrics *
+pango_cairo_win32_font_get_metrics (PangoFont *font,
+ PangoLanguage *language)
+{
+ PangoCairoWin32Font *cwfont = PANGO_CAIRO_WIN32_FONT (font);
+
+ if (!cwfont->metrics)
+ {
+ cairo_font_t *cairo_font;
+ cairo_font_extents_t font_extents;
+ cwfont->metrics = pango_font_metrics_new ();
+ double height;
+
+ cairo_font = pango_cairo_win32_font_get_cairo_font (PANGO_CAIRO_FONT (font));
+
+ cairo_font_extents (cairo_font, cwfont->font_matrix,
+ &font_extents);
+
+ cwfont->metrics->ascent = font_extents.ascent * PANGO_SCALE;
+ cwfont->metrics->descent = font_extents.ascent * PANGO_SCALE;
+ cwfont->metrics->approximate_char_width = font_extents.max_x_advance * PANGO_SCALE;
+ cwfont->metrics->approximate_digit_width = font_extents.max_y_advance * PANGO_SCALE;
+
+ height = font_extents.ascent + font_extents.descent;
+
+ cwfont->metrics->underline_thickness = (PANGO_SCALE * height) / 14;
+ cwfont->metrics->underline_position = - cwfont->metrics->underline_thickness;
+ cwfont->metrics->strikethrough_thickness = cwfont->metrics->underline_thickness;
+ cwfont->metrics->strikethrough_position = (PANGO_SCALE * height) / 4;
+ }
+
+ return pango_font_metrics_ref (cwfont->metrics);
+}
+
+static gboolean
+pango_cairo_win32_font_select_font (PangoFont *font,
+ HDC hdc)
+{
+ cairo_font_t *cairo_font = pango_cairo_win32_font_get_cairo_font (PANGO_CAIRO_FONT (font));
+
+ return cairo_win32_font_select_font (cairo_font, hdc) == CAIRO_STATUS_SUCCESS;
+}
+
+static void
+pango_cairo_win32_font_done_font (PangoFont *font)
+{
+ cairo_font_t *cairo_font = pango_cairo_win32_font_get_cairo_font (PANGO_CAIRO_FONT (font));
+
+ cairo_win32_font_done_font (cairo_font);
+}
+
+static double
+pango_cairo_win32_font_get_scale_factor (PangoFont *font)
+{
+ PangoWin32Font *win32font = PANGO_WIN32_FONT (font);
+ cairo_font_t *cairo_font = pango_cairo_win32_font_get_cairo_font (PANGO_CAIRO_FONT (font));
+
+ return cairo_win32_font_get_scale_factor (cairo_font) * win32font->size;
+}
+
+static void
+pango_cairo_win32_font_class_init (PangoCairoWin32FontClass *class)
+{
+ GObjectClass *object_class = G_OBJECT_CLASS (class);
+ PangoFontClass *font_class = PANGO_FONT_CLASS (class);
+ PangoWin32FontClass *win32_font_class = PANGO_WIN32_FONT_CLASS (class);
+
+ object_class->finalize = pango_cairo_win32_font_finalize;
+
+ font_class->get_glyph_extents = pango_cairo_win32_font_get_glyph_extents;
+ font_class->get_metrics = pango_cairo_win32_font_get_metrics;
+
+ win32_font_class->select_font = pango_cairo_win32_font_select_font;
+ win32_font_class->done_font = pango_cairo_win32_font_done_font;
+ win32_font_class->get_scale_factor = pango_cairo_win32_font_get_scale_factor;
+}
+
+static void
+pango_cairo_win32_font_init (PangoCairoWin32Font *cwfont)
+{
+}
+
+/********************
+ * Private API *
+ ********************/
+
+PangoFont *
+_pango_cairo_win32_font_new (PangoCairoWin32FontMap *cwfontmap,
+ PangoContext *context,
+ PangoWin32Face *face,
+ const PangoFontDescription *desc)
+{
+ PangoCairoWin32Font *cwfont;
+ PangoWin32Font *win32font;
+ const PangoMatrix *pango_ctm;
+ double size;
+
+ cwfont = g_object_new (PANGO_TYPE_CAIRO_WIN32_FONT, NULL);
+ win32font = PANGO_WIN32_FONT (cwfont);
+
+ win32font->fontmap = PANGO_FONT_MAP (cwfontmap);
+ g_object_ref (cwfontmap);
+
+ win32font->win32face = face;
+
+ size = (double) pango_font_description_get_size (desc) / PANGO_SCALE;
+
+ if (!pango_font_description_get_size_is_absolute (desc))
+ size *= cwfontmap->dpi / 72.;
+
+ /* FIXME: THis is a pixel size, so not really what we want for describe(),
+ * but it's what we need when computing the scale factor.
+ */
+ win32font->size = size * PANGO_SCALE;
+
+ cwfont->font_matrix = cairo_matrix_create ();
+ cairo_matrix_scale (cwfont->font_matrix, size, size);
+
+ cwfont->total_matrix = cairo_matrix_create ();
+
+ pango_ctm = pango_context_get_matrix (context);
+ if (pango_ctm)
+ {
+ cairo_matrix_t *ctm;
+
+ ctm = cairo_matrix_create ();
+ cairo_matrix_set_affine (ctm,
+ pango_ctm->xx,
+ pango_ctm->yx,
+ pango_ctm->xy,
+ pango_ctm->yy,
+ 0., 0.);
+
+ cairo_matrix_multiply (cwfont->total_matrix, cwfont->font_matrix, ctm);
+ cairo_matrix_destroy (ctm);
+ }
+ else
+ cairo_matrix_copy (cwfont->total_matrix, cwfont->font_matrix);
+
+ return PANGO_FONT (cwfont);
+}
diff --git a/pango/pangocairo-win32fontmap.c b/pango/pangocairo-win32fontmap.c
new file mode 100644
index 00000000..51393efa
--- /dev/null
+++ b/pango/pangocairo-win32fontmap.c
@@ -0,0 +1,108 @@
+/* Pango
+ * pangocairo-win32fontmap.c: Cairo font handling, Win32 backend
+ *
+ * Copyright (C) 2000-2005 Red Hat Software
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Library 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
+ * Library General Public License for more details.
+ *
+ * You should have received a copy of the GNU Library 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 "pangowin32-private.h"
+#include "pangocairo.h"
+#include "pangocairo-private.h"
+#include "pangocairo-win32.h"
+
+typedef struct _PangoCairoWin32FontMapClass PangoCairoWin32FontMapClass;
+
+struct _PangoCairoWin32FontMapClass
+{
+ PangoWin32FontMapClass parent_class;
+};
+
+static void
+pango_cairo_win32_font_map_set_resolution (PangoCairoFontMap *cfontmap,
+ double dpi)
+{
+ PangoCairoWin32FontMap *cwfontmap = PANGO_CAIRO_WIN32_FONT_MAP (cfontmap);
+
+ cwfontmap->dpi = dpi;
+}
+
+static double
+pango_cairo_win32_font_map_get_resolution (PangoCairoFontMap *cfontmap)
+{
+ PangoCairoWin32FontMap *cwfontmap = PANGO_CAIRO_WIN32_FONT_MAP (cfontmap);
+
+ return cwfontmap->dpi;
+}
+
+static PangoRenderer *
+pango_cairo_win32_font_map_get_renderer (PangoCairoFontMap *cfontmap)
+{
+ PangoCairoWin32FontMap *cwfontmap = PANGO_CAIRO_WIN32_FONT_MAP (cfontmap);
+
+ if (!cwfontmap->renderer)
+ cwfontmap->renderer = g_object_new (PANGO_TYPE_CAIRO_RENDERER, NULL);
+
+ return cwfontmap->renderer;
+}
+
+static void
+cairo_font_map_iface_init (PangoCairoFontMapIface *iface)
+{
+ iface->set_resolution = pango_cairo_win32_font_map_set_resolution;
+ iface->get_resolution = pango_cairo_win32_font_map_get_resolution;
+ iface->get_renderer = pango_cairo_win32_font_map_get_renderer;
+}
+
+G_DEFINE_TYPE_WITH_CODE (PangoCairoWin32FontMap, pango_cairo_win32_font_map, PANGO_TYPE_WIN32_FONT_MAP,
+ { G_IMPLEMENT_INTERFACE (PANGO_TYPE_CAIRO_FONT_MAP, cairo_font_map_iface_init) });
+
+static void
+pango_cairo_win32_font_map_finalize (GObject *object)
+{
+ PangoCairoWin32FontMap *cwfontmap = PANGO_CAIRO_WIN32_FONT_MAP (object);
+
+ if (cwfontmap->renderer)
+ g_object_unref (cwfontmap->renderer);
+
+ G_OBJECT_CLASS (pango_cairo_win32_font_map_parent_class)->finalize (object);
+}
+
+static PangoFont *
+pango_cairo_win32_font_map_find_font (PangoWin32FontMap *fontmap,
+ PangoContext *context,
+ PangoWin32Face *face,
+ const PangoFontDescription *desc)
+{
+ return _pango_cairo_win32_font_new (PANGO_CAIRO_WIN32_FONT_MAP (fontmap),
+ context, face, desc);
+}
+
+static void
+pango_cairo_win32_font_map_class_init (PangoCairoWin32FontMapClass *class)
+{
+ GObjectClass *gobject_class = G_OBJECT_CLASS (class);
+ PangoWin32FontMapClass *win32fontmap_class = PANGO_WIN32_FONT_MAP_CLASS (class);
+
+ gobject_class->finalize = pango_cairo_win32_font_map_finalize;
+ win32fontmap_class->find_font = pango_cairo_win32_font_map_find_font;
+}
+
+static void
+pango_cairo_win32_font_map_init (PangoCairoWin32FontMap *cwfontmap)
+{
+ cwfontmap->dpi = 96.0;
+}
diff --git a/pango/pangocairo.h b/pango/pangocairo.h
index dbaff5fe..147e619c 100644
--- a/pango/pangocairo.h
+++ b/pango/pangocairo.h
@@ -23,7 +23,7 @@
#define __PANGOCAIRO_H__
#include <pango/pango-context.h>
-#include <pango/pangofc-fontmap.h>
+#include <pango/pango-fontmap.h>
#include <pango/pango-layout.h>
#include <cairo.h>
diff --git a/pango/pangofc-font.c b/pango/pangofc-font.c
index fabb2f17..f6adb330 100644
--- a/pango/pangofc-font.c
+++ b/pango/pangofc-font.c
@@ -69,6 +69,7 @@ static PangoCoverage * pango_fc_font_get_coverage (PangoFont *font,
PangoLanguage *language);
static PangoFontMetrics * pango_fc_font_get_metrics (PangoFont *font,
PangoLanguage *language);
+static PangoFontMap * pango_fc_font_get_font_map (PangoFont *font);
static PangoFontDescription *pango_fc_font_describe (PangoFont *font);
G_DEFINE_TYPE (PangoFcFont, pango_fc_font, PANGO_TYPE_FONT)
@@ -88,6 +89,7 @@ pango_fc_font_class_init (PangoFcFontClass *class)
font_class->find_shaper = pango_fc_font_find_shaper;
font_class->get_coverage = pango_fc_font_get_coverage;
font_class->get_metrics = pango_fc_font_get_metrics;
+ font_class->get_font_map = pango_fc_font_get_metrics;
g_object_class_install_property (object_class, PROP_PATTERN,
g_param_spec_pointer ("pattern",
@@ -461,6 +463,14 @@ pango_fc_font_get_metrics (PangoFont *font,
return pango_font_metrics_ref (info->metrics);
}
+static PangoFontMap *
+pango_fc_font_get_font_map (PangoFont *font)
+{
+ PangoFcFont *fcfont = PANGO_FC_FONT (font);
+
+ return fcfont->fontmap;
+}
+
static gboolean
pango_fc_font_real_has_char (PangoFcFont *font,
gunichar wc)
diff --git a/pango/pangowin32-fontmap.c b/pango/pangowin32-fontmap.c
index 92bf7f64..98057170 100644
--- a/pango/pangowin32-fontmap.c
+++ b/pango/pangowin32-fontmap.c
@@ -33,43 +33,12 @@
#include "pango-utils.h"
#include "pangowin32-private.h"
-#define PANGO_TYPE_WIN32_FONT_MAP (pango_win32_font_map_get_type ())
-#define PANGO_WIN32_FONT_MAP(object) (G_TYPE_CHECK_INSTANCE_CAST ((object), PANGO_TYPE_WIN32_FONT_MAP, PangoWin32FontMap))
-#define PANGO_WIN32_IS_FONT_MAP(object) (G_TYPE_CHECK_INSTANCE_TYPE ((object), PANGO_TYPE_WIN32_FONT_MAP))
-
-typedef struct _PangoWin32FontMap PangoWin32FontMap;
-typedef struct _PangoWin32FontMapClass PangoWin32FontMapClass;
typedef struct _PangoWin32Family PangoWin32Family;
typedef struct _PangoWin32SizeInfo PangoWin32SizeInfo;
/* Number of freed fonts */
#define MAX_FREED_FONTS 16
-struct _PangoWin32FontMap
-{
- PangoFontMap parent_instance;
-
- PangoWin32FontCache *font_cache;
- GQueue *freed_fonts;
-
- /* Map Pango family names to PangoWin32Family structs */
- GHashTable *families;
-
- /* Map LOGFONTS (taking into account only the lfFaceName, lfItalic
- * and lfWeight fields) to PangoWin32SizeInfo structs.
- */
- GHashTable *size_infos;
-
- int n_fonts;
-
- double resolution; /* (points / pixel) * PANGO_SCALE */
-};
-
-struct _PangoWin32FontMapClass
-{
- PangoFontMapClass parent_class;
-};
-
struct _PangoWin32Family
{
PangoFontFamily parent_instance;
@@ -108,6 +77,11 @@ static void pango_win32_font_map_list_families (PangoFontMap
PangoFontFamily ***families,
int *n_families);
+static PangoFont *pango_win32_font_map_real_find_font (PangoWin32FontMap *win32fontmap,
+ PangoContext *context,
+ PangoWin32Face *face,
+ const PangoFontDescription *description);
+
static void pango_win32_fontmap_cache_clear (PangoWin32FontMap *win32fontmap);
static void pango_win32_insert_font (PangoWin32FontMap *fontmap,
@@ -144,42 +118,19 @@ logfont_nosize_equal (gconstpointer v1,
&& lfp1->lfWeight == lfp2->lfWeight);
}
-static void
-pango_win32_font_map_init (PangoWin32FontMap *win32fontmap)
-{
- win32fontmap->families = g_hash_table_new (g_str_hash, g_str_equal);
- win32fontmap->size_infos =
- g_hash_table_new (logfont_nosize_hash, logfont_nosize_equal);
- win32fontmap->n_fonts = 0;
-}
-
-static void
-pango_win32_font_map_class_init (PangoWin32FontMapClass *class)
-{
- GObjectClass *object_class = G_OBJECT_CLASS (class);
- PangoFontMapClass *fontmap_class = PANGO_FONT_MAP_CLASS (class);
-
- object_class->finalize = pango_win32_font_map_finalize;
- fontmap_class->load_font = pango_win32_font_map_load_font;
- fontmap_class->list_families = pango_win32_font_map_list_families;
- fontmap_class->shape_engine_type = PANGO_RENDER_TYPE_WIN32;
-
- pango_win32_get_dc ();
-}
-
-static PangoWin32FontMap *fontmap = NULL;
-
static int CALLBACK
pango_win32_inner_enum_proc (LOGFONT *lfp,
TEXTMETRIC *metrics,
DWORD fontType,
LPARAM lParam)
{
+ PangoWin32FontMap *win32fontmap = (PangoWin32FontMap *)lParam;
+
/* Windows generates synthetic vertical writing versions of East
* Asian fonts with @ prepended to their name, ignore them.
*/
if (lfp->lfFaceName[0] != '@')
- pango_win32_insert_font (fontmap, lfp);
+ pango_win32_insert_font (win32fontmap, lfp);
return 1;
}
@@ -205,6 +156,45 @@ pango_win32_enum_proc (LOGFONT *lfp,
return 1;
}
+static void
+pango_win32_font_map_init (PangoWin32FontMap *win32fontmap)
+{
+ LOGFONT logfont;
+
+ win32fontmap->families = g_hash_table_new (g_str_hash, g_str_equal);
+ win32fontmap->size_infos =
+ g_hash_table_new (logfont_nosize_hash, logfont_nosize_equal);
+ win32fontmap->n_fonts = 0;
+
+ win32fontmap->font_cache = pango_win32_font_cache_new ();
+ win32fontmap->freed_fonts = g_queue_new ();
+
+ memset (&logfont, 0, sizeof (logfont));
+ logfont.lfCharSet = DEFAULT_CHARSET;
+ EnumFontFamiliesExA (pango_win32_hdc, &logfont, (FONTENUMPROC) pango_win32_enum_proc,
+ (LPARAM)win32fontmap, 0);
+
+ win32fontmap->resolution = (PANGO_SCALE / (double) GetDeviceCaps (pango_win32_hdc, LOGPIXELSY)) * 72.0;
+
+}
+
+static void
+pango_win32_font_map_class_init (PangoWin32FontMapClass *class)
+{
+ GObjectClass *object_class = G_OBJECT_CLASS (class);
+ PangoFontMapClass *fontmap_class = PANGO_FONT_MAP_CLASS (class);
+
+ class->find_font = pango_win32_font_map_real_find_font;
+ object_class->finalize = pango_win32_font_map_finalize;
+ fontmap_class->load_font = pango_win32_font_map_load_font;
+ fontmap_class->list_families = pango_win32_font_map_list_families;
+ fontmap_class->shape_engine_type = PANGO_RENDER_TYPE_WIN32;
+
+ pango_win32_get_dc ();
+}
+
+static PangoWin32FontMap *default_fontmap = NULL;
+
/**
* pango_win32_font_map_for_display:
*
@@ -217,26 +207,15 @@ pango_win32_enum_proc (LOGFONT *lfp,
PangoFontMap *
pango_win32_font_map_for_display (void)
{
- LOGFONT logfont;
-
/* Make sure that the type system is initialized */
g_type_init ();
- if (fontmap != NULL)
- return PANGO_FONT_MAP (fontmap);
+ if (default_fontmap != NULL)
+ return PANGO_FONT_MAP (default_fontmap);
- fontmap = g_object_new (PANGO_TYPE_WIN32_FONT_MAP, NULL);
+ default_fontmap = g_object_new (PANGO_TYPE_WIN32_FONT_MAP, NULL);
- fontmap->font_cache = pango_win32_font_cache_new ();
- fontmap->freed_fonts = g_queue_new ();
-
- memset (&logfont, 0, sizeof (logfont));
- logfont.lfCharSet = DEFAULT_CHARSET;
- EnumFontFamiliesExA (pango_win32_hdc, &logfont, (FONTENUMPROC) pango_win32_enum_proc, 0, 0);
-
- fontmap->resolution = (PANGO_SCALE / (double) GetDeviceCaps (pango_win32_hdc, LOGPIXELSY)) * 72.0;
-
- return PANGO_FONT_MAP (fontmap);
+ return PANGO_FONT_MAP (default_fontmap);
}
/**
@@ -247,12 +226,12 @@ pango_win32_font_map_for_display (void)
void
pango_win32_shutdown_display (void)
{
- if (fontmap)
+ if (default_fontmap)
{
- pango_win32_fontmap_cache_clear (fontmap);
- g_object_unref (fontmap);
+ pango_win32_fontmap_cache_clear (default_fontmap);
+ g_object_unref (default_fontmap);
- fontmap = NULL;
+ default_fontmap = NULL;
}
}
@@ -445,43 +424,9 @@ pango_win32_font_map_load_font (PangoFontMap *fontmap,
}
if (best_match)
- {
- GSList *tmp_list = best_match->cached_fonts;
- gint size = pango_font_description_get_size (description);
-
- if (pango_font_description_get_size_is_absolute (description))
- size = (int) 0.5 + (size * win32fontmap->resolution) / PANGO_SCALE;
-
- PING(("got best match:%s size=%d",best_match->logfont.lfFaceName,size));
-
- while (tmp_list)
- {
- PangoWin32Font *win32font = tmp_list->data;
- if (win32font->size == size)
- {
- PING (("size matches"));
- result = (PangoFont *)win32font;
-
- g_object_ref (result);
- if (win32font->in_cache)
- pango_win32_fontmap_cache_remove (fontmap, win32font);
-
- break;
- }
- tmp_list = tmp_list->next;
- }
-
- if (!result)
- {
- PangoWin32Font *win32font = pango_win32_font_new (fontmap, &best_match->logfont, size);
-
- win32font->fontmap = fontmap;
- win32font->win32face = best_match;
- best_match->cached_fonts = g_slist_prepend (best_match->cached_fonts, win32font);
-
- result = (PangoFont *)win32font;
- }
- }
+ result = PANGO_WIN32_FONT_MAP_GET_CLASS (win32fontmap)->find_font (win32fontmap, context,
+ best_match,
+ description);
else
PING(("no best match!"));
}
@@ -490,6 +435,47 @@ pango_win32_font_map_load_font (PangoFontMap *fontmap,
return result;
}
+static PangoFont *
+pango_win32_font_map_real_find_font (PangoWin32FontMap *win32fontmap,
+ PangoContext *context,
+ PangoWin32Face *face,
+ const PangoFontDescription *description)
+{
+ PangoFontMap *fontmap = PANGO_FONT_MAP (win32fontmap);
+ PangoWin32Font *win32font;
+ GSList *tmp_list = face->cached_fonts;
+ int size = pango_font_description_get_size (description);
+
+ if (pango_font_description_get_size_is_absolute (description))
+ size = (int) 0.5 + (size * win32fontmap->resolution) / PANGO_SCALE;
+
+ PING(("got best match:%s size=%d",face->logfont.lfFaceName,size));
+
+ while (tmp_list)
+ {
+ win32font = tmp_list->data;
+ if (win32font->size == size)
+ {
+ PING (("size matches"));
+
+ g_object_ref (win32font);
+ if (win32font->in_cache)
+ pango_win32_fontmap_cache_remove (fontmap, win32font);
+
+ return (PangoFont *)win32font;
+ }
+ tmp_list = tmp_list->next;
+ }
+
+ win32font = pango_win32_font_new (fontmap, &face->logfont, size);
+
+ win32font->fontmap = fontmap;
+ win32font->win32face = face;
+ face->cached_fonts = g_slist_prepend (face->cached_fonts, win32font);
+
+ return (PangoFont *)win32font;
+}
+
static gchar *
get_family_name (LOGFONT *lfp)
{
diff --git a/pango/pangowin32-private.h b/pango/pangowin32-private.h
index e51f2d55..d8449385 100644
--- a/pango/pangowin32-private.h
+++ b/pango/pangowin32-private.h
@@ -64,9 +64,57 @@ typedef enum
PANGO_WIN32_N_COVERAGES
} PangoWin32CoverageLanguageClass;
-typedef struct _PangoWin32Font PangoWin32Font;
-typedef struct _PangoWin32Face PangoWin32Face;
-typedef struct _PangoWin32GlyphInfo PangoWin32GlyphInfo;
+#define PANGO_TYPE_WIN32_FONT_MAP (pango_win32_font_map_get_type ())
+#define PANGO_WIN32_FONT_MAP(object) (G_TYPE_CHECK_INSTANCE_CAST ((object), PANGO_TYPE_WIN32_FONT_MAP, PangoWin32FontMap))
+#define PANGO_WIN32_IS_FONT_MAP(object) (G_TYPE_CHECK_INSTANCE_TYPE ((object), PANGO_TYPE_WIN32_FONT_MAP))
+#define PANGO_WIN32_FONT_MAP_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), PANGO_TYPE_WIN32_FONT_MAP, PangoWin32FontMapClass))
+#define PANGO_IS_WIN32_FONT_MAP_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), PANGO_TYPE_WIN32_FONT_MAP))
+#define PANGO_WIN32_FONT_MAP_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), PANGO_TYPE_WIN32_FONT_MAP, PangoWin32FontMapClass))
+
+#define PANGO_TYPE_WIN32_FONT (pango_win32_font_get_type ())
+#define PANGO_WIN32_FONT(object) (G_TYPE_CHECK_INSTANCE_CAST ((object), PANGO_TYPE_WIN32_FONT, PangoWin32Font))
+#define PANGO_WIN32_FONT_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), PANGO_TYPE_WIN32_FONT, PangoWin32FontClass))
+#define PANGO_WIN32_IS_FONT(object) (G_TYPE_CHECK_INSTANCE_TYPE ((object), PANGO_TYPE_WIN32_FONT))
+#define PANGO_WIN32_IS_FONT_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), PANGO_TYPE_WIN32_FONT))
+#define PANGO_WIN32_FONT_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), PANGO_TYPE_WIN32_FONT, PangoWin32FontClass))
+
+typedef struct _PangoWin32FontMap PangoWin32FontMap;
+typedef struct _PangoWin32FontMapClass PangoWin32FontMapClass;
+typedef struct _PangoWin32Font PangoWin32Font;
+typedef struct _PangoWin32FontClass PangoWin32FontClass;
+typedef struct _PangoWin32Face PangoWin32Face;
+typedef struct _PangoWin32GlyphInfo PangoWin32GlyphInfo;
+
+struct _PangoWin32FontMap
+{
+ PangoFontMap parent_instance;
+
+ PangoWin32FontCache *font_cache;
+ GQueue *freed_fonts;
+
+ /* Map Pango family names to PangoWin32Family structs */
+ GHashTable *families;
+
+ /* Map LOGFONTS (taking into account only the lfFaceName, lfItalic
+ * and lfWeight fields) to PangoWin32SizeInfo structs.
+ */
+ GHashTable *size_infos;
+
+ int n_fonts;
+
+ double resolution; /* (points / pixel) * PANGO_SCALE */
+};
+
+struct _PangoWin32FontMapClass
+{
+ PangoFontMapClass parent_class;
+
+ PangoFont *(*find_font) (PangoWin32FontMap *fontmap,
+ PangoContext *context,
+ PangoWin32Face *face,
+ const PangoFontDescription *desc);
+
+};
struct _PangoWin32Font
{
@@ -94,6 +142,16 @@ struct _PangoWin32Font
GHashTable *glyph_info;
};
+struct _PangoWin32FontClass
+{
+ PangoFontClass parent_class;
+
+ gboolean (*select_font) (PangoFont *font,
+ HDC hdc);
+ void (*done_font) (PangoFont *font);
+ double (*get_scale_factor) (PangoFont *font);
+};
+
struct _PangoWin32Face
{
PangoFontFace parent_instance;
@@ -114,7 +172,6 @@ struct _PangoWin32GlyphInfo
PangoRectangle ink_rect;
};
-
/* TrueType defines: */
#define MAKE_TT_TABLE_NAME(c1, c2, c3, c4) \
@@ -176,6 +233,8 @@ struct name_record
guint16 string_offset;
};
+GType pango_win32_font_get_type (void);
+
PangoWin32Font *pango_win32_font_new (PangoFontMap *fontmap,
const LOGFONT *lfp,
int size);
@@ -192,6 +251,8 @@ void pango_win32_font_entry_set_coverage (PangoWin32Face *face,
void pango_win32_font_entry_remove (PangoWin32Face *face,
PangoFont *font);
+GType pango_win32_font_map_get_type (void);
+
void pango_win32_fontmap_cache_add (PangoFontMap *fontmap,
PangoWin32Font *xfont);
void pango_win32_fontmap_cache_remove (PangoFontMap *fontmap,
diff --git a/pango/pangowin32.c b/pango/pangowin32.c
index 6e48ce33..ea7b41dc 100644
--- a/pango/pangowin32.c
+++ b/pango/pangowin32.c
@@ -32,27 +32,14 @@
#include "pangowin32-private.h"
#include "modules.h"
-#define PANGO_TYPE_WIN32_FONT (pango_win32_font_get_type ())
-#define PANGO_WIN32_FONT(object) (G_TYPE_CHECK_INSTANCE_CAST ((object), PANGO_TYPE_WIN32_FONT, PangoWin32Font))
-#define PANGO_WIN32_FONT_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), PANGO_TYPE_WIN32_FONT, PangoWin32FontClass))
-#define PANGO_WIN32_IS_FONT(object) (G_TYPE_CHECK_INSTANCE_TYPE ((object), PANGO_TYPE_WIN32_FONT))
-#define PANGO_WIN32_IS_FONT_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), PANGO_TYPE_WIN32_FONT))
-#define PANGO_WIN32_FONT_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), PANGO_TYPE_WIN32_FONT, PangoWin32FontClass))
-
#define PANGO_WIN32_UNKNOWN_FLAG 0x10000000
HDC pango_win32_hdc;
OSVERSIONINFO pango_win32_os_version_info;
gboolean pango_win32_debug = FALSE;
-typedef struct _PangoWin32FontClass PangoWin32FontClass;
typedef struct _PangoWin32MetricsInfo PangoWin32MetricsInfo;
-struct _PangoWin32FontClass
-{
- PangoFontClass parent_class;
-};
-
struct _PangoWin32MetricsInfo
{
const char *sample_str;
@@ -62,6 +49,11 @@ struct _PangoWin32MetricsInfo
static void pango_win32_font_dispose (GObject *object);
static void pango_win32_font_finalize (GObject *object);
+static gboolean pango_win32_font_real_select_font (PangoFont *font,
+ HDC hdc);
+static void pango_win32_font_real_done_font (PangoFont *font);
+static double pango_win32_font_real_get_scale_factor (PangoFont *font);
+
static PangoFontDescription *pango_win32_font_describe (PangoFont *font);
static PangoCoverage *pango_win32_font_get_coverage (PangoFont *font,
PangoLanguage *lang);
@@ -77,6 +69,13 @@ static void pango_win32_font_get_glyph_extents (PangoFont
PangoRectangle *logical_rect);
static PangoFontMetrics * pango_win32_font_get_metrics (PangoFont *font,
PangoLanguage *lang);
+static PangoFontMap * pango_win32_font_get_font_map (PangoFont *font);
+
+static gboolean pango_win32_font_real_select_font (PangoFont *font,
+ HDC hdc);
+static void pango_win32_font_real_done_font (PangoFont *font);
+static double pango_win32_font_real_get_scale_factor (PangoFont *font);
+
static HFONT pango_win32_get_hfont (PangoFont *font);
static void pango_win32_get_item_properties (PangoItem *item,
PangoUnderline *uline,
@@ -85,7 +84,7 @@ static void pango_win32_get_item_properties (PangoItem
PangoAttrColor *bg_color,
gboolean *bg_set);
-static inline HFONT
+static HFONT
pango_win32_get_hfont (PangoFont *font)
{
PangoWin32Font *win32font = (PangoWin32Font *)font;
@@ -218,6 +217,11 @@ pango_win32_font_class_init (PangoWin32FontClass *class)
font_class->find_shaper = pango_win32_font_find_shaper;
font_class->get_glyph_extents = pango_win32_font_get_glyph_extents;
font_class->get_metrics = pango_win32_font_get_metrics;
+ font_class->get_font_map = pango_win32_font_get_font_map;
+
+ class->select_font = pango_win32_font_real_select_font;
+ class->done_font = pango_win32_font_real_done_font;
+ class->get_scale_factor = pango_win32_font_real_get_scale_factor;
pango_win32_get_dc ();
}
@@ -624,6 +628,43 @@ pango_win32_font_get_metrics (PangoFont *font,
return pango_font_metrics_ref (info->metrics);
}
+static PangoFontMap *
+pango_win32_font_get_font_map (PangoFont *font)
+{
+ PangoWin32Font *win32font = (PangoWin32Font *)font;
+
+ return win32font->fontmap;
+}
+
+static gboolean
+pango_win32_font_real_select_font (PangoFont *font,
+ HDC hdc)
+{
+ HFONT hfont = pango_win32_get_hfont (font);
+
+ if (!hfont)
+ return FALSE;
+
+ if (!SelectObject (hdc, hfont))
+ {
+ g_warning ("pango_win32_font_real_select_font: Cannot select font\n");
+ return FALSE;
+ }
+
+ return TRUE;
+}
+
+static void
+pango_win32_font_real_done_font (PangoFont *font)
+{
+}
+
+static double
+pango_win32_font_real_get_scale_factor (PangoFont *font)
+{
+ return PANGO_SCALE;
+}
+
/**
* pango_win32_font_logfont:
* @font: a #PangoFont which must be from the Win32 backend
@@ -648,6 +689,64 @@ pango_win32_font_logfont (PangoFont *font)
return lfp;
}
+/**
+ * pango_win32_font_select_font:
+ * @font: a #PangoFont from the Win32 backend
+ * @scale: location to store a scale factor from Windows
+ * units to Pango Units.
+ *
+ * Selects the font into the specified DC and changes the mapping mode
+ * and world transformation of the DC appropriately for the font.
+ * You may want to surround the use of this function with calls
+ * to SaveDC and RestoreDC. Call pango_win32_font_done_font() when
+ * you are done using the DC to release allocated resources.
+ *
+ * See
+ *
+ * Return value: %TRUE if the operation succeeded.
+ **/
+gboolean
+pango_win32_font_select_font (PangoFont *font,
+ HDC hdc)
+{
+ g_return_val_if_fail (PANGO_WIN32_IS_FONT (font), FALSE);
+
+ return PANGO_WIN32_FONT_GET_CLASS (font)->select_font (font, hdc);
+}
+
+/**
+ * pango_win32_font_done_font:
+ * @font: a #PangoFont from the win32 backend
+ *
+ * Releases any resources allocated by pango_win32_font_done_font()
+ **/
+void
+pango_win32_font_done_font (PangoFont *font)
+{
+ g_return_if_fail (PANGO_WIN32_IS_FONT (font));
+
+ PANGO_WIN32_FONT_GET_CLASS (font)->done_font (font);
+}
+
+/**
+ * pango_win32_font_get_scale_factor:
+ * @font: a #PangoFont from the win32 backend
+ *
+ * Returns the scale factor from logical units in the coordinate
+ * space used by pango_win32_font_select_font() to Pango units
+ * in user space.
+ *
+ * Return value: factor to multiply logical units by to get Pango
+ * units.
+ **/
+double
+pango_win32_font_get_scale_factor (PangoFont *font)
+{
+ g_return_val_if_fail (PANGO_WIN32_IS_FONT (font), 1.);
+
+ return PANGO_WIN32_FONT_GET_CLASS (font)->get_scale_factor (font);
+}
+
static void
pango_win32_font_dispose (GObject *object)
{
@@ -1179,15 +1278,14 @@ static struct type_4_cmap *
font_get_unicode_table (PangoFont *font)
{
PangoWin32Font *win32font = (PangoWin32Font *)font;
- HFONT hfont;
struct type_4_cmap *table;
if (win32font->win32face->unicode_table)
return (struct type_4_cmap *)win32font->win32face->unicode_table;
- hfont = pango_win32_get_hfont (font);
- SelectObject (pango_win32_hdc, hfont);
+ pango_win32_font_select_font (font, pango_win32_hdc);
table = get_unicode_mapping (pango_win32_hdc);
+ pango_win32_font_done_font (font);
win32font->win32face->unicode_table = table;
diff --git a/pango/pangowin32.def b/pango/pangowin32.def
index 72762c8c..2f0e308e 100644
--- a/pango/pangowin32.def
+++ b/pango/pangowin32.def
@@ -6,11 +6,16 @@ EXPORTS
pango_win32_font_entry_get_coverage
pango_win32_font_entry_remove
pango_win32_font_get_glyph_index
+ pango_win32_font_get_type
pango_win32_font_logfont
pango_win32_font_map_for_display
pango_win32_font_map_get_font_cache
+ pango_win32_font_map_get_type
pango_win32_font_new
pango_win32_font_logfont
+ pango_win32_font_done_font
+ pango_win32_font_get_scale_factor
+ pango_win32_font_select_font
pango_win32_fontmap_cache_add
pango_win32_fontmap_cache_remove
pango_win32_get_context
diff --git a/pango/pangowin32.h b/pango/pangowin32.h
index fb56d7f0..29903567 100644
--- a/pango/pangowin32.h
+++ b/pango/pangowin32.h
@@ -78,6 +78,11 @@ HDC pango_win32_get_dc (void);
gboolean pango_win32_get_debug_flag (void);
+gboolean pango_win32_font_select_font (PangoFont *font,
+ HDC hdc);
+void pango_win32_font_done_font (PangoFont *font);
+double pango_win32_font_get_scale_factor (PangoFont *font);
+
#endif
/* API for libraries that want to use PangoWin32 mixed with classic
diff --git a/pango/pangox.c b/pango/pangox.c
index 9668de44..6e1025a0 100644
--- a/pango/pangox.c
+++ b/pango/pangox.c
@@ -92,6 +92,7 @@ static void pango_x_font_get_glyph_extents (PangoFont *f
PangoRectangle *logical_rect);
static PangoFontMetrics * pango_x_font_get_metrics (PangoFont *font,
PangoLanguage *language);
+static PangoFontMap * pango_x_font_get_font_map (PangoFont *font);
static PangoXSubfontInfo * pango_x_find_subfont (PangoFont *font,
PangoXSubfont subfont_index);
@@ -944,6 +945,14 @@ pango_x_font_get_metrics (PangoFont *font,
return pango_font_metrics_ref (info->metrics);
}
+static PangoFontMap *
+pango_x_font_get_font_map (PangoFont *font)
+{
+ PangoXFont *xfont = (PangoXFont *)font;
+
+ return xfont->fontmap;
+}
+
/* Compare the tail of a to b */
static gboolean
match_end (char *a, char *b)