X-Git-Url: http://git.asbjorn.biz/?p=swftools.git;a=blobdiff_plain;f=lib%2Fpdf%2FInfoOutputDev.h;h=4198b7d7ef2f30cdb7361769318383c8625ac0a4;hp=68b036f6b6c6274a4039adc4213db34502478a17;hb=fc713269e9d26d1be92f70e1ff0d508c94a65dba;hpb=cdcf434411b35bb57bc3de9dffa6314d6ac70d5f diff --git a/lib/pdf/InfoOutputDev.h b/lib/pdf/InfoOutputDev.h index 68b036f..4198b7d 100644 --- a/lib/pdf/InfoOutputDev.h +++ b/lib/pdf/InfoOutputDev.h @@ -44,8 +44,10 @@ #include "../gfxdevice.h" #include "../gfxtools.h" #include "../gfxfont.h" +#include "../q.h" #define INTERNAL_FONT_SIZE 1024.0 +#define GLYPH_IS_SPACE(g) ((!(g)->line || ((g)->line->type==gfx_moveTo && !(g)->line->next)) && (g)->advance) struct GlyphInfo { @@ -71,6 +73,7 @@ public: double lastx,lasty; int lastchar; + int lastadvance; double ascender,descender; @@ -80,9 +83,12 @@ public: double max_size; int num_glyphs; GlyphInfo**glyphs; - int*charid2glyph; + dict_t**kerning; + SplashFont*splash_font; char seen; + int space_char; + float average_advance; }; extern char*getFontID(GfxFont*font); @@ -103,7 +109,6 @@ class InfoOutputDev: public OutputDev int num_polygons; int num_textfields; - void finish(); void dumpfonts(gfxdevice_t*dev); InfoOutputDev(XRef*xref); @@ -117,6 +122,9 @@ class InfoOutputDev: public OutputDev virtual void drawLink(Link *link, Catalog *catalog); virtual double getMaximumFontSize(char*id); virtual void updateFont(GfxState *state); + + virtual void saveState(GfxState *state); + virtual void restoreState(GfxState *state); virtual GBool beginType3Char(GfxState *state, double x, double y, double dx, double dy, CharCode code, Unicode *u, int uLen); virtual void type3D0(GfxState *state, double wx, double wy);