Shape Animation
Animations are visual effects that can be applied to texts, images, shapes, or charts. They give life to presentations or its constituents.
Why Use Animations in Presentations?
Using animations, you can
- control the flow of information
- emphasize important points
- increase interest or participation among your audience
- make content easier to read or assimilate or process
- draw your readers or viewers attention to important parts in a presentation
PowerPoint provides many options and tools for animations and animation effects across the entrance, exit, emphasis, and motion paths categories.
Animations in Aspose.Slides
- Aspose.Slides provides the classes and types you need to work with animations under the Aspose.Slides.Animation namespace,
- Aspose.Slides provides over 150 animation effects under the EffectType enumeration. These effects are essentially the same (or equivalent) effects used in PowerPoint.
Apply Animation to TextBox
Aspose.Slides for .NET allows you to apply animation to the text in a shape.
- Create an instance of the Presentation class.
- Get a slide’s reference through its index.
- Add a
rectangle
IAutoShape. - Add text to IAutoShape.TextFrame.
- Get a main sequence of effects.
- Add an animation effect to IAutoShape.
- Set the TextAnimation.BuildType property to the value from BuildType Enumeration.
- Write the presentation to disk as a PPTX file.
This C# code shows you how to apply the Fade
effect to AutoShape and set the text animation to the By 1st Level Paragraphs value:
// Instantiates a presentation class that represents a presentation file.
using (Presentation pres = new Presentation())
{
ISlide sld = pres.Slides[0];
// Adds new AutoShape with text
IAutoShape autoShape = sld.Shapes.AddAutoShape(ShapeType.Rectangle, 20, 20, 150, 100);
ITextFrame textFrame = autoShape.TextFrame;
textFrame.Text = "First paragraph \nSecond paragraph \n Third paragraph";
// Gets the main sequence of the slide.
ISequence sequence = sld.Timeline.MainSequence;
// Adds Fade animation effect to shape
IEffect effect = sequence.AddEffect(autoShape, EffectType.Fade, EffectSubtype.None, EffectTriggerType.OnClick);
// Animates shape text by 1st level paragraphs
effect.TextAnimation.BuildType = BuildType.ByLevelParagraphs1;
// Save the PPTX file to disk
pres.Save(path + "AnimText_out.pptx", SaveFormat.Pptx);
}
Apply Animation to PictureFrame
- Create an instance of the Presentation class.
- Get a slide’s reference through its index.
- Add or get a PictureFrame on the slide.
- Get the main sequence of effects.
- Add an animation effect to PictureFrame.
- Write the presentation to disk as a PPTX file.
This C# code shows you how to apply the Fly
effect to a picture frame:
// Instantiates a presentation class that represents a presentation file.
using (Presentation pres = new Presentation())
{
// Load Image to be added in presentaiton image collection
Image img = new Bitmap("aspose-logo.jpg");
IPPImage image = pres.Images.AddImage(img);
// Adds picture frame to slide
IPictureFrame picFrame = pres.Slides[0].Shapes.AddPictureFrame(ShapeType.Rectangle, 50, 50, 100, 100, image);
// Gets the main sequence of the slide.
ISequence sequence = pres.Slides[0].Timeline.MainSequence;
// Adds Fly from Left animation effect to picture frame
IEffect effect = sequence.AddEffect(picFrame, EffectType.Fly, EffectSubtype.Left, EffectTriggerType.OnClick);
// Save the PPTX file to disk
pres.Save(path + "AnimImage_out.pptx", SaveFormat.Pptx);
}
Apply Animation to Shape
- Create an instance of the Presentation class.
- Get a slide’s reference through its index.
- Add a
rectangle
IAutoShape. - Add a
Bevel
IAutoShape (when this object is clicked, the animation gets played). - Create a sequence of effects on the bevel shape.
- Create a custom
UserPath
. - Add commands for moving to the
UserPath
. - Write the presentation to disk as a PPTX file.
This C# code shows you how to apply the PathFootball
(path football) effect to a shape:
// Instantiates a Presentation class that represents a presentation file.
using (Presentation pres = new Presentation())
{
ISlide sld = pres.Slides[0];
// Creates PathFootball effect for existing shape from scratch.
IAutoShape ashp = sld.Shapes.AddAutoShape(ShapeType.Rectangle, 150, 150, 250, 25);
ashp.AddTextFrame("Animated TextBox");
// Adds the PathFootBall animation effect.
pres.Slides[0].Timeline.MainSequence.AddEffect(ashp, EffectType.PathFootball,
EffectSubtype.None, EffectTriggerType.AfterPrevious);
// Creates some kind of "button".
IShape shapeTrigger = pres.Slides[0].Shapes.AddAutoShape(ShapeType.Bevel, 10, 10, 20, 20);
// Creates a sequence of effects for the button.
ISequence seqInter = pres.Slides[0].Timeline.InteractiveSequences.Add(shapeTrigger);
// Creates a custom user path. Our object will be moved only after the button is clicked.
IEffect fxUserPath = seqInter.AddEffect(ashp, EffectType.PathUser, EffectSubtype.None, EffectTriggerType.OnClick);
// Adds commands for moving since created path is empty.
IMotionEffect motionBhv = ((IMotionEffect)fxUserPath.Behaviors[0]);
PointF[] pts = new PointF[1];
pts[0] = new PointF(0.076f, 0.59f);
motionBhv.Path.Add(MotionCommandPathType.LineTo, pts, MotionPathPointsType.Auto, true);
pts[0] = new PointF(-0.076f, -0.59f);
motionBhv.Path.Add(MotionCommandPathType.LineTo, pts, MotionPathPointsType.Auto, false);
motionBhv.Path.Add(MotionCommandPathType.End, null, MotionPathPointsType.Auto, false);
// Writes the PPTX file to disk
pres.Save("AnimExample_out.pptx", SaveFormat.Pptx);
}
Get the Animation Effects Applied to Shape
You may decide to find out the all animation effects applied to a single shape.
This C# code shows you how to get the all effects applied to a specific shape:
// Instantiates a presentation class that represents a presentation file.
using (Presentation pres = new Presentation("AnimExample_out.pptx"))
{
ISlide firstSlide = pres.Slides[0];
// Gets the main sequence of the slide.
ISequence sequence = firstSlide.Timeline.MainSequence;
// Gets the first shape on slide.
IShape shape = firstSlide.Shapes[0];
// Gets all animation effects applied to the shape.
IEffect[] shapeEffects = sequence.GetEffectsByShape(shape);
if (shapeEffects.Length > 0)
Console.WriteLine("The shape " + shape.Name + " has " + shapeEffects.Length + " animation effects.");
}
Change Animation Effect Timing Properties
Aspose.Slides for .NET allows you to change the Timing properties of an animation effect.
This is the Animation Timing pane and extended menu in Microsoft PowerPoint:
These are the correspondences between PowerPoint Timing and Effect.Timing properties:
- PowerPoint Timing Start drop-down list matches the Effect.Timing.TriggerType property.
- PowerPoint Timing Duration matches the Effect.Timing.Duration property. The duration of an animation (in seconds) is the total time it takes the animation to complete one cycle.
- PowerPoint Timing Delay matches the Effect.Timing.TriggerDelayTime property.
- PowerPoint Timing Repeat drop-down list matches these properties:
- Effect.Timing.RepeatCount property which describes the number of times the effect is repeated;
- Effect.Timing.RepeatUntilEndSlide flag which specifies whether the effect is repeated until the end of the slide;
- Effect.Timing.RepeatUntilNextClick flag which specifies whether the effect is repeated until the next click.
This is how you change the Effect Timing properties:
- Apply or get the animation effect.
- Set new values for the Effect.Timing properties you need.
- Save the modified PPTX file.
This C# code demonstrates the operation:
// Instantiates a presentation class that represents a presentation file.
using (Presentation pres = new Presentation("AnimExample_out.pptx"))
{
// Gets the main sequence of the slide.
ISequence sequence = pres.Slides[0].Timeline.MainSequence;
// Gets the first effect of main sequence.
IEffect effect = sequence[0];
// Changes effect TriggerType to start on click
effect.Timing.TriggerType = EffectTriggerType.OnClick;
// Changes effect Duration
effect.Timing.Duration = 3f;
// Changes effect TriggerDelayTime
effect.Timing.TriggerDelayTime = 0.5f;
// If the effect Repeat value is "none"
if (effect.Timing.RepeatCount == 1f)
{
// Changes effect Repeat to "Until Next Click"
effect.Timing.RepeatUntilNextClick = true;
}
else
{
// Changes effect Repeat to "Until End of Slide"
effect.Timing.RepeatUntilEndSlide = true;
}
// Saves the PPTX file to disk
pres.Save("AnimExample_changed.pptx", SaveFormat.Pptx);
}
Animation Effect Sound
Aspose.Slides provides these properties to allow you to work with sounds in animation effects:
Add Animation Effect Sound
This C# code shows you how to add an animation effect sound and stop it when the next effect starts:
using (Presentation pres = new Presentation("AnimExample_out.pptx"))
{
// Adds audio to presentation audio collection
IAudio effectSound = pres.Audios.AddAudio(File.ReadAllBytes("sampleaudio.wav"));
ISlide firstSlide = pres.Slides[0];
// Gets the main sequence of the slide.
ISequence sequence = firstSlide.Timeline.MainSequence;
// Gets the first effect of the main sequence
IEffect firstEffect = sequence[0];
// Сhecks the effect for "No Sound"
if (!firstEffect.StopPreviousSound && firstEffect.Sound == null)
{
// Adds sound for the first effect
firstEffect.Sound = effectSound;
}
// Gets the first interactive sequence of the slide.
ISequence interactiveSequence = firstSlide.Timeline.InteractiveSequences[0];
// Sets the effect "Stop previous sound" flag
interactiveSequence[0].StopPreviousSound = true;
// Writes the PPTX file to disk
pres.Save("AnimExample_Sound_out.pptx", SaveFormat.Pptx);
}
Extract Animation Effect Sound
- Create an instance of the Presentation class.
- Get a slide’s reference through its index.
- Get the main sequence of effects.
- Extract the Sound embedded to each animation effect.
This C# code shows you how to extract the sound embedded in an animation effect:
// Instantiates a presentation class that represents a presentation file.
using (Presentation presentation = new Presentation("EffectSound.pptx"))
{
ISlide slide = presentation.Slides[0];
// Gets the main sequence of the slide.
ISequence sequence = slide.Timeline.MainSequence;
foreach (IEffect effect in sequence)
{
if (effect.Sound == null)
continue;
// Extracts the effect sound in byte array
byte[] audio = effect.Sound.BinaryData;
}
}