Image Appears Stretched Out in the PDF Output
When publishing XML content (DITA, DocBook, etc.), images are sometimes scaled up in the PDF outputs but are displayed perfectly in the HTML (or WebHelp) output.
PDF output from XML content is obtained by first obtaining a intermediary XML format called XSL-FO and then applying an XSL-FO processor to it to obtain the PDF. This stretching problem is caused by the fact that all XSL-FO processors take into account the DPI (dots-per-inch) resolution when computing the size of the rendered image.
The PDF processor that comes out of the box with the application is the open-source Apache FOP processor. Here is what Apache FOP does when deciding the image size:
- If the XSL-FO output contains width, height or a scale specified for the image
external-graphic
tag, then these dimensions are used. This means that if in the XML (DITA, DocBook, etc.) you set explicit dimensions to the image they will be used as such in the PDF output. - If there are no sizes (width, height or scale) specified on the image XML element, the processor looks at the image resolution information available in the image content. If the image has such a resolution saved in it, the resolution will be used and combined with the image width and height to obtain the rendered image dimensions.
- If the image does not contain resolution information inside, Apache FOP will look
at the
FOP configuration file for a default resolution. The FOP configuration file for XSLT
transformations that output PDF is located in the
[OXYGEN_INSTALL_DIR]/lib/fop.xconf
. DITA publishing uses the DITA Open Toolkit that has the Apache FOP configuration file located in[DITA_OT_DIR/plugins/org.dita.pdf2/fop/conf/fop.xconf
. The configuration file contains two XML elements calledsource-resolution
andtarget-resolution
. The values set to those elements can be increased (usually a DPI value of 110 or 120 should render the image in PDF the same as in the HTML output).
The commercial RenderX XEP XSL-FO processor behaves similarly but as a fallback it uses 120 as the DPI value instead of using a configuration file.