// Start a page.
void startFrame(int width, int height);
virtual void startPage(int pageNum, GfxState *state, double x1, double y1, double x2, double y2) ;
void endframe();
// Start a page.
void startFrame(int width, int height);
virtual void startPage(int pageNum, GfxState *state, double x1, double y1, double x2, double y2) ;
void endframe();
virtual void type3D0(GfxState *state, double wx, double wy);
virtual void type3D1(GfxState *state, double wx, double wy, double llx, double lly, double urx, double ury);
virtual void type3D0(GfxState *state, double wx, double wy);
virtual void type3D1(GfxState *state, double wx, double wy, double llx, double lly, double urx, double ury);
private:
void drawGeneralImage(GfxState *state, Object *ref, Stream *str,
int width, int height, GfxImageColorMap*colorMap, GBool invert,
GBool inlineImg, int mask, int *maskColors,
Stream *maskStr, int maskWidth, int maskHeight, GBool maskInvert, GfxImageColorMap*maskColorMap);
private:
void drawGeneralImage(GfxState *state, Object *ref, Stream *str,
int width, int height, GfxImageColorMap*colorMap, GBool invert,
GBool inlineImg, int mask, int *maskColors,
Stream *maskStr, int maskWidth, int maskHeight, GBool maskInvert, GfxImageColorMap*maskColorMap);
- int SWFOutputDev::setGfxFont(char*id, char*filename, double quality);
+ int SWFOutputDev::setGfxFont(char*id, char*name, char*filename, double quality);
void strokeGfxline(GfxState *state, gfxline_t*line);
void clipToGfxLine(GfxState *state, gfxline_t*line);
void fillGfxLine(GfxState *state, gfxline_t*line);
void strokeGfxline(GfxState *state, gfxline_t*line);
void clipToGfxLine(GfxState *state, gfxline_t*line);
void fillGfxLine(GfxState *state, gfxline_t*line);
-SWFOutputDev::SWFOutputDev()
-{
- jpeginfo = 0;
- textmodeinfo = 0;
- ttfinfo = 0;
- linkinfo = 0;
- pbminfo = 0;
- type3active = 0;
- statepos = 0;
- xref = 0;
- substitutepos = 0;
- type3Warning = 0;
- user_movex = 0;
- user_movey = 0;
- user_clipx1 = 0;
- user_clipy1 = 0;
- user_clipx2 = 0;
- user_clipy2 = 0;
- current_text_stroke = 0;
- current_text_clip = 0;
- fontlist = 0;
- result = 0;
- outer_clip_box = 0;
- pages = 0;
- pagebuflen = 0;
- pagepos = 0;
- output = (gfxdevice_t*)malloc(sizeof(gfxdevice_t));
- gfxdevice_swf_init(output);
+SWFOutputDev::SWFOutputDev(gfxdevice_t*output)
+{
+ this->output = output;
+ this->jpeginfo = 0;
+ this->textmodeinfo = 0;
+ this->ttfinfo = 0;
+ this->linkinfo = 0;
+ this->pbminfo = 0;
+ this->type3active = 0;
+ this->statepos = 0;
+ this->xref = 0;
+ this->substitutepos = 0;
+ this->type3Warning = 0;
+ this->user_movex = 0;
+ this->user_movey = 0;
+ this->user_clipx1 = 0;
+ this->user_clipy1 = 0;
+ this->user_clipx2 = 0;
+ this->user_clipy2 = 0;
+ this->current_text_stroke = 0;
+ this->current_text_clip = 0;
+ this->fontlist = 0;
+ this->outer_clip_box = 0;
+ this->pages = 0;
+ this->pagebuflen = 0;
+ this->pagepos = 0;
+
- char* fontname = gstr==0?0:gstr->getCString();
- if(fontname==0) {
- char buf[32];
- Ref*r=font->getID();
- sprintf(buf, "UFONT%d", r->num);
- return strdup(buf);
+ char* fname = gstr==0?0:gstr->getCString();
+ char buf[128];
+ if(fname==0) {
+ sprintf(buf, "font-%d-%d", ref->num, ref->gen);
+ } else {
+ sprintf(buf, "%s-%d-%d", fname, ref->num, ref->gen);
- char*fontid = getFontID(font);
+ char*fontid;
+ GString*gstr = font->getName();
+ char* fname = gstr==0?0:gstr->getCString();
+ if(fname==0) {
+ char buf[32];
+ Ref*r=font->getID();
+ sprintf(buf, "UFONT%d", r->num);
+ fontid = strdup(buf);
+ }
+ fontid = strdup(fname);
+
char*fontname= 0;
char* plus = strchr(fontid, '+');
if(plus && plus < &fontid[strlen(fontid)-1]) {
char*fontname= 0;
char* plus = strchr(fontid, '+');
if(plus && plus < &fontid[strlen(fontid)-1]) {
- if(output) {
- this->result = output->finish(output);
- free(output);output=0;
- }
-}
-
-int SWFOutputDev::save(char*filename)
-{
- finish();
- return result->save(result, filename);
-}
-void* SWFOutputDev::get(char*name)
-{
- finish();
- return result->get(result, name);
- if(!name) {
- msg("<warning> Didn't find character '%s' (c=%d,u=%d) in current charset (%s, %d characters)",
- FIXNULL(name),c, u, FIXNULL((char*)current_font_id), current_gfxfont->num_glyphs);
- }
+ msg("<warning> Didn't find character '%s' (c=%d,u=%d) in current charset (%s, %d characters)",
+ FIXNULL(name),c, u, FIXNULL((char*)current_font_id), current_gfxfont->num_glyphs);
now (as there may be texts of other rendering modes in this
text object)- clipping objects have to wait until endTextObject,
however */
now (as there may be texts of other rendering modes in this
text object)- clipping objects have to wait until endTextObject,
however */
if((render&3) == RENDER_FILL) {
fillGfxLine(state, current_text_stroke);
gfxline_free(current_text_stroke);
if((render&3) == RENDER_FILL) {
fillGfxLine(state, current_text_stroke);
gfxline_free(current_text_stroke);
double x1, y1, x2, y2, w;
gfxline_t points[5];
int x, y;
double x1, y1, x2, y2, w;
gfxline_t points[5];
int x, y;
link->getRect(&x1, &y1, &x2, &y2);
cvtUserToDev(x1, y1, &x, &y);
link->getRect(&x1, &y1, &x2, &y2);
cvtUserToDev(x1, y1, &x, &y);
-int SWFOutputDev::setGfxFont(char*id, char*filename, double maxSize)
+int SWFOutputDev::setGfxFont(char*id, char*name, char*filename, double maxSize)
fileName = searchFont(fontname);
if(!fileName) showFontError(gfxFont,0);
fileName = searchFont(fontname);
if(!fileName) showFontError(gfxFont,0);
msg("<warning> Try specifying one or more font directories");
fileName = substituteFont(gfxFont, fontid);
msg("<warning> Try specifying one or more font directories");
fileName = substituteFont(gfxFont, fontid);
if(fontid) { free(fontid);fontid = strdup(substitutetarget[substitutepos-1]); /*ugly hack*/};
msg("<notice> Font is now %s (%s)", fontid, fileName);
}
if(fontid) { free(fontid);fontid = strdup(substitutetarget[substitutepos-1]); /*ugly hack*/};
msg("<notice> Font is now %s (%s)", fontid, fileName);
}
- if(!setGfxFont(fontid, 0, 0)) {
- setGfxFont(fontid, fileName, maxSize);
+ if(!setGfxFont(fontid, fontname, 0, 0)) {
+ setGfxFont(fontid, fontname, fileName, maxSize);
imgStr = new ImageStream(str, width, ncomps,bits);
imgStr->reset();
imgStr = new ImageStream(str, width, ncomps,bits);
imgStr->reset();
state->transform(1, 0, &x3, &y3); x3 += user_movex; y3 += user_movey;
state->transform(1, 1, &x4, &y4); x4 += user_movex; y4 += user_movey;
state->transform(1, 0, &x3, &y3); x3 += user_movex; y3 += user_movey;
state->transform(1, 1, &x4, &y4); x4 += user_movex; y4 += user_movey;
if(!pbminfo && !(str->getKind()==strDCT)) {
if(!type3active) {
msg("<notice> file contains pbm pictures %s",mask?"(masked)":"");
if(!pbminfo && !(str->getKind()==strDCT)) {
if(!type3active) {
msg("<notice> file contains pbm pictures %s",mask?"(masked)":"");
strcpy(config_file, dir);
strcat(config_file, dirseparator());
strcat(config_file, "add-to-xpdfrc");
strcpy(config_file, dir);
strcat(config_file, dirseparator());
strcat(config_file, "add-to-xpdfrc");
- swf_output_t*swf_output = (swf_output_t*)malloc(sizeof(swf_output_t));
- memset(swf_output, 0, sizeof(swf_output_t));
- swf_output_internal_t*i= (swf_output_internal_t*)malloc(sizeof(swf_output_internal_t));
- memset(i, 0, sizeof(swf_output_internal_t));
- swf_output->internal = i;
+ dev_output_t*dev_output = (dev_output_t*)malloc(sizeof(dev_output_t));
+ memset(dev_output, 0, sizeof(dev_output_t));
+ dev_output_internal_t*i= (dev_output_internal_t*)malloc(sizeof(dev_output_internal_t));
+ memset(i, 0, sizeof(dev_output_internal_t));
+ dev_output->internal = i;
-void swf_output_preparepage(swf_output_t*swf, int pdfpage, int outputpage)
+void dev_output_finish(dev_output_t*swf)
+{
+ dev_output_internal_t*i= (dev_output_internal_t*)swf->internal;
+ i->outputDev->finish();
+}
+
+void dev_output_preparepage(dev_output_t*swf, int pdfpage, int outputpage)
-int swf_output_save(swf_output_t*swf, char*filename)
-{
- swf_output_internal_t*i= (swf_output_internal_t*)swf->internal;
- int ret = i->outputDev->save(filename);
- return ret;
-}
-
-void* swf_output_get(swf_output_t*swf,char*name)
-{
- swf_output_internal_t*i= (swf_output_internal_t*)swf->internal;
- void* ret = i->outputDev->get(name);
- return ret;
-}
-
-void swf_output_destroy(swf_output_t*output)
+void dev_output_destroy(dev_output_t*output)
pi->doc->displayPage((OutputDev*)si->outputDev, page->nr, zoom, zoom, /*rotate*/0, true, true, /*doLinks*/(int)1);
}
pi->doc->displayPage((OutputDev*)si->outputDev, page->nr, zoom, zoom, /*rotate*/0, true, true, /*doLinks*/(int)1);
}
-void pdf_page_rendersection(pdf_page_t*page, swf_output_t*output, int x, int y, int x1, int y1, int x2, int y2)
+void pdf_page_rendersection(pdf_page_t*page, dev_output_t*output, int x, int y, int x1, int y1, int x2, int y2)
si->outputDev->setMove(x,y);
if((x1|y1|x2|y2)==0) x2++;
si->outputDev->setMove(x,y);
if((x1|y1|x2|y2)==0) x2++;
si->outputDev->setMove(0,0);
si->outputDev->setClip(0,0,0,0);
si->outputDev->setMove(0,0);
si->outputDev->setClip(0,0,0,0);