zoukankan      html  css  js  c++  java
  • 稳扎稳打Silverlight(18) 2.0视频之详解MediaElement, 开发一个简易版的全功能播放器

    [索引页]
    [源码下载]


    稳扎稳打Silverlight(18) - 2.0视频之详解MediaElement, 开发一个简易版的全功能播放器


    作者:webabcd


    介绍
    Silverlight 2.0 详解MediaElement:开发一个简易版的全功能播放器
        MediaOpened - 当媒体被成功地打开时所触发的事件
        MediaFailed - 当媒体未能被成功地打开时所触发的事件
        CurrentStateChanged - 播放状态(CurrentState)发生改变时所触发的事件
        DownloadProgressChanged - 下载进度(DownloadProgress)发生变化时所触发的事件
        MediaEnded - 当媒体播放到末尾时所触发的事件
        BufferingProgressChanged - 缓冲进度(BufferingProgress)发生变化时所触发的事件
        Source - 需要播放的媒体地址
        Stretch - 拉伸值
        AutoPlay - 是否自动播放媒体
        CurrentState - 播放状态
        Position - 媒体的位置
        DroppedFramesPerSecond - 媒体每秒正在丢弃的帧数
        BufferingProgress - 缓冲进度
        DownloadProgress - 下载进度
        NaturalDuration - 媒体文件的时长
        Volume - 音量大小
        Balance - 音量平衡
        BufferingTime - 需要缓冲的时间的长度
        CurrentState - 播放状态
        IsMuted - 是否静音
        Play() - 播放媒体
        Pause() - 暂停媒体的播放
        Stop() - 停止媒体的播放


    在线DEMO
    http://www.cnblogs.com/webabcd/archive/2008/10/09/1307486.html


    示例
    VideoPlayer.xaml
    <UserControl x:Class="Silverlight20.Video.VideoPlayer"
        xmlns
    ="http://schemas.microsoft.com/winfx/2006/xaml/presentation" 
        xmlns:x
    ="http://schemas.microsoft.com/winfx/2006/xaml">
        
    <StackPanel HorizontalAlignment="Left">
        
            
    <!--
            Source - 需要播放的媒体地址
            Stretch - 拉伸值 [System.Windows.Media.Stretch 枚举]。参见:本Demo的Shape/Shape.xaml
            AutoPlay - 是否自动播放媒体
            
    -->
            
    <MediaElement x:Name="mediaElement"
                    Width
    ="400" Height="200"
                    Source
    ="http://download.microsoft.com/download/2/0/5/205d8c39-3d55-4032-8195-7b0e6eda4cb6/WinVideo-SL-InstallExperience.wmv" 
                    Stretch
    ="Fill" 
                    AutoPlay
    ="False">
            
    </MediaElement>

            
    <Button x:Name="play" Content="播放" Margin="5" Click="play_Click" />
            
    <Button x:Name="pause" Content="暂停" Margin="5" Click="pause_Click" />
            
    <Button x:Name="stop" Content="停止" Margin="5" Click="stop_Click" />
            
    <Button x:Name="mute" Content="静音" Margin="5" Click="mute_Click" />

            
    <Slider x:Name="playSlider" Minimum="0" Maximum="1" Margin="5" ToolTipService.ToolTip="播放进度" ValueChanged="playSlider_ValueChanged" />
            
    <Slider x:Name="volumeSlider" Minimum="0" Maximum="1" Margin="5" ToolTipService.ToolTip="音量大小" ValueChanged="volumeSlider_ValueChanged" />
            
    <Slider x:Name="balanceSlider" Minimum="-1" Maximum="1" Margin="5" ToolTipService.ToolTip="音量平衡" ValueChanged="balanceSlider_ValueChanged" />

            
    <TextBlock x:Name="lblPlayTime" Margin="5" />
            
    <TextBlock x:Name="lblVolume" Margin="5" />
            
    <TextBlock x:Name="lblBalance" Margin="5" />

            
    <TextBlock x:Name="lblDownloadProgress" Margin="5" />
            
    <TextBlock x:Name="lblBufferingProgress" Margin="5" />
            
    <TextBlock x:Name="lblDroppedFramesPerSecond" Margin="5" />
            
    <TextBlock x:Name="lblState" Margin="5" />

            
    <TextBlock x:Name="lblWidth" Margin="5" />
            
    <TextBlock x:Name="lblHeight" Margin="5" />
            
    <TextBlock x:Name="lblTotalTime" Margin="5" />
            
    <TextBlock x:Name="lblBufferingTime" Margin="5" />

        
    </StackPanel>
    </UserControl>

    VideoPlayer.xaml.cs
    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Net;
    using System.Windows;
    using System.Windows.Controls;
    using System.Windows.Documents;
    using System.Windows.Input;
    using System.Windows.Media;
    using System.Windows.Media.Animation;
    using System.Windows.Shapes;

    using System.Windows.Threading;

    namespace Silverlight20.Video
    {
        
    public partial class VideoPlayer : UserControl
        
    {
            
    // 媒体的时长
            private TimeSpan _duration;

            
    private DispatcherTimer _timer = new DispatcherTimer();

            
    public VideoPlayer()
            
    {
                InitializeComponent();

                
    this.Loaded += new RoutedEventHandler(VideoPlayer_Loaded);

                
    /*
                 * MediaOpened - 当媒体被成功地打开时所触发的事件
                 * MediaFailed - 当媒体未能被成功地打开时所触发的事件
                 * CurrentStateChanged - 播放状态(CurrentState)发生改变时所触发的事件
                 * DownloadProgressChanged - 下载进度(DownloadProgress)发生变化时所触发的事件(当下载增加量大于等于 0.05 或下载进度增加到 1 时会触发此事件)
                 * MediaEnded - 当媒体播放到末尾时所触发的事件
                 * BufferingProgressChanged - 缓冲进度(BufferingProgress)发生变化时所触发的事件(当缓冲增加量大于等于 0.05 或缓冲进度增加到 1 时会触发此事件)
                 
    */


                mediaElement.MediaOpened 
    += new RoutedEventHandler(mediaElement_MediaOpened);
                mediaElement.CurrentStateChanged 
    += new RoutedEventHandler(mediaElement_CurrentStateChanged);
                mediaElement.DownloadProgressChanged 
    += new RoutedEventHandler(mediaElement_DownloadProgressChanged);
                mediaElement.MediaEnded 
    += new RoutedEventHandler(mediaElement_MediaEnded);
                mediaElement.BufferingProgressChanged 
    += new RoutedEventHandler(mediaElement_BufferingProgressChanged);
            }


            
    void VideoPlayer_Loaded(object sender, RoutedEventArgs e)
            
    {
                
    // 每 500 毫秒调用一次指定的方法
                _timer.Interval = TimeSpan.FromMilliseconds(500);
                _timer.Tick 
    += new EventHandler(_timer_Tick);
                _timer.Start();
            }


            
    void _timer_Tick(object sender, EventArgs e)
            
    {
                
    // CurrentState - 播放状态 [System.Windows.Media.MediaElementState枚举]
                
    // Position - 媒体的位置(单位:秒)
                if (mediaElement.CurrentState == MediaElementState.Playing)
                
    {
                    lblPlayTime.Text 
    = string.Format(
                        
    "{0}{1:00}:{2:00}:{3:00}",
                        
    "播放进度:",
                        mediaElement.Position.Hours,
                        mediaElement.Position.Minutes,
                        mediaElement.Position.Seconds);
                }


                
    // DroppedFramesPerSecond - 媒体每秒正在丢弃的帧数
                lblDroppedFramesPerSecond.Text = "每秒正在丢弃的帧数:" + mediaElement.DroppedFramesPerSecond.ToString();
            }


            
    void mediaElement_BufferingProgressChanged(object sender, RoutedEventArgs e)
            
    {
                
    // BufferingProgress - 缓冲进度(0 - 1 之间)
                lblBufferingProgress.Text = string.Format(
                    
    "缓冲进度:{0:##%}",
                    mediaElement.BufferingProgress);
            }


            
    void mediaElement_MediaEnded(object sender, RoutedEventArgs e)
            
    {
                mediaElement.Stop();
            }


            
    void mediaElement_DownloadProgressChanged(object sender, RoutedEventArgs e)
            
    {
                
    // DownloadProgress - 下载进度(0 - 1 之间)
                lblDownloadProgress.Text = string.Format(
                    
    "下载进度:{0:##%}",
                    mediaElement.DownloadProgress);
            }

            
    private void mediaElement_MediaOpened(object sender, RoutedEventArgs e)
            
    {
                
    /*
                 * NaturalVideoWidth - 媒体文件的宽
                 * NaturalVideoHeight - 媒体文件的高
                 * HasTimeSpan - 是否可取得媒体文件的时长
                 * NaturalDuration - 媒体文件的时长
                 * Volume - 音量大小(0 - 1 之间)
                 * Balance - 音量平衡(-1 - 1 之间)
                 * BufferingTime - 需要缓冲的时间的长度
                 
    */


                lblWidth.Text 
    = "媒体文件的宽:" + mediaElement.NaturalVideoWidth.ToString();
                lblHeight.Text 
    = "媒体文件的高:" + mediaElement.NaturalVideoHeight.ToString();

                _duration 
    = mediaElement.NaturalDuration.HasTimeSpan ? mediaElement.NaturalDuration.TimeSpan : TimeSpan.FromMilliseconds(0);

                lblTotalTime.Text 
    = string.Format(
                    
    "{0}{1:00}:{2:00}:{3:00}""时长:",
                    _duration.Hours,
                    _duration.Minutes,
                    _duration.Seconds);

                mediaElement.Volume 
    = 0.8;
                volumeSlider.Value 
    = 0.8;
                lblVolume.Text 
    = "音量大小:80%";

                mediaElement.Balance 
    = 0;
                balanceSlider.Value 
    = 0;
                lblBalance.Text 
    = "音量平衡:0%";

                mediaElement.BufferingTime 
    = TimeSpan.FromSeconds(30);
                lblBufferingTime.Text 
    = "缓冲长度:30秒";
            }


            
    private void mediaElement_CurrentStateChanged(object sender, RoutedEventArgs e)
            
    {
                
    /*
                 * CurrentState - 播放状态 [System.Windows.Media.MediaElementState枚举]
                 *     MediaElementState.Closed - 无可用媒体
                 *     MediaElementState.Opening - 尝试打开媒体(此时Play(),Pause(),Stop()命令会被排进队列,等到媒体被成功打开后再依次执行)
                 *     MediaElementState.Buffering - 缓冲中
                 *     MediaElementState.Playing - 播放中
                 *     MediaElementState.Paused - 被暂停(显示当前帧)
                 *     MediaElementState.Stopped - 被停止(显示第一帧)
                 
    */


                lblState.Text 
    = "播放状态:" + mediaElement.CurrentState.ToString();
            }


            
    private void play_Click(object sender, RoutedEventArgs e)
            
    {
                
    // Play() - 播放媒体(在当前 Position 处播放)
                mediaElement.Play();
            }


            
    private void pause_Click(object sender, RoutedEventArgs e)
            
    {
                
    // CanPause - 媒体是否可暂停
                
    // Pause() - 暂停媒体的播放
                if (mediaElement.CanPause)
                    mediaElement.Pause();
            }


            
    private void stop_Click(object sender, RoutedEventArgs e)
            
    {
                
    // Stop() - 停止媒体的播放
                mediaElement.Stop();
            }


            
    void mute_Click(object sender, RoutedEventArgs e)
            
    {
                
    // IsMuted - 是否静音
                if (mediaElement.IsMuted == true)
                
    {
                    mute.Content 
    = "静音";
                    mediaElement.IsMuted 
    = false;
                }

                
    else
                
    {
                    mute.Content 
    = "有声";
                    mediaElement.IsMuted 
    = true;
                }

            }


            
    private void playSlider_ValueChanged(object sender, RoutedPropertyChangedEventArgs<double> e)
            
    {
                
    // CanSeek - 是否可以通过设置 Position 来重新定位媒体
                
    // Position - 媒体的位置(单位:秒)
                if (mediaElement.CanSeek)
                
    {
                    mediaElement.Pause();
                    mediaElement.Position 
    = TimeSpan.FromSeconds(_duration.TotalSeconds * playSlider.Value);
                    mediaElement.Play();
                }

            }


            
    private void volumeSlider_ValueChanged(object sender, RoutedPropertyChangedEventArgs<double> e)
            
    {
                
    // Volume - 音量大小(0 - 1 之间)
                mediaElement.Volume = volumeSlider.Value;
                lblVolume.Text 
    = string.Format(
                    
    "音量大小:{0:##%}",
                    volumeSlider.Value);
            }


            
    private void balanceSlider_ValueChanged(object sender, RoutedPropertyChangedEventArgs<double> e)
            
    {
                
    // Balance - 音量平衡(-1 - 1 之间)
                mediaElement.Balance = balanceSlider.Value;
                lblBalance.Text 
    = string.Format(
                    
    "音量平衡:{0:##%}",
                    balanceSlider.Value);
            }

        }

    }



    OK
    [源码下载]
  • 相关阅读:
    自省改过
    c语言学习教程1之预定义代码
    tqdm进度条管理
    React-i18next切换中英文
    React怎样实现点击其他地方隐藏弹出的菜单
    遍历对象再取值,获得新值
    Web 用户体验设计提升指南
    antd vue form
    echarts 内容显示值在图中显示,不显示交互效果,只是静态图
    element-ui中el-table根据浏览器的缩放自适应宽度
  • 原文地址:https://www.cnblogs.com/webabcd/p/1344632.html
Copyright © 2011-2022 走看看