mPlayer is a simple Silverlight-based Media Player with support for Video and Audio content with Playback and Audio control such as Volume and more!
Printer Friendly Download Tutorial (316KB) Download Source Code (6.40KB) Online Demonstration
Step 1
Start Microsoft Visual Web Developer 2010 Express, then Select File then New Project... Select "Visual Basic" then "Silverlight 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/bbec6/bbec6766da8b1677089c6d093b615cf7dc02f8d9" alt="New Project"
Step 2
New Silverlight Application window should appear, uncheck the box "Host the Silverlight Application in a new Web site" and then select the required Silverlight Version, see below:
data:image/s3,"s3://crabby-images/a5adb/a5adb615c2cdbf74381ac03397bb94e9b0a3bbbe" alt="New Silverlight Application"
Step 3
A Blank Page named MainPage.xaml should then appear, see below:
data:image/s3,"s3://crabby-images/607db/607db0ef20ef4c36d5f145968e319a4292fd54b3" alt="MainPage.xaml"
Step 4
Then from the All Silverlight Controls section in the Toolbox select the Canvas control:
data:image/s3,"s3://crabby-images/37b94/37b94df837b2679ee56e2e3e3846c03c924f5a30" alt="Canvas Control"
Step 5
Draw a Two Canvases on the Page then in the XAML Pane above the "</Grid>" then change the "<Canvas>" lines to the following:
<Canvas Height="35" Width="400" VerticalAlignment="Top" HorizontalAlignment="Left" Name="Toolbar"></Canvas> <Canvas Height="35" Width="400" Margin="0,265,0,0" VerticalAlignment="Top" HorizontalAlignment="Left" Name="Playback"></Canvas>
See below:
data:image/s3,"s3://crabby-images/701fb/701fbd23b2a7d1c25ecc343f73b662f1bbbabae6" alt="MainPage with Toolbar Canvas and Playback Canvas"
Step 6
Then from the Common Silverlight Controls section in the Toolbox select the Button control:
data:image/s3,"s3://crabby-images/64be8/64be82595b376a2e343a212b9b9da94a40f46123" alt="Button Control"
Step 7
Draw Three Buttons on the "Toolbar" Canvas by dragging the Buttons from the Toolbox onto the Canvas then in the XAML Pane inbetween top the "<Canvas>" and "</Canvas>" tags change the "<Button>" lines to the following:
<Button Canvas.Left="6" Canvas.Top="6" Height="23" Width="75" Name="Open" Content="Open..."/> <Button Canvas.Left="87" Canvas.Top="6" Height="23" Width="75" Name="PlayPause" Content="Play Pause"/> <Button Canvas.Left="168" Canvas.Top="6" Height="23" Width="75" Name="Stop" Content="Stop"/>
See below:
data:image/s3,"s3://crabby-images/cf1c0/cf1c06f36c24181073395e4873fd809a08a9a2f8" alt="MainPage with Canvas and Buttons"
Step 8
Then from the All Silverlight Controls section in the Toolbox select the Slider control:
data:image/s3,"s3://crabby-images/aac52/aac52d92a32e1cfd8641af393530fbab8f6a5505" alt="Slider Control"
Step 9
Draw One Slider on the Upper Canvas (Toolbar) with the Buttons, and change the <Slider> line to the following:
<Slider Canvas.Left="249" Canvas.Top="6" Height="23" Width="75" Minimum="-1" Maximum="1" Value="0" Name="Balance"/>
Then Draw Two more Sliders onto the Bottom Canvas (Playback) and change the <Slider> lines to the following:
<Slider Canvas.Left="6" Canvas.Top="6" Height="23" Width="237" Name="Position"/> <Slider Canvas.Left="249" Canvas.Top="6" Height="23" Width="75" Minimum="0" Maximum="1" Value="0.5" Name="Volume"/>
See below:
data:image/s3,"s3://crabby-images/41401/41401526ed6f0b999dc971ab8e564a3da0466ecd" alt="MainPage with Buttons and Sliders"
Step 10
Then from the All Silverlight Controls section in the Toolbox select the MediaElement control:
data:image/s3,"s3://crabby-images/f0a6f/f0a6f02ed0b63830eb64c8c0aad217fe3c9cd630" alt="MediaElement Control"
Step 11
Draw a MediaElement on the Page between the Canvases and in the XAML Pane change the "<MediaElement>" line to the following:
<MediaElement Height="230" Width="400" Margin="0,35,0,0" HorizontalAlignment="Left" VerticalAlignment="Top" Stretch="Uniform" Name="Player"/>
See below:
data:image/s3,"s3://crabby-images/076a4/076a47a340229d8b746ccd9ccd0ebf5c8f60cdd7" alt="MainPage with MediaElement"
Step 12
Right Click on the Page or the entry for "MainPage.xaml" in Solution Explorer and choose the "View Code" option.
In the Code View below the "End Sub" for "Public Sub New()" Constructor type the following Event Handler Subs:
Private Sub Player_MediaOpened(ByVal sender As Object, _ ByVal args As RoutedEventArgs) _ Handles Player.MediaOpened Position.Maximum = Player.NaturalDuration.TimeSpan.TotalMilliseconds End Sub Private Sub Player_MediaEnded(ByVal sender As Object, _ ByVal args As RoutedEventArgs) _ Handles Player.MediaEnded Player.Stop() End Sub
See Below:
data:image/s3,"s3://crabby-images/a0b57/a0b5733dfe374d740e5fc76fec7d5fd686915058" alt="MainPage.xaml Player Event Handlers"
Step 13
Return to the Designer View, by selecting the "MainPage.xaml" Tab, or Right Click on the Page or the Entry for "MainPage.xaml" in Solution Explorer and choose the "View Designer" option.
Double Click on the "Open..." Button and type in the Open_Click Sub:
Dim OpenDialog As New OpenFileDialog OpenDialog.Filter = "Audio|*.wma;*.mp3|Video|*.wmv;*mp4" If OpenDialog.ShowDialog Then Try If OpenDialog.File.Exists Then Player.SetSource(OpenDialog.File.OpenRead()) End If Catch ex As Exception ' Ignore Errors End Try End If
See Below:
data:image/s3,"s3://crabby-images/4c40a/4c40a7e21d1d3a365a7611e01b1cee7d8ab7407c" alt="Open Button Click Event"
Step 14
Return to the Designer View again, by selecting the "MainPage.xaml" Tab, or Right Click on the Page or the Entry for "MainPage.xaml" in Solution Explorer and choose the "View Designer" option.
Double Click on the "Play Pause" Button and type in the PlayPause_Click Sub:
If Player.CurrentState = MediaElementState.Playing Then Player.Pause() Else Player.Play() End If
See Below:
data:image/s3,"s3://crabby-images/5b7e1/5b7e1440948ea66894387b7fec0ba8ae1d9d3a0c" alt="Play Pause Button Click Event"
Step 15
Return to the Designer View, by selecting the "MainPage.xaml" Tab, or Right Click on the Page or the Entry for "MainPage.xaml" in Solution Explorer and choose the "View Designer" option.
Double Click on the "Stop" Button Control and type in the Stop_Click Sub:
Player.Stop()
See Below:
data:image/s3,"s3://crabby-images/3b387/3b38771f258b70f9bf1e30721f80ddbad6466db7" alt="Stop Button Click Event"
Step 16
Return to the Designer View, by selecting the "MainPage.xaml" Tab, or Right Click on the Page or the Entry for "MainPage.xaml" in Solution Explorer and choose the "View Designer" option.
Double Click on the "Balance" Slider Control, at the end of the Buttons on the Toolbar Canvas, and type in the Balance_ValueChanged Sub:
Player.Balance = Balance.Value
See Below:
data:image/s3,"s3://crabby-images/2fa26/2fa2664f24ad910e520d363afc7a7a8f1a1d507f" alt="Balance Slider ValueChanged Event"
Step 17
Return to the Designer View, by selecting the "MainPage.xaml" Tab, or Right Click on the Page or the Entry for "MainPage.xaml" in Solution Explorer and choose the "View Designer" option.
Double Click on the "Position" Slider Control, which is the larger Slider on the "Playback" Canvas, and type in the Position_ValueChanged Sub:
Player.Position = TimeSpan.FromMilliseconds(CInt(Position.Value))
See Below:
data:image/s3,"s3://crabby-images/466cb/466cb595d5977941f590c58fc6db17f8e5395375" alt="Position Slider ValueChanged Event"
Step 18
Return to the Designer View, by selecting the "MainPage.xaml" Tab, or Right Click on the Page or the Entry for "MainPage.xaml" in Solution Explorer and choose the "View Designer" option.
Double Click on the "Volume" Slider Control, which is next to the "Position" Slider, and type in the Volume_ValueChanged Sub:
Player.Volume = Volume.Value
See Below:
data:image/s3,"s3://crabby-images/a8db4/a8db42a07ab784d138ee02c44878988bcf31051f" alt="Volume Slider ValueChanged Event"
Step 19
Save the Project as you have now finished the Silverlight application. Select Debug then Start Debugging or click on Start Debugging:
data:image/s3,"s3://crabby-images/ff3e2/ff3e2dc36fd5826bdfaf1c933648df5ef8494d62" alt="Start Debugging"
After you do, the following will appear in a new Web Browser window:
data:image/s3,"s3://crabby-images/112c2/112c28977cc5abc4a43451d79f1a87ba58aa7fef" alt="Application Running"
Step 20
You can Open compatible Audio and Video to Play such as Windows Media Audio/Video and MP3, see below:
data:image/s3,"s3://crabby-images/9be34/9be34e2d9ddfe555e735e98c2f8a38f6acb9b9c8" alt="mPlayer"
Step 21
Close the Browser window by clicking on the Close Button on
the top right of the Web Browser to Stop the application.
This is a simple Media Playing application, try adding more features such as Fast Forward or Rewind, it also possible to use this as a basis for a Hosted-Media Player to play content from an web address - make it your own!