Need help with PHPPresentation?
Click the “chat” button below for chat support from the developer who created it, or find similar developers for support.

About the developer

PHPOffice
1.1K Stars 431 Forks Other 928 Commits 242 Opened issues

Description

A pure PHP library for reading and writing presentations documents

Services available

!
?

Need anything else?

Contributors list

# 8,236
PHP
Docker
ods
excel
522 commits
# 8,520
PHP
Shell
odt
HTML
39 commits
# 27,219
C#
PHP
phpstor...
ods
21 commits
# 227,507
pptx
PHP
Shell
powerpo...
13 commits
# 29,970
PHP
openapi
swagger
HTML
9 commits
# 279,612
pptx
PHP
Shell
powerpo...
7 commits
# 292,332
pptx
PHP
Shell
powerpo...
6 commits
# 293,276
pptx
PHP
Shell
powerpo...
6 commits
# 128,657
Bash
C
ffmpeg
dtw
5 commits
# 9,477
PHP
Laravel
PHPUnit
phpstan
5 commits
# 212,967
PHP
HTML
Shell
powerpo...
5 commits
# 40,051
PHP
Nextclo...
vala
Symfony
4 commits
# 112,453
MySQL
PHP
html5
postgre...
4 commits
# 356,184
pptx
PHP
Shell
powerpo...
3 commits
# 327,319
PHP
pptx
Shell
powerpo...
3 commits
# 270,354
PHP
HTML
Django
Shell
3 commits
# 356,515
pptx
PHP
Shell
powerpo...
3 commits
# 225,228
C
Shell
C++
powerpo...
2 commits
# 395,117
pptx
PHP
Shell
powerpo...
2 commits
# 394,399
pptx
PHP
Shell
powerpo...
2 commits

PHPPresentation

Latest Stable Version Code Climate Test Coverage Total Downloads License BountySource Join the chat at https://gitter.im/PHPOffice/PHPPresentation

Branch Master : Build Status Documentation Status Branch Develop : Build Status Documentation Status

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

  • 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:

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:

We use cookies. If you continue to browse the site, you agree to the use of cookies. For more information on our use of cookies please see our Privacy Policy.