-
Notifications
You must be signed in to change notification settings - Fork 0
/
README
95 lines (71 loc) · 3.59 KB
/
README
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
Pango is a library for layout and rendering of text, with an emphasis
on internationalization. Pango can be used anywhere that text layout
is needed; however, most of the work on Pango so far has been done using
the GTK+ widget toolkit as a test platform. Pango forms the core of text
and font handling for GTK+-2.x.
Pango is designed to be modular; the core Pango layout can be used
with different font backends. There are three basic backends, with
multiple options for rendering with each.
- Client side fonts using the FreeType and fontconfig libraries.
Rendering can be with with Cairo or Xft libraries, or directly
to an in-memory buffer with no additional libraries.
- Native fonts on Microsoft Windows using Uniscribe if available for
complex script handling. Rendering can be done via Cairo or
directly using the native Win32 API.
- Native fonts on MacOS X, rendering via Cairo.
The integration of Pango with Cairo (http://cairographics.org)
provides a complete solution with high quality text handling
and graphics rendering.
Dynamically loaded modules then handle text layout for particular
combinations of script and font backend.
As well as the low level layout rendering routines, Pango includes
PangoLayout, a high level driver for laying out entire blocks of text,
and routines to assist in editing internationalized text.
For more information about Pango, see:
http://www.pango.org/
Dependencies
============
Pango depends on the GLib library; more information about GLib can
be found at http://www.gtk.org/.
When using client side fonts, the fontconfig library
(http://www.fontconfig.org) to look up fonts. At least version 2.0.9
of the FreeType font handling library (http://www.freetype.org) is
also required.
Cairo support depends on the Cairo library (http://cairographics.org).
The Cairo backend is the preferred backend to use Pango with and is
subject of most of the development in the future. It has the
advantage that the same code can be used for display and printing.
We suggest using Pango with Cairo as described above, but you can also
do X-specific rendering using the Xft library. The Xft backend uses
version 2 of the Xft library to manage client side fonts. Version 2 of
Xft is available from http://xlibs.freedesktop.org/release/. You'll
need the libXft package, and possibly the libXrender and renderext
packages as well. You'll also need fontconfig (see below.)
Installation of Pango on Win32 is possible, but is not documented
here. See http://www.gimp.org/~tml/gimp/win32/downloads.html
Notes
=====
- By default, Pango tries to build itself so that no explicit
dependency on Xft or FreeType will be introduced in apps that
link to Pango. This is to avoid compatibility problems with
changes in the Xft or FreeType API's or ABI's. Specifying
--enable-explicit-deps or --enable-static when configuring Pango
will defeat this and should be avoided if possible.
License
=======
Most of the code of Pango is licensed under the terms of the
GNU Lesser Public License (LGPL) - see the file COPYING for details.
The OpenType code in pango/opentype is derived from the FreeType
project (http://www.freetype.org) and is dual-licensed under the
GNU General Public License and the FreeType license. See see
pango/opentype/FT-license.txt for full details of the FreeType
license.
Note that binary distributions of Pango must include a disclaimer
that the software is based in part of the work of the FreeType Team,
in the distribution documentation; for instance, by including this
README file.
Owen Taylor
otaylor@redhat.com
Behdad Esfahbod
behdad@gnome.org
26 February 2007