forked from syncfusion/xamarin-demos
-
Notifications
You must be signed in to change notification settings - Fork 0
/
SlideTransition.cs
137 lines (110 loc) · 5.25 KB
/
SlideTransition.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
#region Copyright Syncfusion Inc. 2001-2022.
// Copyright Syncfusion Inc. 2001-2022. All rights reserved.
// Use of this code is subject to the terms of our license.
// A copy of the current license can be obtained at any time by e-mailing
// [email protected]. Any infringement will be prosecuted under
// applicable laws.
#endregion
using Syncfusion.Presentation;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using COLOR = Syncfusion.Drawing;
using System.IO;
using System.Reflection;
using Android.App;
using Android.Content;
using Android.OS;
using Android.Runtime;
using Android.Views;
using Android.Widget;
namespace SampleBrowser
{
public partial class SlideTransitionPresentation : SamplePage
{
private Context m_context;
public override View GetSampleContent(Context con)
{
LinearLayout linear = new LinearLayout(con);
linear.SetBackgroundColor(Android.Graphics.Color.White);
linear.Orientation = Orientation.Vertical;
linear.SetPadding(10, 10, 10, 10);
TextView text1 = new TextView(con);
text1.TextSize = 17;
text1.TextAlignment = TextAlignment.Center;
text1.SetTextColor(Android.Graphics.Color.ParseColor("#262626"));
text1.Text = "This sample demonstrates how to create slide transition effects in PowerPoint presentation.";
text1.SetPadding(5, 10, 10, 5);
linear.AddView(text1);
TextView space = new TextView(con);
space.TextSize = 10;
linear.AddView(space);
m_context = con;
TextView space2 = new TextView(con);
space2.TextSize = 10;
linear.AddView(space2);
Button button1 = new Button(con);
button1.Text = "Generate Presentation";
button1.Click += OnButtonClicked;
linear.AddView(button1);
return linear;
}
void OnButtonClicked(object sender, EventArgs e)
{
string resourcePath = "SampleBrowser.Samples.Presentation.Templates.Transition.pptx";
Assembly assembly = Assembly.GetExecutingAssembly();
Stream fileStream = assembly.GetManifestResourceStream(resourcePath);
IPresentation presentation = Syncfusion.Presentation.Presentation.Open(fileStream);
//Create the transition effects on slides
CreateTransition(presentation);
MemoryStream stream = new MemoryStream();
presentation.Save(stream);
presentation.Close();
stream.Position = 0;
if (stream != null)
{
SaveAndroid androidSave = new SaveAndroid ();
androidSave.Save ("SlideTransitionSample.pptx", "application/powerpoint", stream, m_context);
}
}
#region Create Transition
private void CreateTransition(IPresentation presentation)
{
//Get the first slide from the presentation
ISlide slide1 = presentation.Slides[0];
// Add the 'Wheel' transition effect to the first slide
slide1.SlideTransition.TransitionEffect = Syncfusion.Presentation.SlideTransition.TransitionEffect.Wheel;
// Get the second slide from the presentation
ISlide slide2 = presentation.Slides[1];
// Add the 'Checkerboard' transition effect to the second slide
slide2.SlideTransition.TransitionEffect = Syncfusion.Presentation.SlideTransition.TransitionEffect.Checkerboard;
// Add the subtype to the transition effect
slide2.SlideTransition.TransitionEffectOption = Syncfusion.Presentation.SlideTransition.TransitionEffectOption.Across;
// Apply the value to transition mouse on click parameter
slide2.SlideTransition.TriggerOnClick = true;
// Get the third slide from the presentation
ISlide slide3 = presentation.Slides[2];
// Add the 'Orbit' transition effect for slide
slide3.SlideTransition.TransitionEffect = Syncfusion.Presentation.SlideTransition.TransitionEffect.Orbit;
// Add the speed for transition
slide3.SlideTransition.Speed = Syncfusion.Presentation.SlideTransition.TransitionSpeed.Fast;
// Get the fourth slide from the presentation
ISlide slide4 = presentation.Slides[3];
// Add the 'Uncover' transition effect to the slide
slide4.SlideTransition.TransitionEffect = Syncfusion.Presentation.SlideTransition.TransitionEffect.Uncover;
// Apply the value to advance on time for slide
slide4.SlideTransition.TriggerOnTimeDelay = true;
// Assign the advance on time value
slide4.SlideTransition.TimeDelay = 5;
// Get the fifth slide from the presentation
ISlide slide5 = presentation.Slides[4];
// Add the 'PageCurlDouble' transition effect to the slide
slide5.SlideTransition.TransitionEffect = Syncfusion.Presentation.SlideTransition.TransitionEffect.PageCurlDouble;
// Add the duration value for the transition effect
slide5.SlideTransition.Duration = 5;
}
#endregion
}
}