set_option("searchpath={" . $searchpath . "}"); /* This means we must check return values of load_font() etc. */ $p->set_option("errorpolicy=return"); $p->set_option("stringformat=utf8"); if ($p->begin_document($outfile, "") == 0) throw new Exception("Error: " . $p->get_errmsg()); $p->set_info("Creator", "PDFlib Cookbook"); $p->set_info("Title", $title ); /* Import vector data from "kraxi_logo.pdf" to create the "LogoFont" * Type 3 font with one glyph "kraxi". Output text containing * the glyph by addressing via character reference value by glyph * name and via PUA value (Unicode Private Use Area). */ /* Load vector data from PDF file */ $indoc = $p->open_pdi_document($logofile, ""); if ($indoc == 0) throw new Exception("Error: " . $p->get_errmsg()); $page = $p->open_pdi_page($indoc, 1, ""); if ($page == 0) throw new Exception("Error: " . $p->get_errmsg()); /* Create the font LogoFont. The matrix entries are chosen to create * the common 1000x1000 coordinate system. These numbers are also * used when placing the logo within the glyph box below (option * "boxsize"). */ $p->begin_font("LogoFont", 0.001, 0.0, 0.0, 0.001, 0.0, 0.0, "colorized"); /* The .notdef (fallback) glyph should be contained in all Type 3 * fonts to avoid problems with some PDF viewers. It is usually * empty. */ $p->begin_glyph_ext(0x0000, "width=1000"); $p->end_glyph(); /* * Add a glyph with the name "kraxi" and width 1000. Colorized fonts * do not need any bounding box, so we supply the values 0, 0, 0, 0. * With colorized=false (the default) we could use 0, 0, 1000, 1000 * for the common 1000x1000 coordinate system. * * As there is no meaningful Unicode value for the logo, we let * PDFlib assign a PUA value. The glyph can be addressed via its * glyph name, or alternatively the Unicode PUA value can be * retrieved via the info_font() API call. */ $p->begin_glyph_ext(-1, "width=1000 glyphname=kraxi"); /* Fit the contents of the PDF in a box similar to the dimensions * of the glyph box. We place the glyph at (0, 100) in order to * slightly move up the logo so that it better matches standard * text. */ $p->fit_pdi_page($page, 0, 100, "boxsize={1000 1000} fitmethod=meet"); $p->end_glyph(); $p->end_font(); $p->close_pdi_page($page); $p->close_pdi_document($indoc); /* Load the new "LogoFont" font with encoding "unicode" */ $logofont = $p->load_font("LogoFont", "unicode", ""); if ($logofont == 0) throw new Exception("Error: " . $p->get_errmsg()); /* Load the "Helvetica" font */ $normalfont = $p->load_font("Helvetica", "unicode", ""); if ($normalfont == 0) throw new Exception("Error: " . $p->get_errmsg()); /* Start page */ $p->begin_page_ext(0, 0, "width=200 height=100"); /* For subsequent text switch on substitution of character references */ $p->set_text_option("charref=true"); /* Print the glyph "kraxi" of the "LogoFont" font */ $p->fit_textline("&.kraxi;", 10, 50, "font=" . $logofont . " fontsize=14"); /* Print standard text */ $p->fit_textline("This is the kraxi logo.", 30, 50, "font=" . $normalfont . " fontsize=14"); /* * Alternatively, fetch the PUA value, and address the glyph with * the PUA value. */ $kraxi_pua_value = (int) $p->info_font($logofont, "unicode", "glyphname=kraxi"); $kraxi_dec_charref = "&#" . $kraxi_pua_value . ";"; $p->fit_textline($kraxi_dec_charref, 170, 50, "font=" . $logofont . " fontsize=14"); /* Finish page */ $p->end_page_ext(""); $p->end_document(""); $buf = $p->get_buffer(); $len = strlen($buf); header("Content-type: application/pdf"); header("Content-Length: $len"); header("Content-Disposition: inline; filename=type3_vectorlogo.pdf"); print $buf; } catch (PDFlibException $e) { echo("PDFlib exception occurred:\n" . "[" . $e->get_errnum() . "] " . $e->get_apiname() . ": " . $e->get_errmsg() . "\n"); exit(1); } catch (Exception $e) { echo($e->getMessage()); exit(1); } $p = 0; ?>