Silverlight中的模式窗体
来源:爱站网时间:2022-09-29编辑:网友分享
今天小编来给大家谈一谈Silverlight中的模式窗体的相关内容,感兴趣的朋友可以随时来参考阅读下,接下来的时间就让爱站技术频道小编给大家来说一说,希望对你有所帮助。
其实在Silverlight中开发模式窗体并不难,比在Html里面用div来构造容易多了,但是要做到具有重用性和规范性还是要下一点工夫的。如果SL的开发朋友们想偷一点懒,直接用些现成写好的模式窗体代码的话,我在这里介绍一个SL的框架,叫SilverlightFX,里面就有一个Form类,只要你的xaml类继承了Form类就可以很方便地使用模式窗体了。
如果想自己写模式窗体的代码也不难,这里我给出一段简单的代码大家
首先是模式窗体的基类及委托
复制代码 代码如下:
public class ModalDialog : UserControl
{
public event EventHandler closed; // Dialog Close Event
public event ModalEventHandler CompletedCallback; // Call back event
public void Close()
{
if (closed != null)
{
closed(this, EventArgs.Empty);
}
}
public void HandleCallback(ModalEventArgs e)
{
if (CompletedCallback != null)
{
CompletedCallback(this, e);
}
}
}
public interface IModalDialogOpener
{
void ShowModalDialog(ModalDialog dialog);
void CloseModalDialog();
}
public class ModalEventArgs : EventArgs
{
public object Result { set; get; } // the result of this modal dialog
}
public delegate void ModalEventHandler(object sender, ModalEventArgs e);
{
public event EventHandler closed; // Dialog Close Event
public event ModalEventHandler CompletedCallback; // Call back event
public void Close()
{
if (closed != null)
{
closed(this, EventArgs.Empty);
}
}
public void HandleCallback(ModalEventArgs e)
{
if (CompletedCallback != null)
{
CompletedCallback(this, e);
}
}
}
public interface IModalDialogOpener
{
void ShowModalDialog(ModalDialog dialog);
void CloseModalDialog();
}
public class ModalEventArgs : EventArgs
{
public object Result { set; get; } // the result of this modal dialog
}
public delegate void ModalEventHandler(object sender, ModalEventArgs e);
所有想以模式窗体弹出的控件都可以继承ModalDialog这个类,然后母窗体必须实现IModalDialogOpener接口并实现里面的方法;至于ModalEventArg这个参数类是可以由开发者自己扩展的,我这里只提供一个object类型的结果属性。
接着是在母窗体中给出遮蔽层元素
<!-- Use for loading modal dialog -->
<Border x:Name="placeHolder" VerticalAlignment="Stretch" HorizontalAlignment="Stretch"
Visibility="Collapsed" Width="1600" Height="1200"
Background="#ff8a8a8a" Opacity="0.9" Canvas.ZIndex="1000"/>
<Border x:Name="placeHolder" VerticalAlignment="Stretch" HorizontalAlignment="Stretch"
Visibility="Collapsed" Width="1600" Height="1200"
Background="#ff8a8a8a" Opacity="0.9" Canvas.ZIndex="1000"/>
这个遮蔽层也是可以由开发者自己订制的,比如长宽、透明度、背景色之类的。
最后就是在母窗体代码是实现 ShowModalDialog 方法和 CloseModalDialog 方法了,思路无非是把遮蔽层的Child中赋值为模式窗体类,接着显示遮蔽层;关闭反之。
模式窗体就介绍到这里,以后如果有更好的代码我会及时奉上的。
Silverlight中的模式窗体内容小编就一一给大家讲解到这里了,是不是觉得挺有意思的呢?想要获取更多精彩有趣的技术文章内容,尽在js.aizhan.com。