时间:2021-07-01 10:21:17 帮助过:31人阅读
- <br>public class ModalDialog : UserControl <br>{ <br>public event EventHandler closed; // Dialog Close Event <br>public event ModalEventHandler CompletedCallback; // Call back event <br><br>public void Close() <br>{ <br>if (closed != null) <br>{ <br>closed(this, EventArgs.Empty); <br>} <br>} <br><br>public void HandleCallback(ModalEventArgs e) <br>{ <br>if (CompletedCallback != null) <br>{ <br>CompletedCallback(this, e); <br>} <br>} <br>} <br><br>public interface IModalDialogOpener <br>{ <br>void ShowModalDialog(ModalDialog dialog); <br>void CloseModalDialog(); <br>} <br>public class ModalEventArgs : EventArgs <br>{ <br>public object Result { set; get; } // the result of this modal dialog <br>} <br>public delegate void ModalEventHandler(object sender, ModalEventArgs e); <br> <br><br> 所有想以模式窗体弹出的控件都可以继承ModalDialog这个类,然后母窗体必须实现IModalDialogOpener接口并实现里面的方法;至于ModalEventArg这个参数类是可以由开发者自己扩展的,我这里只提供一个object类型的结果属性。 <br><br>接着是在母窗体中给出遮蔽层元素 <br><span><u></u></span> 代码如下:<pre class="brush:php;toolbar:false layui-box layui-code-view layui-code-notepad"><ol class="layui-code-ol"><li><br><!-- Use for loading modal dialog --> <br><Border x:Name="placeHolder" VerticalAlignment="Stretch" HorizontalAlignment="Stretch" <br>Visibility="Collapsed" Width="1600" Height="1200" <br>Background="#ff8a8a8a" Opacity="0.9" Canvas.ZIndex="1000"/> <br> <br>这个遮蔽层也是可以由开发者自己订制的,比如长宽、透明度、背景色之类的。 <br><br>最后就是在母窗体代码是实现 ShowModalDialog 方法和 CloseModalDialog 方法了,思路无非是把遮蔽层的Child中赋值为模式窗体类,接着显示遮蔽层;关闭反之。 <br><br>模式窗体就介绍到这里,以后如果有更好的代码我会及时奉上的。</li><li> </li><li> </li></ol></pre>