Create a Zooming Button Style In Silverlight Without Code
Download code for this sample (updated for RCW)
I was reading Mike Snow’s blog and he had a recent Silverlight tutorial on creating a Zooming toolbar. I looked at it and said to myself, “I think I can do that without code in Blend!” So here’s a tutorial on exactly that.
End product :
Big bonuses to this XAML-only method include:
- Much smoother animation
- Midway animation (if you fly over a button, it doesn’t need to animate all the way up before it starts to animate back down)
- Really low overhead
- Can be done and maintained entirely by a designer in Blend without any code
1) create a new Silverlight project in either Visual Studio 2008 or Blend 2.5.
2) In Blend, add a new folder for our images by right-clicking on the project and selecting “Add New Folder”
3) Pull in our images by right-clicking on our new folder and selecting “Add Existing Item…” Navigate to the images you want to use and select “OK” to bring them into the project.
4) Create the button to which you want to add the image and then double-click it in the Obejcts and Timeline pane so that it has a yellow outline around it.
5) Now, go to the image you want to insert (in the Project panel), right click on it and select “Insert”
OK… so now we have a button with an image in it. Now it’s time to make the sucker zoom.
6) Right click on the button and select “Edit Control Parts (Template) -> Edit a Copy…”
Name your custom Template and hit OK
7) In the “States” pane, you see a set of “CommonStates” (Normal, MouseOver, Pressed, and Disabled). Click on the MouseOver state and a red box will surround your composition, indicating that any changes made will be changes to the “Mouse Over” state, not to the default control.
8] Click on the highest level item in the template (in my case, it is a “Grid”) and go to the “Transform” section in the “Properties” pane and select the “Scale” transformation tab. Change the X and Y scales to “1.5”
If you run the project now, you’ll notice that we get a cool zoom in effect on the mouse over, but our zoom out when the mouse leaves the button is basically a snap back to the original size. Let’s fix that now.
9) Click on the the arrow icon in the MouseOver state in the States pane and select the “MouseOver -> Normal”
In the “Transition Duration” box, type “.2”
10) Extra Designer Happiness Bonus Step! – If you’d like to have a zoom effect that isn’t strictly linear, open up the timeline view with the button on the right hand of the state recording box (seen below).
Click and drag the keyframe (the light gray oval below) to the point you want it. I put mine at .3 seconds.
With the keyframe selected, you should see an “Easing” pane on the right. The default easing is linear (aka. no easing), but you can change the easing curve by just dragging the yellow dots. Here is the easing curve I’ve found works pretty well for my apps.
That’s it. Now you can just assign this template to a button and you’ll have this zooming functionality all set up.rcw_zooming_button
9 Responses to Create a Zooming Button Style In Silverlight Without Code
Anything for Silverlight?
Crap, I cant seem to get it to function correctly in WPF. I can get the MouseEnter event to enlarge the images, but the MouseLeave event doesn’t seem to trigger the event to shrink it back to its original size.
Thank you for the reply. I am trying this now. I hope I can get it to work as this is great eye candy. 😉
WPF doesn’t have the visual state manager that Silverlight has, so this exact approach wouldn’t work.
You could do it in WPF, but you would do it with Event Triggers, which are accessible in the control templates. Basically, once you get into the button control template (using the same method here), create an event trigger for the MouseOver event and create the same kind of animation zooming the button. Make sure you create another shrinking animation for the MouseOut event.
Will this work in WPF for WinForms or does this have to be for Silverlight?
Pingback: 2008 September 29 - Links for today « My (almost) Daily Links
I put it up at the top. Hope that helps.
Is there a project/solution for this?