phpoffice / phppresentation
PHPPresentation - Read, Create and Write Presentations documents in PHP
Installs: 1 676 228
Dependents: 27
Suggesters: 0
Security: 0
Stars: 1 310
Watchers: 84
Forks: 523
Open Issues: 265
Requires
- php: ^7.1|^8.0
- ext-xml: *
- ext-zip: *
- phpoffice/common: ^1
- phpoffice/phpspreadsheet: ^1.9.0
Requires (Dev)
- phpmd/phpmd: 2.*
- phpstan/phpstan: ^0.12.88 || ^1.0.0
- phpunit/phpunit: >=7.0
Suggests
- ext-gd: Required to add images
README
PHPPresentation is a library written in pure PHP that provides a set of classes to write to different presentation file formats, i.e. Microsoft Office Open XML (OOXML or OpenXML) or OASIS Open Document Format for Office Applications (OpenDocument or ODF).
PHPPresentation is an open source project licensed under the terms of LGPL version 3. PHPPresentation is aimed to be a high quality software product by incorporating continuous integration and unit testing. You can learn more about PHPPresentation by reading the Developers' Documentation and the API Documentation.
Read more about PHPPresentation:
- Features
- Requirements
- Installation
- Getting started
- Contributing
- Developers' Documentation
- API Documentation
Features
- Create an in-memory presentation representation
- Set presentation meta data (author, title, description, etc)
- Add slides from scratch or from existing one
- Supports different fonts and font styles
- Supports different formatting, styles, fills, gradients
- Supports hyperlinks and rich-text strings
- Add images with different styles (positioning, rotation, shadow)
- Set printing options (header, footer, page margins, paper size, orientation)
- Set transitions between slides
- Output to different file formats: PowerPoint 2007 (.pptx), OpenDocument Presentation (.odp), Serialized Presentation)
- ... and lots of other things!
Requirements
PHPPresentation requires the following:
- PHP 7.1+
- ZIP Extension
- XML Parser Extension
- XMLWriter Extension (optional, used to write DOCX and ODT)
- GD Extension
Installation
Composer method
It is recommended that you install the PHPPresentation library through composer. To do so, add
the following lines to your composer.json
.
{ "require": { "phpoffice/phppresentation": "dev-master" } }
Manual download method
Alternatively, you can download the latest release from the releases page. In this case, you will have to register the autoloader. (Register autoloading is required only if you do not use composer in your project.)
require_once 'path/to/PhpPresentation/src/PhpPresentation/Autoloader.php'; \PhpOffice\PhpPresentation\Autoloader::register();
You will also need to download the latest PHPOffice/Common release from its releases page. And you will also have to register its autoloader, too.
require_once 'path/to/PhpOffice/Common/src/Common/Autoloader.php'; \PhpOffice\Common\Autoloader::register();
Getting started
The following is a basic usage example of the PHPPresentation library.
// with your own install require_once 'src/PhpPresentation/Autoloader.php'; \PhpOffice\PhpPresentation\Autoloader::register(); require_once 'src/Common/Autoloader.php'; \PhpOffice\Common\Autoloader::register(); // with Composer require_once 'vendor/autoload.php'; use PhpOffice\PhpPresentation\PhpPresentation; use PhpOffice\PhpPresentation\IOFactory; use PhpOffice\PhpPresentation\Style\Color; use PhpOffice\PhpPresentation\Style\Alignment; $objPHPPowerPoint = new PhpPresentation(); // Create slide $currentSlide = $objPHPPowerPoint->getActiveSlide(); // Create a shape (drawing) $shape = $currentSlide->createDrawingShape(); $shape->setName('PHPPresentation logo') ->setDescription('PHPPresentation logo') ->setPath('./resources/phppowerpoint_logo.gif') ->setHeight(36) ->setOffsetX(10) ->setOffsetY(10); $shape->getShadow()->setVisible(true) ->setDirection(45) ->setDistance(10); // Create a shape (text) $shape = $currentSlide->createRichTextShape() ->setHeight(300) ->setWidth(600) ->setOffsetX(170) ->setOffsetY(180); $shape->getActiveParagraph()->getAlignment()->setHorizontal( Alignment::HORIZONTAL_CENTER ); $textRun = $shape->createTextRun('Thank you for using PHPPresentation!'); $textRun->getFont()->setBold(true) ->setSize(60) ->setColor( new Color( 'FFE06B20' ) ); $oWriterPPTX = IOFactory::createWriter($objPHPPowerPoint, 'PowerPoint2007'); $oWriterPPTX->save(__DIR__ . "/sample.pptx"); $oWriterODP = IOFactory::createWriter($objPHPPowerPoint, 'ODPresentation'); $oWriterODP->save(__DIR__ . "/sample.odp");
More examples are provided in the samples folder. You can also read the Developers' Documentation and the API Documentation for more detail.
Contributing
We welcome everyone to contribute to PHPPresentation. Below are some of the things that you can do to contribute:
- Read our contributing guide
- Fork us and request a pull to the develop branch
- Submit bug reports or feature requests to GitHub
- Follow @PHPOffice on Twitter