Animating in Response To User Interaction (VB)
The Animation control in the ASP.NET AJAX Control Toolkit is not just a control but a whole framework to add animations to a control. The animations can start automatically or may be triggered by user interaction, e.g. by clicking with the mouse.
Overview
The Animation control in the ASP.NET AJAX Control Toolkit is not just a control but a whole framework to add animations to a control. The animations can start automatically or may be triggered by user interaction, e.g. by clicking with the mouse.
Steps
First of all, include the ScriptManager
in the page; then, the ASP.NET AJAX library is loaded, making it possible to use the Control Toolkit:
[!code-aspxMain]
1: <asp:ScriptManager ID="asm" runat="server" />
The animation will be applied to a panel of text which looks like this:
[!code-aspxMain]
1: <asp:Panel ID="panelShadow" runat="server" CssClass="panelClass">
2: ASP.NET AJAX is a free framework for quickly creating a new generation of more
3: efficient, more interactive and highly-personalized Web experiences that work
4: across all the most popular browsers.<br />
5: ASP.NET AJAX is a free framework for quickly creating a new generation of more
6: efficient, more interactive and highly-personalized Web experiences that work
7: across all the most popular browsers.<br />
8: ASP.NET AJAX is a free framework for quickly creating a new generation of more
9: efficient, more interactive and highly-personalized Web experiences that work
10: across all the most popular browsers.<br />
11: </asp:Panel>
In the associated CSS class for the panel, define a nice background color and also set a fixed width for the panel:
[!code-cssMain]
1: <style type="text/css">
2: .panelClass {background-color: lime; width: 300px;}
3: </style>
Then, add the AnimationExtender
to the page, providing an ID
, the TargetControlID
attribute and the obligatory runat="server"
:
[!code-aspxMain]
1: <ajaxToolkit:AnimationExtender ID="ae" runat="server" TargetControlID="Panel1">
Within the <Animations>
node, there are five ways to start the animation via user interaction (the missing element is <OnLoad>
which is executed once the whole page has been fully loaded):
<OnClick>
(mouse click on the control)<OnHoverOut>
(mouse leaves the control)<OnHoverOver>
(mouse hovers over a control, stopping the<OnHoverOut>
animation)<OnMouseOut>
(mouse leaves a control)<OnMouseOver>
(mouse hovers over a control, not stopping the<OnMouseOut>
animation)
In this scenario, <OnClick>
is used. When the user clicks on the panel, it is resized and fades out at the same time.
[!code-aspxMain]
1: <ajaxToolkit:AnimationExtender ID="ae" runat="server" TargetControlID="Panel1">
2: <Animations>
3: <OnClick>
4: <Parallel>
5: <FadeOut Duration="1.5" Fps="24" />
6: <Resize Width="1000" Height="150" Unit="px" />
7: </Parallel>
8: </OnClick>
9: </Animations>
10: </ajaxToolkit:AnimationExtender>
A mouse click starts the animation (Click to view full-size image)
|