当前位置: 移动技术网 > IT编程>移动开发>WP > Windows Phone开发(4):框架和页

Windows Phone开发(4):框架和页

2018年10月08日  | 移动技术网IT编程  | 我要评论

识骨寻踪第八季,天才眼镜狗下载,石天照片

在开如之前,我想更正一个小问题,之前我在第一篇文章中说,visual studio express for windows phone的中文版没有简体中文,那是因为我是在英文主页上下载的,语言选择列表中只有一个中文,但是繁体的,后来,我发现windwos phone sdk是有简体中文版的,顺便我也给出下载地址。
http://www.microsoft.com/downloads/zh-cn/details.x?familyid=0a373422-6680-46a7-89e1-e9a468a14259
可以在线安装,如果你的网速不给力的话,可以下载iso镜像本地安装。
----------------------------------

上一篇文章中,我们了解了wp应用程序的生命周期和各个事件的触发情况,今天,我们一起来探讨一下框架和页面。
理论枯躁的东西就不讲了,msdn上都有的,具体一点,我们随便新建一个wp应用程序项目,接着打开app.xaml.cs文件瞧瞧,看看里面有没有“新大陆”?

1、一个app类,从application派生,这跟silverlight中是一样的,当然,如果你对silerlight不熟悉也不要紧,我简单吹一下。
我想各位玩过c#的,不管怎么说也应该玩过windows窗体应用程序吧,对,就是我们常说的winform项目,在windowsform项目里面,有一个program.cs之类的文件,程序的入口点就在里面定义,在main的最后,vs默认生成的代码中有这么一行:application.run(...);
所以,这个application和那个application的意义是一样,专门负责整个应用程序范围的各种事务的协调。
2、我们会注意到app里面有一个公共属性rootframe,这就是主框架,一个wp应用程序只有一个主框架。\

 

3、主框架下面是页,主框架中可以包含1个或n多个页面。
4、页面这个概念很好理解,就像我们平时看到的一个窗体,只不过在silverlight里面叫页,所以,我们也可以联想起web页面。在android里面叫一个activity,其实所指的东东是一样的,只是叫法不同罢了。下图所示为一个页。

\


 

好的,下面来看一下一个页面是如何构成的。
先来看看页面的xaml声明部分。


[html]
<phone:phoneapplicationpage  
    x:class="phoneapp.mainpage" 
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" 
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" 
    xmlns:phone="clr-namespace:microsoft.phone.controls;assembly=microsoft.phone" 
    xmlns:shell="clr-namespace:microsoft.phone.shell;assembly=microsoft.phone" 
    xmlns:d="http://schemas.microsoft.com/expression/blend/2008" 
    xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" 
    mc:ignorable="d" d:designwidth="480" d:designheight="768" 
    fontfamily="{staticresource phonefontfamilynormal}" 
    fontsize="{staticresource phonefontsizenormal}" 
    foreground="{staticresource phoneforegroundbrush}" 
    supportedorientations="portrait" orientation="portrait" 
    shell:systemtray.isvisible="true"> 
 
    …………………… 
<phone:phoneapplicationpage
    x:class="phoneapp.mainpage"
    xmlns=""
    xmlns:x=""
    xmlns:phone="clr-namespace:microsoft.phone.controls;assembly=microsoft.phone"
    xmlns:shell="clr-namespace:microsoft.phone.shell;assembly=microsoft.phone"
    xmlns:d=""
    xmlns:mc=""
    mc:ignorable="d" d:designwidth="480" d:designheight="768"
    fontfamily="{staticresource phonefontfamilynormal}"
    fontsize="{staticresource phonefontsizenormal}"
    foreground="{staticresource phoneforegroundbrush}"
    supportedorientations="portrait" orientation="portrait"
    shell:systemtray.isvisible="true">

    ……………………


我们看到,每一个页面都是phoneapplicationpage的子类,它是继承自silverlight中的page类。
因为程序是面向wp手机的,所以注意要使用phoneapplicationpage而不是用page类,这样可以避免出问题。class属性就是我们这个页面类的类名。
有两个命名空间我们要注意一下的:
xmlns:d=""
xmlns:mc=""
d可以理解为是设计时的状态,d:designwidth="480"就是说这个宽度和高度只是在设计时有效,也就是我们在设计器中看到的大小,并不意味着真正运行起来是这个值,有可能会随着手机屏幕的不同而自动调整,所以我们不应该刻意地设置页面的宽度和高度,以免被固定了,不能自动调整。
mc是什么呢?从语义上翻译是,是标记兼容性相关的内容,其中我们看到一句:mc:ignorable="d",正如上面所说,d:designwidth是设计时的,所以,ignorable="d"就是告诉编译器在实际运行时,忽略设计时设置的值。
supportedorientations用于设置页面支持的方向,如果我们希望在手机屏幕被用户旋转后,程序能够自动跟着调整,就相应地修改该属性。
orientation属性就是用来设置当前页面的默认方向,是纵向的还是横向的。
下面,一起来做个练习,把supportedorientations改为portraitorlandscape,再把orientation改为除none以外的其它值,然后运行,把手机向不同方向旋转,看看怎么样?
\


\

\

这个大家多改改,多试几次就明白了,挺有意思的。
还有一个,shell:systemtray.isvisible="true"用于设置是否隐藏托盘,我们把它设置为true时,运行程序,把鼠标移到页面顶部点击一下,我们就会看到系统托盘了,如显示当前手机信号强度,电池剩余量等信息。

 \


摘自 tcjiaan的专栏

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网