Presentation Viewer

Aspose.Slides for .NET is used to create presentation files with slides. These slides can be viewed by opening presentations in Microsoft PowerPoint, for example. However, sometimes developers may need to view slides as images in their preferred image viewer or create their own presentation viewer. In such cases, Aspose.Slides allows you to export an individual slide as an image. This article describes how to do it.

Generate an SVG Image from a Slide

To generate an SVG image from a presentation slide with Aspose.Slides, please follow the steps below:

  1. Create an instance of the Presentation class.
  2. Get the slide reference by its index.
  3. Open a file stream.
  4. Save the slide as an SVG image to the file stream.
int slideIndex = 0;

using (Presentation presentation = new Presentation("sample.pptx"))
{
    ISlide slide = presentation.Slides[slideIndex];

    using (FileStream svgStream = File.Create("output.svg"))
    {
        slide.WriteAsSvg(svgStream);
    }
}

Generate an SVG with a Custom Shape ID

Aspose.Slides can be used to generate an SVG from a slide with a custom shape ID. To do this, use the Id property from ISvgShape. CustomSvgShapeFormattingController can be used to set the shape ID.

int slideIndex = 0;

using (Presentation presentation = new Presentation("sample.pptx"))
{
    ISlide slide = presentation.Slides[slideIndex];
    
    SVGOptions svgOptions = new SVGOptions
    {
        ShapeFormattingController = new CustomSvgShapeFormattingController()
    };

    using (FileStream svgStream = File.Create("output.svg"))
    {
        slide.WriteAsSvg(svgStream, svgOptions);
    }
}
class CustomSvgShapeFormattingController : ISvgShapeFormattingController
{
    private int m_shapeIndex;

    public CustomSvgShapeFormattingController(int shapeStartIndex = 0)
    {
        m_shapeIndex = shapeStartIndex;
    }

    public void FormatShape(ISvgShape svgShape, IShape shape)
    {
        svgShape.Id = string.Format("shape-{0}", m_shapeIndex++);
    }
}

Create a Slide Thumbnail Image

Aspose.Slides helps you generate thumbnail images of slides. To generate a thumbnail of a slide using Aspose.Slides, please follow the steps below:

  1. Create an instance of the Presentation class.
  2. Get the slide reference by its index.
  3. Get the thumbnail image of the referenced slide at a defined scale.
  4. Save the thumbnail image in any desired image format.
int slideIndex = 0;
float scaleX = 1;
float scaleY = scaleX;

using (Presentation presentation = new Presentation("sample.pptx"))
{
    ISlide slide = presentation.Slides[slideIndex];

    using (IImage image = slide.GetImage(scaleX, scaleY))
    {
        image.Save("output.jpg", ImageFormat.Jpeg);
    }
}

Create a Slide Thumbnail with User Defined Dimensions

To create a slide thumbnail image with user defined dimensions, please follow the steps below:

  1. Create an instance of the Presentation class.
  2. Get the slide reference by its index.
  3. Get the thumbnail image of the referenced slide with the defined dimensions.
  4. Save the thumbnail image in any desired image format.
int slideIndex = 0;
Size slideSize = new Size(1200, 800);

using (Presentation presentation = new Presentation("sample.pptx"))
{
    ISlide slide = presentation.Slides[slideIndex];

    using (IImage image = slide.GetImage(slideSize))
    {
        image.Save("output.jpg", ImageFormat.Jpeg);
    }
}

Create a Slide Thumbnail with Speaker Notes

To generate the thumbnail of a slide with speaker notes using Aspose.Slides, please follow the steps below:

  1. Create an instance of the RenderingOptions class.
  2. Use the RenderingOptions.SlidesLayoutOptions property to set the position of speaker notes.
  3. Create an instance of the Presentation class.
  4. Get the slide reference by its index.
  5. Get the thumbnail image of the referenced slide with the rendering options.
  6. Save the thumbnail image in any desired image format.
int slideIndex = 0;

RenderingOptions renderingOptions = new RenderingOptions
{
    SlidesLayoutOptions = new NotesCommentsLayoutingOptions
    {
        NotesPosition = NotesPositions.BottomTruncated
    }
};

using (Presentation presentation = new Presentation("sample.pptx"))
{
    ISlide slide = presentation.Slides[slideIndex];

    using (IImage image = slide.GetImage(renderingOptions))
    {
        image.Save("output.png", ImageFormat.Png);
    }
}

Live Example

You can try Aspose.Slides Viewer free app to see what you can implement with Aspose.Slides API:

Online PowerPoint Viewer