imal-h / pdf-box
Current Release of PDFlib provide you methods to convert PDF to Images as well as Images to PDF.
Installs: 319 994
Dependents: 0
Suggesters: 0
Security: 0
Stars: 57
Watchers: 8
Forks: 37
Open Issues: 11
Requires
- php: >=5.5.0
Requires (Dev)
- phpunit/phpunit: 4.*
- scrutinizer/ocular: ~1.1
README
PDFlib is a project which enables you to interact with PDFs, Current Release provide you methods to convert PDF to Images as well as Images to PDF, future releases will included more functions to interact with PDF files
This project is an initiative of Treinetic (Pvt) Ltd, Sri Lanka. contact us via info@treinetic.com and get your project done by the experts.
Requirements
You should have Ghostscript >= 9.16 installed and configured.
Install
The package can be installed via composer:
$ composer require imal-h/pdf-box
Usage
Converting a PDF to set of images.
$pdflib = new ImalH\PDFLib\PDFLib(); $pdflib->setPdfPath($pdf_file_path); $pdflib->setOutputPath($folder_path_for_images); $pdflib->setImageFormat(\ImalH\PDFLib\PDFLib::$IMAGE_FORMAT_PNG); $pdflib->setDPI(300); $pdflib->setPageRange(1,$pdflib->getNumberOfPages()); $pdflib->setFilePrefix('page-'); // Optional $pdflib->convert();
Alternatively using chaining:
$files = (new ImalH\PDFLib\PDFLib()) ->setPdfPath($pdf_file_path) ->setOutputPath($folder_path_for_images) ->setImageFormat(\ImalH\PDFLib\PDFLib::$IMAGE_FORMAT_PNG) ->setDPI(300) ->setPageRange(1,$pdflib->getNumberOfPages()) ->setFilePrefix('page-') // Optional ->convert();
Making a PDF from set of images
$pdflib = new ImalH\PDFLib\PDFLib(); $imagePaths = ["images-1.jpg","images-2.jpg"]; $pdflib->makePDF($destination_pdf_file_path,$imagePaths);
If in anycase code throws '**** Unable to open the initial device, quitting.' this type of error that means program can't create temporary files because of a permission problem, this error only comes in the Linux or Mac Oparating systems so Please check the apache log and provide necessay permissions
Other useful methods
You can get the total number of pages in the pdf:
$pdfBox->getNumberOfPages(); //returns the number of pages in the pdf $pdfBox->setPageRange(1,2); // allows you to convert only few pages in the PDF Document $pdfBox->setImageQuality(95); // allows you to tell the quality you expect in the output Jpg file (only jpg) $pdfBox->setDPI(300); //setting the DPI (Dots per inch) of output files $pdfLib->setImageFormat(\ImalH\PDFLib\PDFLib::$IMAGE_FORMAT_PNG,$dDownScaleFactor=null); //this will set the output image format, default it is jpg, but I recommend using pdf to png because it seems it is faster /* $dDownScaleFactor=integer This causes the internal rendering to be scaled down by the given (integer <= 8) factor before being output. For example, the following will produce a 200dpi output png from a 600dpi internal rendering: gs -sDEVICE=png16m -r600 -dDownScaleFactor=3 -o tiger.png\examples/tiger.png Read More : http://ghostscript.com/doc/current/Devices.htm */
Changelog
Please see CHANGELOG for more information what has changed recently.
Contributing
Please see CONTRIBUTING for details.
Tests
- Make sure to run all the tests and see all of them are pssing before sumbitting a pull requests
How to run Tests ?
composer install
vendor/bin/phpunit
Credits
License
The MIT License (MIT). Please see License File for more information.