X-Git-Url: http://git.asbjorn.biz/?p=swftools.git;a=blobdiff_plain;f=lib%2Fpdf%2FInfoOutputDev.h;h=66958da3c87d3a1d9a6453196e0a3b7a0b1d2b55;hp=532e2edc6bb9a600c0980247571bf8409ae63b5e;hb=62f28906ebae10fa325af43bf19315260c344303;hpb=5f1e7e9ebbac00effaae0545c32fe9060215d125 diff --git a/lib/pdf/InfoOutputDev.h b/lib/pdf/InfoOutputDev.h index 532e2ed..66958da 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 { @@ -58,26 +60,35 @@ struct GlyphInfo double advance_max; }; -struct FontInfo +class FontInfo { - FontInfo(); + gfxfont_t*gfxfont; + + char*id; +public: + FontInfo(char*id); ~FontInfo(); + gfxfont_t* getGfxFont(); + double lastx,lasty; int lastchar; + int lastadvance; double ascender,descender; void grow(int size); - gfxfont_t*gfxfont; GfxFont*font; 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); @@ -89,8 +100,6 @@ class InfoOutputDev: public OutputDev GlyphInfo* currentglyph; SplashOutputDev*splash; - gfxfont_t* createGfxFont(GfxFont*xpdffont, FontInfo*src); - public: int x1,y1,x2,y2; int num_links; @@ -100,7 +109,7 @@ class InfoOutputDev: public OutputDev int num_polygons; int num_textfields; - gfxfontlist_t*fonts; + void dumpfonts(gfxdevice_t*dev); InfoOutputDev(XRef*xref); virtual ~InfoOutputDev(); @@ -144,6 +153,7 @@ class InfoOutputDev: public OutputDev Stream *maskStr, int maskWidth, int maskHeight, GfxImageColorMap *maskColorMap); + virtual FontInfo* getFont(char*id); };