Image Carousel is a Carousel that allows images to be displayed as it revolves around, in this case it is a Vertical Carousel using Silverlight on Windows Phone 7.
Printer Friendly Download Tutorial (905KB) Download Source Code (19.9KB)
Step 1
Start Microsoft Visual Studio 2010 Express for Windows Phone, then Select File then New Project... Select "Visual C#" then "Silverlight for Windows Phone" and then "Windows Phone Application" from Templates, select a Location if you wish, then enter a name for the Project and then click OK, see below:
data:image/s3,"s3://crabby-images/95085/95085e993da40f088b13a8adf0f04e701c04a613" alt="New Project"
Step 2
A Windows Phone application Page named MainPage.xaml should then appear, see below:
data:image/s3,"s3://crabby-images/15c4f/15c4fd97c601ea6b6903dec1a7a2a0c73c5e96d2" alt="MainPage.xaml"
Step 3
Right Click on the Entry for the Project in the Solution Explorer and choose "Add" then "New Folder", and give it the Name "images" (without quotes), see below:
data:image/s3,"s3://crabby-images/f3fe2/f3fe22cc07d3293a3dd646649ec5c21f42c2ed30" alt="Project Images Folder"
Step 4
Download the following images (add.png, remove.png & clear.png) by right-clicking on the images below and choose "Save Picture As..." or "Save Image As..." and Save them to a Folder on your computer:
Step 5
Right Click on the Entry for the "image" Folder for the Project in Solution Explorer, and choose "Add", then "Existing Item...", then in the "Add Existing Item" dialog select Folder you saved the images, then choose "Add" to add add.png, remove.png and clear.png to the images folder in the project, see below:
data:image/s3,"s3://crabby-images/ff62e/ff62e133a9e7cb42fbb67269478652e31e8b0e03" alt="Project Images Folder with Images"
Step 6
While still in the Solution Explorer click on the "add.png" image then goto the Properties box and change the Build Action to Content, do the same for the "clear.png" and "remove.png" images, see below:
data:image/s3,"s3://crabby-images/a293c/a293c50f179deb67f5fc5af689dce14b19baf6ee" alt="Image Properties"
Step 7
Select the ImageCarousel Project from Solution Explorer.
Then select from the Main Menu "Project" then "Add New Item...", and select the "Windows Phone User Control" Template, then change the "Name" to CarouselItem.xaml see below:
data:image/s3,"s3://crabby-images/e4c8d/e4c8d46c9eab89de6bee69ccc7fdea9a4f50355b" alt="Add CarouselItem User Control"
Step 8
Add the new User Control to the Project by Clicking on Add, then in the XAML Pane for the CarouselItem.xaml User Control.
Remove d:DesignHeight="480" d:DesignWidth="480"
from the <UserControl ...> Tag.
Also remove Background="{StaticResource PhoneChromeBrush}" from <Grid x:Name="LayoutRoot" ...>, see below:
data:image/s3,"s3://crabby-images/199bf/199bf1e5ff8dc0e764072faa6a5bbf4ad1d2ecda" alt="CarouselItem UserControl Attributes"
Step 9
While still in XAML Pane for CarouselItem.xaml between the <Grid x:Name="LayoutRoot"> and </Grid> lines type the following Image Control XAML:
<Image Height="150" Width="150" Name="Image">
<Image.RenderTransform>
<TransformGroup>
<ScaleTransform ScaleX="1" ScaleY="1" x:Name="ItemScale"/>
</TransformGroup>
</Image.RenderTransform>
</Image>
XAML:
data:image/s3,"s3://crabby-images/4196d/4196dce176a2c5657fca479a4e588683beee73f9" alt="CarouselItem XAML Pane"
Design:
data:image/s3,"s3://crabby-images/65d01/65d016facb8f69f1de8c694c698af7f93427eba5" alt="CarouselItem Design View"
Step 10
Right Click on the Page or the entry for "CarouselItem.xaml" in Solution Explorer and choose the "View Code" option. In the Code View above "public CarouselItem()" type the following Declaration:
public double Angle = 0;
See Below:
data:image/s3,"s3://crabby-images/34e6a/34e6acdfd4b98cba96857dfc65d035b831f0e4d6" alt="CarouselItem Declarations"
Step 11
Select from the Main Menu "Project" then "Add New Item...", and select the "Windows Phone User Control" Template, then change the "Name" to Carousel.xaml see below:
data:image/s3,"s3://crabby-images/aae0f/aae0fe89c0aa475292c057aead57ffd3389fd2e9" alt="Add Carousel User Control"
Step 12
Add the new User Control to the Project by Clicking on Add, then in the XAML Pane for the Carousel.xaml User Control.
Remove Background="{StaticResource PhoneChromeBrush}" from <Grid x:Name="LayoutRoot" ...>
from the <UserControl ...> Tag, see below:
data:image/s3,"s3://crabby-images/3359c/3359c5b52f8a68e3efc8796d48403dd92b27e6de" alt="CarouselItem UserControl Attributes"
Step 13
While still in XAML Pane for Carousel.xaml between the <Grid x:Name="LayoutRoot"> and </Grid> lines type the following XAML:
<Canvas x:Name="Container" Width="480" Height="480">
<Canvas Height="150" Width="150" x:Name="Display"/>
</Canvas>
XAML:
data:image/s3,"s3://crabby-images/50cd2/50cd24ada7b7d6ae411e730088b1268a99bf74a3" alt="Carousel XAML Pane"
Design:
data:image/s3,"s3://crabby-images/a75df/a75df5621a61d0a065d18cababeacb7c4f10039b" alt="Carousel Design View"
Step 14
Right Click on the Entry for the "Carousel.xaml" Class in Solution Explorer and choose "View Code".
In the Code View for Carousel.xaml.cs above "namespace ImageCarousel", type the following:
using System.Windows.Media.Imaging;
Also in the CodeView below the "{" of the line "public partial class Carousel : UserControl" type the following Declarations:
private Storyboard _rotate = new Storyboard(); private List<BitmapImage> _images = new List<BitmapImage>(); private List<CarouselItem> _items = new List<CarouselItem>(); private Point _position; private Point _radius = new Point { X = -25, Y = 200 }; private double _speed = 0.0125; private double _perspective = 75; private double _distance;
See Below:
data:image/s3,"s3://crabby-images/bee38/bee38c9195734df3e4db597b2fb3ee6f90724325" alt="Carousel Imports and Declarations"
Step 15
While still in the Code View below the "_distance" declaration type the following Methods:
private void Populate(ref Canvas canvas) { canvas.Children.Clear(); for (int index = 0; index < _images.Count(); index++) { CarouselItem item = new CarouselItem(); item.Image.Source = _images[index]; item.Angle = index * ((Math.PI * 2) / _images.Count); _position.X = Math.Cos(item.Angle) * _radius.X; _position.Y = Math.Sin(item.Angle) * _radius.Y; Canvas.SetLeft(item, _position.X); Canvas.SetTop(item, _position.Y); _distance = 1 / (1 - (_position.X / _perspective)); item.Opacity = item.ItemScale.ScaleX = item.ItemScale.ScaleY = _distance; _items.Add(item); canvas.Children.Add(item); } } private void Rotate(object sender, EventArgs e) { foreach (CarouselItem item in _items) { item.Angle -= _speed; _position.X = Math.Cos(item.Angle) * _radius.X; _position.Y = Math.Sin(item.Angle) * _radius.Y; Canvas.SetLeft(item, _position.X); Canvas.SetTop(item, _position.Y); if (_radius.X >= 0) { _distance = 1 * (1 - (_position.X / _perspective)); Canvas.SetZIndex(item, -(int)(_position.X)); } else { _distance = 1 / (1 - (_position.X / _perspective)); Canvas.SetZIndex(item, (int)(_position.X)); } item.Opacity = item.ItemScale.ScaleX = item.ItemScale.ScaleY = _distance; } _rotate.Begin(); } public void Add(Uri uri) { BitmapImage _image = new BitmapImage(uri); _images.Add(_image); Populate(ref Display); } public void RemoveLast() { if (_images.Count > 0) { _images.RemoveAt(_images.Count - 1); Populate(ref Display); } } public void Clear() { _images.Clear(); Populate(ref Display); }
See Below:
data:image/s3,"s3://crabby-images/4e89c/4e89c55e8508fe230e7d8dc96af1244d2efd26df" alt="Carousel Methods"
Step 16
While still in the Code View in the "public Carousel()" Constructor below "InitializeComponent();" type the following:
Canvas.SetLeft(Display, Container.Width / 2 - Display.Width / 2); Canvas.SetTop(Display, Container.Height / 2 - Display.Height / 2); _rotate.Completed += Rotate; _rotate.Begin();
See Below:
data:image/s3,"s3://crabby-images/1abd1/1abd120320daf12c3d69ee7afbb9434452714d20" alt="Carousel Constructor"
Step 17
Select "Build Solution" from the Debug menu, see below:
data:image/s3,"s3://crabby-images/2a7f5/2a7f5d90025d593c386a7c5c077ee81e59cec66f" alt="Build Solution"
Step 18
When the Build completes, return to the MainPage Designer View by selecting the "MainPage.xaml" Tab.
In the XAML Pane for MainPage.xaml, above the <Grid x:Name="LayoutRoot" Background="{StaticResource PhoneBackgroundBrush}"> Tag type the following ApplicationBar XAML:
<phone:PhoneApplicationPage.ApplicationBar>
<shell:ApplicationBar IsVisible="True" IsMenuEnabled="False">
<shell:ApplicationBar.Buttons>
<shell:ApplicationBarIconButton Text="add" IconUri="/images/add.png" Click="Add_Click"/>
<shell:ApplicationBarIconButton Text="remove" IconUri="/images/remove.png" Click="Remove_Click"/>
<shell:ApplicationBarIconButton Text="clear" IconUri="/images/clear.png" Click="Clear_Click"/>
</shell:ApplicationBar.Buttons>
</shell:ApplicationBar>
</phone:PhoneApplicationPage.ApplicationBar>
See below:
data:image/s3,"s3://crabby-images/19c5d/19c5d31b30ad8028cfc9e09c885794730f5b9e9d" alt="ApplicationBar XAML"
Step 19
While still in XAML Pane between the <Grid x:Name="ContentGrid" Grid.Row="1"> and </Grid> lines type the following XAML:
<Grid x:Name="ContentMain">
<Grid.RowDefinitions>
<RowDefinition Height="80"/>
<RowDefinition Height="*"/>
</Grid.RowDefinitions>
<!-- Toolbar -->
<!-- Content -->
</Grid>
XAML:
data:image/s3,"s3://crabby-images/ea957/ea957330530ea8810d4340a766ff644606e32da1" alt="MainPage XAML Pane"
Design:
data:image/s3,"s3://crabby-images/e7a11/e7a1103d773f2384eb81999130eb3fe4c9a3ef79" alt="MainPage Design View"
Step 20
Then from the Windows Phone Controls section in the Toolbox select the TextBox control:
data:image/s3,"s3://crabby-images/2e8b0/2e8b0a88752659dfb6964abd7bcb833d027b5c98" alt="TextBox Control"
Step 21
Draw a TextBox onto the Toolbar Section (upper smaller section) of the Grid on the Page, below the Page Title, and in the XAML Pane below the <!-- Toolbar --> line, change "TextBox1" to the following:
<TextBox Grid.Row="0" Name="Location">
<TextBox.InputScope>
<InputScope>
<InputScopeName NameValue="Url"/>
</InputScope>
</TextBox.InputScope>
</TextBox>
See below:
data:image/s3,"s3://crabby-images/57bc6/57bc63e58aee932c315839d7caf74096774075b8" alt="MainPage with Location TextBox"
Step 22
Then from the ImageCarousel Controls section in the Toolbox select the Carousel control:
data:image/s3,"s3://crabby-images/bd90a/bd90ae19b2115ce6ad8d4d8e8b60754080484163" alt="Carousel User Control"
Step 23
Draw a Carousel onto the Page by dragging a Carousel from the Toolbox onto the larger portion of the Grid on the Page (Content), then in the XAML Pane below the <!-- Content --> line, change "carousel1" to the following:
<my:Carousel Grid.Row="1" x:Name="Images"/>
XAML:
data:image/s3,"s3://crabby-images/bdaef/bdaef68612aceb7969b692b344b3ccff4d76e59d" alt="MainPage XAML Pane"
Design:
data:image/s3,"s3://crabby-images/427f2/427f210db2921efb2189faf82e93c24d2c61b7e4" alt="MainPage Design View"
Step 24
While still in the Designer View for MainPage.xaml, Select the "page name" TextBlock (PageTitle) and then Delete or Right-Click and Choose the Delete option so the MainPage.xaml appears as below:
data:image/s3,"s3://crabby-images/b8fdf/b8fdf44dc69d0235b04a60b6a2c9d1f0849f34ea" alt="MainPage with textBlockListTitle Removed"
Step 25
Right Click on the Page or the entry for "MainPage.xaml" in Solution Explorer and choose the "View Code" option.
In the Code View in the "public MainPage()" Constructor below "InitializeComponent();" type the following:
ApplicationTitle.Text = "IMAGE CAROUSEL"; Location.Text = "http://cespage.com/phone.jpg";
See Below:
data:image/s3,"s3://crabby-images/08ec6/08ec6ee64c9b0633ca1a03459e2dd1d3c9ea42e7" alt="MainPage Constructor"
Step 26
While still the Code View for MainPage.xaml.cs above "public MainPage()" type the following Event Handlers:
private void Add_Click(object sender, EventArgs e) { Images.Add(new Uri(Location.Text)); } private void Remove_Click(object sender, EventArgs e) { Images.RemoveLast(); } private void Clear_Click(object sender, EventArgs e) { Images.Clear(); }
See Below:
data:image/s3,"s3://crabby-images/7ef28/7ef28257dbc0d10457840f6be9aa8dfbafa6648b" alt="MainPage Event Handlers"
Step 27
Save the Project as you have now finished the Windows Phone Silverlight application. Select the Windows Phone Emulator option then Select Debug then Start Debugging or click on Start Debugging:
data:image/s3,"s3://crabby-images/216ae/216ae12d45227d046f30e709372a559cf3e92e99" alt="Start Debugging"
After you do, the following will appear in the Windows Phone Emulator after it has been loaded:
data:image/s3,"s3://crabby-images/36237/362375faa34f869cb3ddd834eac1620d039b6266" alt="Application Running"
Step 28
Tap the "Location" TextBox and enter using the SIP to enter the URL of an Image then tap the "add" button to Add it to the Carousel, you can do this multiple times to add more Images to the Carousel, see below:
data:image/s3,"s3://crabby-images/a640b/a640b76ca2733f53bbc89773d6e945dd58c891c8" alt="Image Carousel"
Step 29
You can then Stop the application by selecting the Visual Studio 2010 application window and clicking on the Stop Debugging button:
data:image/s3,"s3://crabby-images/4ada7/4ada7ca65feda9cee86d40589952e0ade14177d5" alt="Stop Debugging"
This is a Simple Image Carousel for displaying images, it could be altered to display any content in a Carousel such as Buttons or other content, try changing it such as making it into a horizontal carousel - make it your own!