silverlight中不存在Flash中的场景,有的只是
一个个Xaml
文件,你要是愿意,也可以把它看做"场景"或"窗口",刚开始接触sl时,对于多个xaml之间如何切换,
调用,传递参数感到很棘手,下面是我总结的几种
方法:
1、A.xaml跳转到B.xaml
(a)首先需要定义
一个公用的接口(interfac
E),如下:
using Sy
stem.Windows;
namespace ChildWin.Code
{
publi
c interface
IContent
{
UIElement Content
{ get; set; }
}
}
(b)A.Xaml与B.Xaml都实现该接口,
代码如下:
public partial class A: UserControl,
IContent
{
...
/// <sum
Mary>
/// 实现IContent接口
/// </sum
Mary>
public new UIElement Content
{
get
{
return base.Content;
}
set
{
base.Content = value;
}
}}
public partial class B: UserControl,
IContent
{
...
/// <sum
Mary>
/// 实现IContent接口
/// </sum
Mary>
public new UIElement Content
{
get
{
return base.Content;
}
set
{
base.Content = value;
}
}}
(C)需要
跳转的地方,类似下面这样处理:
private void btnChange_Click(ob
ject sender,Sy
stem.Window
s.RoutedEventArgs
E)
{
(App.Current.RootVisual as IContent).Content = new Window2();}
上面的的意思是按钮btnChange点击后,当前"场景"将切换到Window2.xaml对应的"场景"
2、"主Xaml"中加载"子Xaml"(类似软件中的MDI窗口)
这个比较容易,在主Xaml中放置
一个容器类的控件(比如ScrollViewer之类),然后指定Content就行了,参
考以下
代码:
<ScrollViewer x:Name="
viewer1" Canva
s.Top="40" Width="400" Height="258"></ScrollViewer>
...
private void btnLoad_Click(ob
ject sender,Sy
stem.Window
s.RoutedEventArgs
E)
{
if (this.viewer1.Content == null)
{
this.viewer1.Content = new SubWin();
}}
3、"主Xaml"中以模态窗口方式弹出"子Xaml"
这个要用到sl3.0中的ChildWindow控件
(a)项目中先
添加Sy
stem.Window
s.Controls的引用
(b)xaml
文件头部加二行
代码:
xmlns:controls="clr-namespace:System.Windows.Controls;assembly=System.Windows.Controls"
xmlns:vsm="clr-namespace:System.Windows;assembly=System.Windows"
(C)要弹出的地方,参
考以下
代码:
private void btnShow_Click(ob
ject sender,Sy
stem.Window
s.RoutedEventArgs
E)
{
ChildWindow win = new ChildWindow();
win.title = "测试弹出窗口";
win.Content = new SubWin();
win.HasCloseButton = true;
win.overlayBrush = new SolidColorBrush(Colors.Gray);
win.overlayOpacity = 0.3;
win.Width = 205;
win.Height = 205;
win.Show();
}
4、调用Xaml时的参数传递问题
可以利用构造
函数来
解决,参
考以下
代码
namespace ChildWin
{
public partial class SubWin : UserControl
{
public SubWin()
{
InitializeComponent(
);
}
public SubWin(datetiR_211_11845@e dt):this()
{
this.calendar1.DisplayDate = dt;
} }
}
这里我
添加了
一个带参数的构架
函数做为测试,即public SubWin(
datetiR_211_11845@e dt):this(),这里接受
一个日期型的参数,然后把日期控件的
显示值设置为该参数,而:this()的作用是
调用该构架
函数前,先
调用无参数的构造
函数,即SubWin(),这种写法
在本例中等价于:
public SubWin(
datetiR_211_11845@e dt)
{
InitializeComponent(
);
thi
s.calendar1.DisplayDate = dt;
}
重点:
调用该Xaml时,上面都是xxx = new SubWin()来处理的,现在我们可以用thi
s.viewer1.Content =
new SubWin(datetiR_211_11845@e.Parse("1979-6-5"));来传递
一个参数给SubWin