Convert PowerPoint Presentations to Video in C#
Overview
By converting your PowerPoint or OpenDocument presentation to video, you gain:
Increased accessibility: All devices, regardless of platform, are equipped with video players by default, making it easier for users to open or play videos compared to traditional presentation applications.
Wider reach: Videos enable you to reach a larger audience and present information in a more engaging format. Surveys and statistics indicate that people prefer to watch and consume video content over other forms, making your message more impactful.
In Aspose.Slides for .NET, we implemented support for converting presentations to video.
- Use Aspose.Slides for .NET to generate frames from the presentation slides at a specified frame rate (FPS).
- Then, use a third-party utility like ffmpeg to compile these frames into a video.
Convert a PowerPoint Presentation to Video
- Use the
dotnet add package
command to add Aspose.Slides and the FFMpegCore library to your project:- run
dotnet add package Aspose.Slides.NET --version 22.11.0
- run
dotnet add package FFMpegCore --version 4.8.0
- run
- Dowload ffmpeg from here.
- FFMpegCore requires you to specify the path to the downloaded ffmpeg (e.g., extracted to “C:\tools\ffmpeg”):
GlobalFFOptions.Configure(new FFOptions { BinaryFolder = @"c:\tools\ffmpeg\bin" });
- Run the PowerPoint-to-video conversion code.
This C# code demonstrates how to convert a presentation (containing a shape and two animation effects) into a video:
using System.Collections.Generic;
using Aspose.Slides;
using FFMpegCore; // will use the FFmpeg binaries we extracted to C:\tools\ffmpeg earlier.
using Aspose.Slides.Animation;
using (Presentation presentation = new Presentation())
{
ISlide slide = presentation.Slides[0];
// Add a smile shape and then animate it.
IAutoShape smile = slide.Shapes.AddAutoShape(ShapeType.SmileyFace, 110, 20, 500, 500);
IEffect effectIn = slide.Timeline.MainSequence.AddEffect(
smile, EffectType.Fly, EffectSubtype.TopLeft, EffectTriggerType.AfterPrevious);
IEffect effectOut = slide.Timeline.MainSequence.AddEffect(
smile, EffectType.Fly, EffectSubtype.BottomRight, EffectTriggerType.AfterPrevious);
effectIn.Timing.Duration = 2f;
effectOut.PresetClassType = EffectPresetClassType.Exit;
const int Fps = 33;
List<string> frames = new List<string>();
using (var animationsGenerator = new PresentationAnimationsGenerator(presentation))
using (var player = new PresentationPlayer(animationsGenerator, Fps))
{
player.FrameTick += (sender, args) =>
{
string frame = $"frame_{(sender.FrameIndex):D4}.png";
args.GetFrame().Save(frame);
frames.Add(frame);
};
animationsGenerator.Run(presentation.Slides);
}
// Configure the ffmpeg binaries folder. See this page: https://github.com/rosenbjerg/FFMpegCore#installation
GlobalFFOptions.Configure(new FFOptions { BinaryFolder = @"c:\tools\ffmpeg\bin" });
// Convert the frames to a webm video.
FFMpeg.JoinImageSequence("smile.webm", Fps, frames.Select(frame => ImageInfo.FromPath(frame)).ToArray());
}
Video Effects
When converting a PowerPoint presentation to video using Aspose.Slides for .NET, you can apply various video effects to enhance the visual quality of the output. These effects allow you to control the appearance of slides in the final video by adding smooth transitions, animations, and other visual elements. This section explains the available video effect options and shows how to apply them.
See:
Animations and transitions make slideshows more engaging and interesting — and they do the same for videos. Let’s add another slide and transition to the code for the previous presentation:
// Add a smile shape and animate it.
// ...
// Add a new slide and an animated transition.
ISlide newSlide = presentation.Slides.AddEmptySlide(presentation.Slides[0].LayoutSlide);
newSlide.Background.Type = BackgroundType.OwnBackground;
newSlide.Background.FillFormat.FillType = FillType.Solid;
newSlide.Background.FillFormat.SolidFillColor.Color = Color.Indigo;
newSlide.SlideShowTransition.Type = TransitionType.Push;
Aspose.Slides also supports text animations. In this example, we animate paragraphs on objects so that they appear one after the other, with a one-second delay between them:
using System.Collections.Generic;
using Aspose.Slides.Export;
using Aspose.Slides;
using FFMpegCore;
using Aspose.Slides.Animation;
using (Presentation presentation = new Presentation())
{
ISlide slide = presentation.Slides[0];
// Add text and animations.
IAutoShape autoShape = slide.Shapes.AddAutoShape(ShapeType.Rectangle, 210, 120, 300, 300);
Paragraph para1 = new Paragraph();
para1.Portions.Add(new Portion("Aspose Slides for .NET"));
Paragraph para2 = new Paragraph();
para2.Portions.Add(new Portion("Convert a PowerPoint presentation with text to video"));
Paragraph para3 = new Paragraph();
para3.Portions.Add(new Portion("paragraph by paragraph"));
autoShape.TextFrame.Paragraphs.Add(para1);
autoShape.TextFrame.Paragraphs.Add(para2);
autoShape.TextFrame.Paragraphs.Add(para3);
autoShape.TextFrame.Paragraphs.Add(new Paragraph());
IEffect effect1 = slide.Timeline.MainSequence.AddEffect(
para1, EffectType.Appear, EffectSubtype.None, EffectTriggerType.AfterPrevious);
IEffect effect2 = slide.Timeline.MainSequence.AddEffect(
para2, EffectType.Appear, EffectSubtype.None, EffectTriggerType.AfterPrevious);
IEffect effect3 = slide.Timeline.MainSequence.AddEffect(
para3, EffectType.Appear, EffectSubtype.None, EffectTriggerType.AfterPrevious);
IEffect effect4 = slide.Timeline.MainSequence.AddEffect(
para3, EffectType.Appear, EffectSubtype.None, EffectTriggerType.AfterPrevious);
effect1.Timing.TriggerDelayTime = 1f;
effect2.Timing.TriggerDelayTime = 1f;
effect3.Timing.TriggerDelayTime = 1f;
effect4.Timing.TriggerDelayTime = 1f;
const int Fps = 33;
List<string> frames = new List<string>();
using (var animationsGenerator = new PresentationAnimationsGenerator(presentation))
using (var player = new PresentationPlayer(animationsGenerator, Fps))
{
player.FrameTick += (sender, args) =>
{
string frame = $"frame_{(sender.FrameIndex):D4}.png";
args.GetFrame().Save(frame);
frames.Add(frame);
};
animationsGenerator.Run(presentation.Slides);
}
// Configure the ffmpeg binaries folder. See this page: https://github.com/rosenbjerg/FFMpegCore#installation
GlobalFFOptions.Configure(new FFOptions { BinaryFolder = @"c:\tools\ffmpeg\bin" });
// Convert the frames to a webm video.
FFMpeg.JoinImageSequence("text_animation.webm", Fps, frames.Select(frame => ImageInfo.FromPath(frame)).ToArray());
}
Video Conversion Classes
To enable PowerPoint to video conversion tasks, Aspose.Slides for .NET provides the PresentationAnimationsGenerator and PresentationPlayer classes.
PresentationAnimationsGenerator
allows you to set the frame size for the video (which will be created later) and the FPS (frames per second) value through its constructor. If you pass an instance of a presentation, its Presentation.SlideSize
will be used and it generates animations that PresentationPlayer uses.
When animations are generated, a NewAnimation
event is triggered for each subsequent animation, which includes an IPresentationAnimationPlayer parameter. This class represents a player for an individual animation.
To work with IPresentationAnimationPlayer, you use the Duration property (which gives the full duration of the animation) and the SetTimePosition method. Each animation position is set within the 0 to duration range, and the GetFrame
method then returns a Bitmap representing the animation state at that point in time.
using (Presentation presentation = new Presentation())
{
ISlide slide = presentation.Slides[0];
// Add a smile shape and animate it.
IAutoShape smile = slide.Shapes.AddAutoShape(ShapeType.SmileyFace, 110, 20, 500, 500);
IEffect effectIn = slide.Timeline.MainSequence.AddEffect(
smile, EffectType.Fly, EffectSubtype.TopLeft, EffectTriggerType.AfterPrevious);
IEffect effectOut = slide.Timeline.MainSequence.AddEffect(
smile, EffectType.Fly, EffectSubtype.BottomRight, EffectTriggerType.AfterPrevious);
effectIn.Timing.Duration = 2f;
effectOut.PresetClassType = EffectPresetClassType.Exit;
using (var animationsGenerator = new PresentationAnimationsGenerator(presentation))
{
animationsGenerator.NewAnimation += animationPlayer =>
{
Console.WriteLine($"Total animation duration: {animationPlayer.Duration}");
animationPlayer.SetTimePosition(0); // The initial animation state.
Bitmap bitmap = animationPlayer.GetFrame(); // The initial animation state bitmap.
animationPlayer.SetTimePosition(animationPlayer.Duration); // The final state of the animation.
Bitmap lastBitmap = animationPlayer.GetFrame(); // The last frame of the animation.
lastBitmap.Save("last.png");
};
}
}
To make all animations in a presentation play at once, the PresentationPlayer class is used. This class takes a PresentationAnimationsGenerator instance and an FPS value for effects in its constructor, and then calls the FrameTick
event for all animations to play them:
using (Presentation presentation = new Presentation("animated.pptx"))
{
using (var animationsGenerator = new PresentationAnimationsGenerator(presentation))
using (var player = new PresentationPlayer(animationsGenerator, 33))
{
player.FrameTick += (sender, args) =>
{
args.GetFrame().Save($"frame_{sender.FrameIndex}.png");
};
animationsGenerator.Run(presentation.Slides);
}
}
Then the generated frames can be compiled to produce a video. See the Convert a PowerPoint Presentation to Video section.
Supported Animations and Effects
When converting a PowerPoint presentation to video using Aspose.Slides for .NET, it’s important to understand which animations and effects are supported in the output. Aspose.Slides supports a wide range of common entrance, exit, and emphasis effects such as fade, fly in, zoom, and spin. However, some advanced or custom animations may not be fully preserved or may appear differently in the final video. This section outlines the supported animations and effects.
Entrance:
Animation Type | Aspose.Slides | PowerPoint |
---|---|---|
Appear | ![]() |
![]() |
Fade | ![]() |
![]() |
Fly In | ![]() |
![]() |
Float In | ![]() |
![]() |
Split | ![]() |
![]() |
Wipe | ![]() |
![]() |
Shape | ![]() |
![]() |
Wheel | ![]() |
![]() |
Random Bars | ![]() |
![]() |
Grow & Turn | ![]() |
![]() |
Zoom | ![]() |
![]() |
Swivel | ![]() |
![]() |
Bounce | ![]() |
![]() |
Emphasis:
Animation Type | Aspose.Slides | PowerPoint |
---|---|---|
Pulse | ![]() |
![]() |
Color Pulse | ![]() |
![]() |
Teeter | ![]() |
![]() |
Spin | ![]() |
![]() |
Grow/Shrink | ![]() |
![]() |
Desaturate | ![]() |
![]() |
Darken | ![]() |
![]() |
Lighten | ![]() |
![]() |
Transparency | ![]() |
![]() |
Object Color | ![]() |
![]() |
Complementary Color | ![]() |
![]() |
Line Color | ![]() |
![]() |
Fill Color | ![]() |
![]() |
Exit:
Animation Type | Aspose.Slides | PowerPoint |
---|---|---|
Disappear | ![]() |
![]() |
Fade | ![]() |
![]() |
Fly Out | ![]() |
![]() |
Float Out | ![]() |
![]() |
Split | ![]() |
![]() |
Wipe | ![]() |
![]() |
Shape | ![]() |
![]() |
Random Bars | ![]() |
![]() |
Shrink & Turn | ![]() |
![]() |
Zoom | ![]() |
![]() |
Swivel | ![]() |
![]() |
Bounce | ![]() |
![]() |
Motion Paths:
Animation Type | Aspose.Slides | PowerPoint |
---|---|---|
Lines | ![]() |
![]() |
Arcs | ![]() |
![]() |
Turns | ![]() |
![]() |
Shapes | ![]() |
![]() |
Loops | ![]() |
![]() |
Custom Path | ![]() |
![]() |
Supported Slide Transition Effects
Slide transition effects play an important role in creating smooth and visually appealing changes between slides in a video. Aspose.Slides for .NET supports a variety of commonly used transition effects to help preserve the flow and style of your original presentation. This section highlights which transition effects are supported during the conversion process.
Subtle:
Animation Type | Aspose.Slides | PowerPoint |
---|---|---|
Morph | ![]() |
![]() |
Fade | ![]() |
![]() |
Push | ![]() |
![]() |
Pull | ![]() |
![]() |
Wipe | ![]() |
![]() |
Split | ![]() |
![]() |
Reveal | ![]() |
![]() |
Random Bars | ![]() |
![]() |
Shape | ![]() |
![]() |
Uncover | ![]() |
![]() |
Cover | ![]() |
![]() |
Flash | ![]() |
![]() |
Strips | ![]() |
![]() |
Exciting:
Animation Type | Aspose.Slides | PowerPoint |
---|---|---|
Fall Over | ![]() |
![]() |
Drape | ![]() |
![]() |
Curtains | ![]() |
![]() |
Wind | ![]() |
![]() |
Prestige | ![]() |
![]() |
Fracture | ![]() |
![]() |
Crush | ![]() |
![]() |
Peel Off | ![]() |
![]() |
Page Curl | ![]() |
![]() |
Airplane | ![]() |
![]() |
Origami | ![]() |
![]() |
Dissolve | ![]() |
![]() |
Checkerboard | ![]() |
![]() |
Blinds | ![]() |
![]() |
Clock | ![]() |
![]() |
Ripple | ![]() |
![]() |
Honeycomb | ![]() |
![]() |
Glitter | ![]() |
![]() |
Vortex | ![]() |
![]() |
Shred | ![]() |
![]() |
Switch | ![]() |
![]() |
Flip | ![]() |
![]() |
Gallery | ![]() |
![]() |
Cube | ![]() |
![]() |
Doors | ![]() |
![]() |
Box | ![]() |
![]() |
Comb | ![]() |
![]() |
Zoom | ![]() |
![]() |
Random | ![]() |
![]() |
Dynamic Content:
Animation Type | Aspose.Slides | PowerPoint |
---|---|---|
Pan | ![]() |
![]() |
Ferris Wheel | ![]() |
![]() |
Conveyor | ![]() |
![]() |
Rotate | ![]() |
![]() |
Orbit | ![]() |
![]() |
Fly Through | ![]() |
![]() |
FAQs
Is it possible to convert presentations that are password protected?
Yes, Aspose.Slides for .NET allows working with password-protected presentations. When processing such files, you need to provide the correct password so that the library can access the content of the presentation.
Does Aspose.Slides for .NET support usage in cloud solutions?
Yes, Aspose.Slides for .NET can be integrated into cloud applications and services. The library is designed to work in server environments, ensuring high performance and scalability for batch processing of files.
Are there any size limitations for presentations during conversion?
Aspose.Slides for .NET is capable of handling presentations of virtually any size. However, when working with very large files, additional system resources may be required, and it is sometimes recommended to optimize the presentation to improve performance.