人生不可能总是顺心如意的,但是持续朝着阳光走,影子就会躲在后面。刺眼,却表明对的方向。
其实在Silverlight中开发模式窗体并不难,比在Html里面用div来构造容易多了,但是要做到具有重用性和规范性还是要下一点工夫的。如果SL的开发朋友们想偷一点懒,直接用些现成写好的模式窗体代码的话,我在这里介绍一个SL的框架,叫SilverlightFX,里面就有一个Form类,只要你的xaml类继承了Form类就可以很方便地使用模式窗体了。具体方面可以参照他的sample工程,这里给出SilverlightFX的连接给大家 http://projects.nikhilk.net/SilverlightFX 如果想自己写模式窗体的代码也不难,这里我给出一段简单的代码大家
首先是模式窗体的基类及委托
所有想以模式窗体弹出的控件都可以继承ModalDialog这个类,然后母窗体必须实现IModalDialogOpener接口并实现里面的方法;至于ModalEventArg这个参数类是可以由开发者自己扩展的,我这里只提供一个object类型的结果属性。 接着是在母窗体中给出遮蔽层元素
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);
<!-- 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"/>
这个遮蔽层也是可以由开发者自己订制的,比如长宽、透明度、背景色之类的。 最后就是在母窗体代码是实现 ShowModalDialog 方法和 CloseModalDialog 方法了,思路无非是把遮蔽层的Child中赋值为模式窗体类,接着显示遮蔽层;关闭反之。 模式窗体就介绍到这里,以后如果有更好的代码我会及时奉上的。
到此这篇关于asp.net Silverlight中的模式窗体就介绍到这了。这个世界上从来没有一蹴而就的成功,如果没有踏实的努力,没有点滴的积累,再好的运气降落到你头上时,你也没有接住它的实力。早安!与您共勉,人生需要一步一个脚印!更多相关asp.net Silverlight中的模式窗体内容请查看相关栏目,小编编辑不易,再次感谢大家的支持!