Bachir Soussi Chiadmi b936b1e616 commited all contents created by participants | 7 years ago | |
---|---|---|
.. | ||
Karla | 7 years ago | |
Reglo | 7 years ago | |
Volkorn | 7 years ago | |
lib | 7 years ago | |
src | 7 years ago | |
.travis~20171216-130144.yml | 7 years ago | |
CONTRIBUTING~20171216-130144.md | 7 years ago | |
LICENSE~20171216-130144.LGPL | 7 years ago | |
README~20171216-130144.md | 7 years ago | |
VERSION~20171216-130144 | 7 years ago | |
autoload.inc~20171216-130144.php | 7 years ago | |
composer~20171216-130144.json | 7 years ago | |
load_font~20171216-130144.php | 7 years ago | |
phpcs~20171216-130144.xml | 7 years ago | |
phpunit.xml~20171216-130144.dist | 7 years ago |
Dompdf is an HTML to PDF converter
At its heart, dompdf is (mostly) a CSS 2.1 compliant HTML layout and rendering engine written in PHP. It is a style-driven renderer: it will download and read external stylesheets, inline style tags, and the style attributes of individual HTML elements. It also supports most presentational HTML attributes.
This document applies to the latest stable code which may not reflect the current release. For released code please navigate to the appropriate tag.
Check out the demo and ask any question on StackOverflow or on the Google Groups.
Visit the wiki for more information: https://github.com/dompdf/dompdf/wiki/Requirements
PDF documents internally support the following fonts: Helvetica, Times-Roman, Courier, Zapf-Dingbats, & Symbol. These fonts only support Windows ANSI encoding. In order for a PDF to display characters that are not available in Windows ANSI you must supply an external font. Dompdf will embed any referenced font in the PDF so long as it has been pre-loaded or is accessible to dompdf and reference in CSS @font-face rules. See the font overview for more information on how to use fonts.
The DejaVu TrueType fonts have been pre-installed
to give dompdf decent Unicode character coverage by default. To use the DejaVu
fonts reference the font in your stylesheet, e.g. body { font-family: DejaVu
Sans; }
(for DejaVu Sans). The following DejaVu 2.34 fonts are available:
DejaVu Sans, DejaVu Serif, and DejaVu Sans Mono.
To install with Composer, simply require the latest version of this package.
composer require dompdf/dompdf
Make sure that the autoload file from Composer is loaded.
// somewhere early in your project's loading, require the Composer autoloader
// see: http://getcomposer.org/doc/00-intro.md
require 'vendor/autoload.php';
Download an archive of dompdf and extract it into the directory where dompdf will reside
Require dompdf, libraries, and helper functions in your PHP:
// include autoloader
require_once 'dompdf/autoload.inc.php';
From the command line, switch to the directory where dompdf will reside and run the following commands:
git clone https://github.com/dompdf/dompdf.git
cd dompdf
git clone https://github.com/PhenX/php-font-lib.git lib/php-font-lib
cd lib/php-font-lib
git checkout 0.4
cd ..
git clone https://github.com/PhenX/php-svg-lib.git php-svg-lib
cd php-svg-lib
git checkout v0.1
Require dompdf, libraries, and helper functions in your PHP:
// include autoloader
require_once 'dompdf/autoload.inc.php';
Just pass your HTML in to dompdf and stream the output:
// reference the Dompdf namespace
use Dompdf\Dompdf;
// instantiate and use the dompdf class
$dompdf = new Dompdf();
$dompdf->loadHtml('hello world');
// (Optional) Setup the paper size and orientation
$dompdf->setPaper('A4', 'landscape');
// Render the HTML as PDF
$dompdf->render();
// Output the generated PDF to Browser
$dompdf->stream();
Set options during dompdf instantiation:
use Dompdf\Dompdf;
use Dompdf\Options;
$options = new Options();
$options->set('defaultFont', 'Courier');
$dompdf = new Dompdf($options);
or at run time
use Dompdf\Dompdf;
$dompdf = new Dompdf();
$dompdf->set_option('defaultFont', 'Courier');
See Dompdf\Options for a list of available options.
$dompdf->set_option('isHtml5ParserEnabled', true);
)
or run your HTML through a HTML validator/cleaner (such as
Tidy or the
W3C Markup Validation Service).If you find this project useful, please consider making a donation. Any funds donated will be used to help further development on this project.)