Practical phppptx
Working with templates
Making a presentation from scratch can get complicated when, for example, you aim for a very elaborated design of the file or if you want to customize its content.
To simplify the presentation creation process, phppptx allows to use templates. In phppptx a template is a PPTX file, which contains one or multiple variables to be replaced.
To work with templates you have to use the class CreatePptxFromTemplate, which provides all necessary methods to modify presentations.
Template methods replace variables (template placeholders) in the slide target.
By default, phppptx uses the symbol '$' to wrap the variables to be replaced. Therefore, to define a variable with the name SIGN, add it to the presentation by writing $SIGN$.
If you prefer to work with another symbol, call the method setTemplateSymbol. For example, to use '#' as symbol for templates, apply the code:
Instead of using just one symbol, '${ }' and other symbols can also be used to wrap placeholders:
Create a new object using the class CreatePptxFromTemplate:
Now, replace the contents of this $pptx object.
The easiest element for replacing a placeholder is a string. replaceVariableText is the method to be used:
The available parameters are:
- $variables: placeholders to be replaced
- $options: it's an array which can have these keys:
- 'activeSlide' (bool): if true, get only the active slide. Default as false.
- 'target' (string): slides (default).
E.g., to replace VAR_1 and VAR_2 placeholders with new texts:
Images can be set to be replaced adding a placeholder in the alternate text option. In order to do this, just right click on it, open the image properties and search for the field alternate text (this name may vary in each version of MS PowerPoint). Type in this field the name of the placeholder, for example: $IMAGE$.
To replace an image, use the replaceVariableImage method:
The available parameters are:
- $variables: placeholders to be replaced
- $options: it's an array which can have these keys:
- 'activeSlide' (bool): if true, get only the active slide. Default as false.
- 'mime' (string): forces a mime (image/jpg, image/jpeg, image/png, image/gif).
- 'target' (string): slides (default).
E.g., to replace the image with placeholder $IMAGE_1$:
Just like with images, audio files can be replaced with new contents by defining a placeholder in the field alternate text when doing right click on it. The replaceVariableAudio method allows to replace audios:
The available parameters are:
- $variables: placeholders to be replaced
- $options: it's an array which can have these keys:
- 'activeSlide' (bool): if true, get only the active slide. Default as false.
- 'image' (string): use a custom image as audio image.
- 'mime' (string): forces a mime (audio/mpeg, audio/x-wav, audio/x-ms-wma, audio/unknown).
- 'target' (string): slides (default).
E.g., this replaces the AUDIO_1 placeholder with a new audio:
Video placeholders work in the same way as audios. A placeholder must be added in the field alternate text. The replaceVariableVideo method allows to replace videos:
The available parameters are:
- $variables: placeholders to be replaced
- $options: it's an array which can have these keys:
- 'activeSlide' (bool): if true, get only the active slide. Default as false.
- 'image' (string): use a custom image as video image.
- 'mime' (string): forces a mime (video/mp4, video/x-msvideo, video/x-ms-wmv, video/unknown).
- 'target' (string): slides (default).
E.g., this replaces the VAR_1 placeholder with a new video:
Replacing lists is as simple as adding a list with a single element in the template which contains the placeholder. When adding the new values, lists elements remain intact.
To add values to the list, use the replaceVariableList method:
The available parameters are:
- $variable: list placeholder
- $listValues: array with the values to add
- $options: it's an array which can have these keys:
- 'activeSlide' (bool): if true, get only the active slide. Default as false.
E.g., replace VAR_LIST:
Just like with the lists, tables can be added to the template by making a table with the chosen styles and defining a row with the variables to replace. This row will be replaced with as many rows as needed with new values, keeping the original table styles.
The available parameters are:
- $variables: multidimensional array with the table placeholders and its values. For each position of the array, a new row is created in the table.
- $options: it's an array which can have these keys:
- 'activeSlide' (bool): if true, get only the active slide. Default as false.
E.g., this replaces a table with placeholders:
The CreatePptxFromTemplate class inherits CreatePptx, so all methods available in this class can be used to add new contents, change settings and other tasks when using PPTX templates.
This is the code sample to add a text in a new text box:
Sometimes there's no need to replace every text placeholder, and some of them remain unused in the template. To delete placeholders, call removeVariableText:
The available options are:
- $variables: array of placeholders to remove
- $options: it's an array which can have these keys:
- 'activeSlide' (bool): if true, get only the active slide. Default as false.
- 'target' (string): slides (default).
E.g., to delete the placeholders HEADER_TITLE and HEADER_CUSTOM in the headers target:
The removeShapeSlide method allows to delete preset placeholder positions from the layout. This is a useful feature for deleting the placeholders defined in the layouts so they are not displayed in the presentation when they are not required to appear.
How to retrieve variables with getTemplateVariables: this method informs at any time which placeholders haven't been replaced. getTemplateVariables sends back an array with the variables by target.
Working with prefixes allows to carry an extensive control of every placeholder, divided by groups of work, and even permits to classify them by substitution priority. This makes easier its further replacement and deletion.
Contents with multiple styles and advanced contents can be added using PptxFragments with the following methods: replaceVariablePptxFragment, replaceVariableList, and replaceVariableTable