首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >MediaElement:加载时显示

MediaElement:加载时显示
EN

Stack Overflow用户
提问于 2013-05-28 02:20:25
回答 1查看 874关注 0票数 0

我有一个带有视频缩略图的图像和一个带有真实视频的MediaElement,如下所示:

代码语言:javascript
复制
<Image Source="{Binding thumbnailurl}"/>
<MediaElement Position="{Binding currenttime}" MediaOpened="MediaElement_Opened" Source="{Binding videourl}" AutoPlay="True" Visibility="Collapsed"/>

在视频的当前时间上使用属性已更改的侦听器:

代码语言:javascript
复制
private TimeSpan _currenttime;
public TimeSpan currenttime
{
    get { return _currenttime; }
    set
    {
        if (_currenttime == value) return;
        _currenttime = value;
        NotifyTimeSpanChanged("timespan");
    }
}

protected void NotifyTimeSpanChanged(string name)
{
    System.ComponentModel.PropertyChangedEventHandler handler = PropertyChanged;
    if (handler != null)
    {
        handler(this, new System.ComponentModel.PropertyChangedEventArgs(name));
    }
}

有了这个晚间处理程序:

代码语言:javascript
复制
private void MyClass_PropertyChanged(object sender, System.ComponentModel.PropertyChangedEventArgs e)
{
    if (e.PropertyName.Equals("timespan"))
    {
        MediaElement me = (MediaElement)sender;

        if (me.Position.Milliseconds > 42)
        {
            me.Visibility = Visibility.Visible; // show video now
        }
    }
}

我想做一个无蒸汽过渡,从缩略图到视频时,视频是42ms (第一帧)。问题是似乎从来没有发生过时间跨度改变的事件……

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-05-28 05:37:39

您可以添加TimeSpan的属性(让我们称其为CurrentTime)并将MediaElement的Position属性绑定到CurrentTime。

当CurrentTime改变时,检查它是否“大于”任意的ε(比方说42ms,这大约是一帧的持续时间)。如果它更大,执行可见性技巧并停止比较。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/16778591

复制
相关文章

相似问题

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