有人会问,以前的MediaElement控件不是有现成的一排操作按钮吗?而且可以直接进入全屏播放。是的,我们知道,以往的Store App都是在全屏模式下运行的,只要MediaElement控件填满整个窗口,就等于全屏播放了,但是,Win10应用是窗口化的,将MediaElement控件的IsFullWindow属性设置为true后,就会这样:

从上面的截图看,MediaElement控件只是覆盖整个窗口而已,并没有实现全屏。那有办法让它全屏播放吗?

老周既然写博客了,当然是有的了。其实,SDK是公开了允许应用程序全屏的API,就像Win8/8.1应用那样。在Windows.UI.ViewManagement命名空间下,提供了与应用程序视图管理有关的类型,其中有一个类叫ApplicationView,类如其名,你看它的名字就知道它是干吗的了,是呀,就是管理应用视图呗。

ApplicationView类有两个方法比较好玩:

TryEnterFullScreenMode:猜到它的用途没有?

ExitFullScreenMode:调用后退出全屏模式。

OK,知道了有这么个家伙后,大概有思路了:当MediaElement控件铺满窗口时调用TryEnterFullScreenMode方法,全屏;反过来,当MediaElement控件还原时就用ExitFullScreenMode方法退出全屏。即:

当MediaElement.IsFullWindow == true时,TryEnterFullScreenMode;

当MediaElement.IsFullWindow == false时,ExitFullScreenMode。

原理就是这样,至于如何实现法嘛,仁者见仁,你喜欢怎么弄都行,达到预期效果就OK。

老周的方法是通过依赖项属性之间的双向绑定完成的。

首先在包含MediaElement控件的页面类或者自定义容器类上声明一个依赖项属性IsFullScreen:

        private static readonly DependencyProperty IsFullScreenProperty = DependencyProperty.Register("IsFullScreen", typeof(bool), typeof(MainPage), new PropertyMetadata(false, new PropertyChangedCallback(OnIsFullScreenPropertyChanged)));

        public bool IsFullScreen
{
get { return (bool)GetValue(IsFullScreenProperty); }
set { SetValue(IsFullScreenProperty, value); }
} private static void OnIsFullScreenPropertyChanged(DependencyObject d, DependencyPropertyChangedEventArgs e)
{
……
}

OnIsFullScreenPropertyChanged方法是用来响应属性更改的,在这个方法里面,判断属性的值,如果true,就进入全屏;否则退出全屏。

        private static void OnIsFullScreenPropertyChanged(DependencyObject d, DependencyPropertyChangedEventArgs e)
{
bool b = (bool)e.NewValue;
var appView = Windows.UI.ViewManagement.ApplicationView.GetForCurrentView();
if (b)
{
appView.TryEnterFullScreenMode();
}
else
{
appView.ExitFullScreenMode();
}
}

属性是弄好了,那如何与MediaElement的IsFullWindow属性关联呢?IsFullWindow属性也是依赖项属性,依赖项属性之间可以直接完成双向绑定,这就是刚才要把IsFullScreen属性定义为依赖项属性的原因。

在XAML文档中,只要把IsFullScreen与IsFullWindow绑定即可。

        <MediaElement ……  IsFullWindow="{Binding IsFullScreen, ElementName=thePage, Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}" />

thePage是当前页面实例的命名。

<Page
x:Class="FullScreenApp.MainPage"
…… x:Name="thePage">

因为刚才我的IsFullScreen属性就是在MainPage页面类中定义的。

如此一来,只要IsFullWindow属性发生变化,IsFullScreen属性就会跟着变,然后就可以进入/退出全屏了。

咱们来看看结果。

刚运行时,非全屏,效果如下图:

然后点击MediaElement控件的全屏按钮,进入全屏播放,如下图:

怎么样,达到效果了吧?

示例源代码下载:http://files.cnblogs.com/files/tcjiaan/FullScreenApp.zip

【Win 10应用开发】实现全屏播放的方法的更多相关文章

  1. 【Win 10 应用开发】在后台播放视频

    从 1607 (14393)版本开始,MediaPlayer 类就可以在前台与后台之间无缝播放,你不必再考虑前台与后之间的通信,所以从 14393 开始,你就不需要再用 BackgroundMedia ...

  2. [转]Android WebView播放视频(包括全屏播放),androidwebview

    Android WebView播放视频(包括全屏播放),androidwebview 最近项目开发中用到了WebView播放视频的功能,总结了开发中犯过的错误,这些错误在开发是及容易遇到的,所以我这里 ...

  3. [Winform]Media Player组件全屏播放的设置

    摘要 在设置程序开始运行时,让视频全屏播放时,直接设置 windowsMediaPlay.fullScreen = true; 会报错,代码如下 windowsMediaPlay.URL = _vid ...

  4. Android之针对WebView的全屏播放

    转载请标明转载处:http://bbs.csdn.net/topics/390839259 本人刚学android,菜鸟一个,第一次写帖子,最近因为项目要用webview加载html5的视频,开始不能 ...

  5. uwp,c#,全屏播放保持屏幕响应

    在开发视频app的时候,全屏播放一段时间内没有电脑操作,电脑会自动进入睡眠模式,这时就要多写些代码来保持响应了. (这里使用的是MediaElement播放控件,MediaElement需要手动添加代 ...

  6. vlc播放器设置开机自动全屏播放网络视频流

    因工作需要,要用vlc视频播放器实现开机自动全屏播放某个网络视频流.百度了下,说的都很模糊,经过整理,设置方法如下: 一,添加视频流地址:rtsp://wowzaec2demo.streamlock. ...

  7. iphone H5视频行内播放(禁止全屏播放)

    一般用户都知道,ios在网页点击视频播放时,视频会弹出全屏播放框. video标签的playsinline.webkit-playsinline标记根本就不会起作用. 还有传闻说对于没有声音的视频不会 ...

  8. HTML5新标签video在iOS上默认全屏播放

    今天做一个app时发现一个问题,应用html5中的video标签加载视频,在Android手机上默认播放大小,但是换成iPhone手机上出问题了,默认弹出全屏播放,查找了好多论坛,都没有谈论这个的.然 ...

  9. video自动全屏播放

    video自动全屏播放 关于Screen.lockOrientation() https://developer.mozilla.org/en-US/docs/Web/API/Screen/lockO ...

随机推荐

  1. 关于jquery简单操作简单表格

    最近在摸索jquery中,想着学习过程中还是记下点自己的东西比较好,不管是日后自己查阅,亦或是对于他人有些许帮助. 也是一件两全其美的事情了. 下面我就简单 贴上自己的html中重要部分了. 具体实现 ...

  2. bzoj3123: [Sdoi2013]森林

    题面传送门 复出的第一道题.. md就遇到坑了.. 简单来说就是可持久化线段树+启发式合并啊.. 感觉启发式合并好神奇好想学 每一次建边就暴力合并,每一个节点维护从根到它的权值线段树 按照题面的话最省 ...

  3. BZOJ‘s Usaco 奶牛题集锦

    1230 线段树 1231 状压DP 1232 最小生成树 1527 贪心 1600 打表找规律 1601 最小生成树 1602 prime 1606 DP 1607 筛法 1609 DP 1610 ...

  4. appium的几点总结

    原文链接:http://blog.csdn.net/bear_w/article/details/50345283 1. 建立session时常用命令: DesiredCapabilities cap ...

  5. 基于XML配置的spring aop增强配置和使用

    在我的另一篇文章中(http://www.cnblogs.com/anivia/p/5687346.html),通过一个例子介绍了基于注解配置spring增强的方式,那么这篇文章,只是简单的说明,如何 ...

  6. PHP:函数赋参数默认初值

    函数的默认参数 允许定义函数时,指定参数的默认值,如: function js_location($url, $alert='', $top=''){ if($alert=='' && ...

  7. 解决IE6/IE7/IE8不支持before,after问题

    对从事web开发的朋友来讲,低版本的IE永远是一个痛点,不支持最新技术(如css3,html5). 在现在web开发中使用图标字体已经很广泛,如Font Awesome,Bootstrap等,字体图片 ...

  8. mySql常用函数说明

    #mySql的数学函数select ABS(-5); #绝对值select ceiling(-5.8); #取大整数select floor(-5.8); #取小整数select LEAST(10,3 ...

  9. SQL 存储过程 传入数组参数

    今天在做统计数据的时候,传入数组导致数据不显示.解决方式和大家分享一下: --参数@CompanyName='北京,天津,上海' DECLARE @PointerPrev int     DECLAR ...

  10. phpcms v9常用方法

    1.联动菜单根据地区id显示地区名称的方法: 显示效果: 四川 >> 攀枝花 >> 仁和区 [字段名字为 area] {get_linkage($info['area'],1, ...