首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Silverlight MediaElement进度

Silverlight MediaElement进度
EN

Stack Overflow用户
提问于 2010-07-09 03:20:31
回答 1查看 2.4K关注 0票数 3

我正在尝试在Silverlight中创建自定义媒体播放器。我正在处理进度条。我想让进度条在播放MediaElement时显示当前的下载进度和当前位置。

为了做到这一点,我有一个进度条来显示下载进度,并有一个滑块覆盖以显示当前位置。

我将两者的值都设置为100的百分比。

例如:

代码语言:javascript
复制
ProgressBar.Value = MediaElement.DownloadProgress;
Slider.Value = (MediaElement.Position.TotalMilliseconds) / (MediaElement.NaturalDuration.TimeSpan.TotalMilliseconds);

问题是Slider.Value变得比ProgressBar.Value大。这怎麽可能?如何才能在比已下载内容更远的位置播放视频?

有什么建议可以让它们正确同步吗?

谢谢。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2010-07-09 05:30:12

这是可能的,因为视频流压缩算法不会产生与时间成比例的字节计数。举个例子,一个300MB的视频文件运行了60分钟,它不会自动跟随文件中的30分钟,这将是150MB点。

如果视频的第一部分相对“安静”,它很可能会压缩得很好,而稍后繁忙的部分可能就不会压缩得那么好。因此,可能只下载了文件大小的一小部分,而播放了较大比例的总播放时间。

编辑

,那么我如何让它们同步呢?

您可以通过将滑块限制为最小的下载进度或时间来对其进行篡改。

代码语言:javascript
复制
Slider.Value = Math.Min(mediaelement.Position.TotalMilliseconds / mediaelement.NaturalDuration.TimeSpan.TotalMilliseconds, mediaelement.downloadprogress);
票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/3207125

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档