Win10系列:VC++媒体播放控制3
(5)添加视频进度条
视频进度条可以用来显示当前视频的播放进度,并可以通过拖动视频进度条来改变视频的播放进度。接下来介绍如何实现视频进度条,首先打开MainPage.xaml文件,并在Grid元素中添加一个名为"VideoSlider"的Slider控件,用来表示一个视频进度条,代码如下所示:
<Slider x:Name="VideoSlider" HorizontalAlignment="Left" Height="40" Margin="114,0,0,0" VerticalAlignment="Top" Width="780" ValueChanged="SliderValueChanged"></Slider>
添加Slider控件以后,接下来将视频进度条和MediaElement控件中的视频进行同步,即当播放MediaElement控件中的视频时,视频进度条的值将跟着改变。为了实现视频进度条和视频的同步,需要用到计时器。打开MainPage.xaml.h头文件,添加如下的代码:
private:
//声明timer变量
Windows::UI::Xaml::DispatcherTimer^ timer;
//声明timeSpan变量
Windows::Foundation::TimeSpan timeSpan;
在上面的代码中,使用private关键字声明了两个私有的成员变量timer和timeSpan,其中timer是一个DispatcherTimer类型的变量,表示计时器,timeSpan是一个TimeSpan类型的变量,使用timeSpan变量来设置时间间隔。
添加了上述代码以后,接着在MainPage.xaml.cpp源文件中添加如下代码来创建计时器:
MainPage::MainPage()
{
InitializeComponent();
//创建计时器
timer=ref new DispatcherTimer();
//触发Tick事件调用DispatcherTimerTick函数
timer->Tick +=ref new EventHandler<Object^>(this,&FileDemo::MainPage::DispatcherTimerTick);
//设置计时器的时间间隔为1ms
timeSpan.Duration=10000;
timer->Interval=timeSpan;
//启动计时器
timer->Start();
}
在上面的代码中,首先初始化一个DispatcherTimer类的对象timer,并为timer对象的Tick事件添加事件处理函数DispatcherTimerTick,此函数用来在视频播放时更新视频进度条的值,后面将介绍这个函数的实现代码。然后将timeSpan的Duration属性赋值为10000,并把此对象赋值给timer对象的Interval属性,使timer对象的Tick事件每1毫秒触发一次。最后调用timer对象的Start函数来启动计时器。
创建了计时器以后,接下来在MainPage.xaml.h头文件中添加如下的代码,用来声明DispatcherTimerTick函数。
private:
//更新视频进度条
void DispatcherTimerTick(Platform::Object^ sender, Platform::Object^ e);
声明了DispatcherTimerTick函数以后,接着在MainPage.xaml.cpp源文件中添加DispatcherTimerTick函数的实现代码,具体代码如下所示:
//更新视频进度条
void FileDemo::MainPage::DispatcherTimerTick(Object^ sender, Object^ e)
{
VideoState->Text="播放状态:"+Video->CurrentState.ToString();
//判断视频是否已加载
if(Video->NaturalDuration.TimeSpan.Duration > 0.0)
{
//将当前视频位置的时间除以视频总的时间,更新VideoSlider的Value属性值
VideoSlider->Value=(100*(Video->Position.Duration)/(Video->NaturalDuration.TimeSpan.Duration));
}
}
在上述的代码中,首先使用MediaElement控件中的CurrentState属性得到视频的播放状态,并调用ToString函数将其转换成字符串类型,显示到名为"VideoState"的TextBlock控件中。然后判断视频文件是否已加载到MediaElement控件中,如果视频文件已加载,则通过MediaElement控件中的Position属性来得到视频已经播放的进度时间,并通过NaturalDuration属性得到视频的总时间,接着将视频已经播放的进度时间除以视频的总时间并乘以100,把得到的进度值赋值给名为"VideoSlider"的Slider控件的Value属性表示播放进度的百分比。
添加了DispatcherTimerTick函数的实现代码以后,接下来实现通过拖动视频进度条来改变视频的播放进度的功能。在MainPage.xaml.h头文件中添加如下的代码:
private:
Windows::Foundation::TimeSpan positionTimeSpan;
private:
//根据视频进度条改变视频的播放进度
void SliderValueChanged(Platform::Object^ sender,Windows::UI::Xaml::Controls::Primitives::RangeBaseValueChangedEventArgs^ e);
在上述的代码中,使用private关键字声明一个TimeSpan类型的私有成员变量positionTimeSpan,用来表示时间进度。接着使用private关键字声明一个私有的SliderValueChanged函数,此函数用来改变视频的播放进度。
声明了SliderValueChanged函数以后,在MainPage.xaml.cpp源文件中添加SliderValueChanged函数的实现代码,具体代码如下所示:
//根据视频进度条改变视频的播放进度
void FileDemo::MainPage::SliderValueChanged(Object^ sender, Windows::UI::Xaml::Controls::Primitives::RangeBaseValueChangedEventArgs^ e)
{
//当播放时不能改变进度条的值
if(!Video->CurrentState.ToString()->Equals("Playing"))
{
positionTimeSpan.Duration=(e->NewValue)*(Video->NaturalDuration.TimeSpan.Duration)/100;
Video->Position=positionTimeSpan;
}
}
在上面的代码中,首先使用if语句进行判断,如果MediaElement控件的播放状态不是Playing时,则通过参数e的NewValue属性得到视频进度条更新的值,并通过MediaElement控件的NaturalDuration属性得到视频的总时间,接着将视频进度条更新的值乘上视频的总时间并除以100,将得到的值赋给positionTimeSpan变量的Duration属性。最后将positionTimeSpan变量赋值给MediaElement控件的Position属性。
添加视频进度条之后,前台界面的显示效果如图20-13所示。
图20-13视频进度条
Win10系列:VC++媒体播放控制3的更多相关文章
- Win10系列:VC++媒体播放控制1
在MediaElement控件中定义了用于控制视频播放的函数,如Play.Pause和Stop等函数.本小节将在20.6.1小节所新建的项目基础上继续来介绍如何为视频添加播放控制,并在最后一部分给出项 ...
- Win10系列:VC++媒体播放控制4
(7)音量控制 MediaElement控件具有一个Volume属性,通过设置此属性的值可以改变视频音量的大小.接下来介绍如何实现视频的音量控制,首先打开MainPage.xaml文件,并在Grid元 ...
- Win10系列:VC++媒体播放控制2
(3)停止视频播放 接下来添加对视频文件播放的停止控制,打开MainPage.xaml文件,并在Grid元素中添加一个"停止"按钮,用于停止视频的播放,代码如下所示: <Bu ...
- Win10系列:VC++媒体播放
媒体播放包括视频播放和音频播放,在开发Windows应用商店应用的过程中可以使用MediaElement控件来播放视频文件和音频文件.本节将通过一个具体的示例介绍如何使用MediaElement控件来 ...
- Movist for Mac(高清媒体播放器)v2.0.7中文特别版
Movist for Mac中文破解版是目前Mac平台上最好用的视频播放器,功能强大简单好用.movist mac版拥有美观简洁的用户界面,提供多种功能,支持视频解码加速高品质的字幕,全屏幕浏览,是与 ...
- Plyr – 简单,灵活的 HTML5 媒体播放器
Plyr 是一个简单的 HTML5 媒体播放器,包含自定义的控制选项和 WebVTT 字幕.它是只支持现代浏览器,轻量,方便和可定制的媒体播放器.还有的标题和屏幕阅读器的全面支持. 在线演示 ...
- 【C语言入门教程】4.10 综合实例 - 媒体播放器
4.10.1 建立播放列表 数据字典 名称 数据类型 说明 MAX_LENGTH 符号常量 用于定义数组长度,表示列表最大长度 MAX_FILE_LENGTH 符号常量 用于定义数组长度,表示文件名最 ...
- .net C# 网页播放器 支持多种格式 媒体播放器 播放器 代码
.avi格式代码片断如下:<object id='video' width='400' height='200' border='0' classid='clsid:CFCDAA03-8BE4- ...
- C#编写媒体播放器--Microsoft的Directx提供的DirectShow组件,该组件的程序集QuartzTypeLib.dll.
使用C#编写媒体播放器时,需要用到Microsoft的Directx提供的DirectShow组件.用该组件前需要先注册程序集QuartzTypeLib.dll. 1.用QuartzTypeLib.d ...
随机推荐
- TextView显示内容不全
今天开发遇到一个问题,发现TextView显示不全,很纳闷,看图: 正常情况应该是这个样子的: 造成这种情况的原因是: TextView被快速并且多次的设置内容值造成的. 我的场景: 我点击全选按钮, ...
- 《剑指offer》第六十七题(把字符串转换成整数)
// 面试题67:把字符串转换成整数 // 题目:请你写一个函数StrToInt,实现把字符串转换成整数这个功能.当然,不 // 能使用atoi或者其他类似的库函数. #include <ios ...
- jQuery 的 prevObject
1. prevObject jquery选择器在遍历的过程中都会找到一组元素(一个jQuery对象),然后jQuery会把这组元素推入到栈中.prevObject属性就指向这个对象栈中的前一个对象,而 ...
- 关于ES6的一些新特性的学习
一.关于变量 ES5 1.只有全局作用域变量和函数作用域变量 2.“变量提升”(当程序进入一个新的函数时,会将该函数中所有的变量的声明放在函数开始的位置.仅仅会提升变量的声明,不会提升变量的赋值) E ...
- Robot framework--内置库xml学习(一)
Using lxml By default this library uses Python's standard ElementTree module for parsing XML, but it ...
- jquery如何获取checkbox的值
jquery如何获取checkbox的值 一.总结 一句话总结:就是通过jquery获取哪些对应name的checkbox,然后找出:check(被选中的),然后通过jquery的each遍历获取这些 ...
- Python 编程快速上手 第九章 组织文件
上一章节,主要讲了如何用 Python 进行创建并写入新文件.这一章节,讲了对如何用 Python 对文件进行进一步的操作,包括: 移动,复制,删除文件 改名 压缩文件 [shutil]移动,复制,删 ...
- ado.net介绍
System.Data:DataTable,DataSet,DataRow,DataColumn,DataRelation,Constraint System.Data.Common(各种数据访问类的 ...
- 倒排索引(Inverted Index)
倒排索引(Inverted Index) 倒排索引是一种索引结构,它存储了单词与单词自身在一个或多个文档中所在位置之间的映射.倒排索引通常利用关联数组实现.它拥有两种表现形式: inverted fi ...
- 机器学习ML策略
1.为什么是ML策略 例如:识别cat分类器的识别率是90%,怎么进一步提高识别率呢? 想法: (1)收集更多数据 (2)收集更多的多样性训练样本 (3)使用梯度下降训练更长时间 (4)尝试Adam代 ...