Layout Slide
This article demonstrates how to work with Layout Slides in Aspose.Slides for PHP via Java. A layout slide defines the design and formatting inherited by normal slides. You can add, access, clone, and remove layout slides, as well as clean up unused ones to reduce presentation size.
Add a Layout Slide
You can create a custom layout slide to define reusable formatting. For example, you might add a text box that appears on all slides using this layout.
function addLayoutSlide() {
$presentation = new Presentation();
try {
$masterSlide = $presentation->getMasters()->get_Item(0);
// Create a layout slide with a blank layout type and a custom name.
$layoutSlide = $presentation->getLayoutSlides()->add($masterSlide, SlideLayoutType::Blank, "Main layout");
$presentation->save("layout_slide.pptx", SaveFormat::Pptx);
} finally {
$presentation->dispose();
}
}
💡 Tip 1: Layout slides act as templates for individual slides. You can define common elements once and reuse them across many slides.
💡 Tip 2: When you add shapes or text to a layout slide, all slides based on that layout will display this shared content automatically. The screenshot below shows two slides, each inheriting a text box from the same layout slide.

Access a Layout Slide
Layout slides can be accessed by index or by layout type (e.g., Blank, Title, SectionHeader, etc.).
function accessLayoutSlide() {
$presentation = new Presentation("layout_slide.pptx");
try {
// Access by index.
$firstLayoutSlide = $presentation->getLayoutSlides()->get_Item(0);
// Access by layout type.
$blankLayoutSlide = $presentation->getLayoutSlides()->getByType(SlideLayoutType::Blank);
} finally {
$presentation->dispose();
}
}
Remove a Layout Slide
You can remove a specific layout slide if it’s no longer needed.
function removeLayoutSlide() {
$presentation = new Presentation("layout_slide.pptx");
try {
// Get a layout slide by type and remove it.
$layoutSlide = $presentation->getLayoutSlides()->getByType(SlideLayoutType::Custom);
$presentation->getLayoutSlides()->remove($layoutSlide);
$presentation->save("layout_slide_removed.pptx", SaveFormat::Pptx);
} finally {
$presentation->dispose();
}
}
Remove Unused Layout Slides
To reduce the presentation size, you may want to remove layout slides that are not used by any normal slides.
function removeUnusedLayoutSlides() {
$presentation = new Presentation("layout_slide.pptx");
try {
// Automatically removes all layout slides not referenced by any slide.
$presentation->getLayoutSlides()->removeUnused();
$presentation->save("layout_slides_removed.pptx", SaveFormat::Pptx);
} finally {
$presentation->dispose();
}
}
Clone a Layout Slide
You can duplicate a layout slide using the addClone method.
function cloneLayoutSlides() {
$presentation = new Presentation("layout_slide.pptx");
try {
// Get an existing layout slide by type.
$blankLayoutSlide = $presentation->getLayoutSlides()->getByType(SlideLayoutType::Blank);
// Clone the layout slide to the end of the layout slide collection.
$clonedLayoutSlide = $presentation->getLayoutSlides()->addClone($blankLayoutSlide);
$presentation->save("layout_slide_cloned.pptx", SaveFormat::Pptx);
} finally {
$presentation->dispose();
}
}
✅ Summary: Layout slides are powerful tools for managing consistent formatting across slides. Aspose.Slides allows full control over creating, managing, and optimizing layout slides.