码迷,mamicode.com
首页 > Windows程序 > 详细

【帅刺猬课堂】Winform中使用WPF的UserControl

时间:2015-01-29 12:08:07      阅读:289      评论:0      收藏:0      [点我收藏+]

标签:

今天准备做一个登录界面的时候,想用WPF来做出比较漂亮的界面,所有在Winform项目中加入WPF的用户控件,过程如下,技术分享FrmLogin是Winform界面,是父窗体,Login.xaml的WPF的UserControl是子窗体,

首先打开FrmLogin的设计界面,在左边的工具栏中找出技术分享拖到界面上,并将Dock设置为Fill,其实就是让ElementHost充满整个界面。然后在FrmLogin对应的代码中加入:

 1 protected override void OnLoad(EventArgs e)
 2         {                        
 3             if (!DesignMode)
 4             {
 5                 var login = new Login(this);
 6                 elementHost1.Child = login;                
 7             }
 8             
 9             base.OnLoad(e);
10         }

下面碰到一个例子,就是我在这个UserControl中点击登录的时候,隐藏自身的同时,也需要隐藏掉父窗体,也就隐藏掉FrmLogin,所以我的做法是,在父窗体代码中设置个属性:MyOpacity为可读写。代码如下:

public double MyOpacity
{
       get { return this.Opacity; }
       set { this.Opacity=value; }
}

protected override void OnLoad(EventArgs e)
{                        
        if (!DesignMode)
        {
              var login = new Login(this);//这里将父窗体传递到子窗体Login中去
               elementHost1.Child = login;                
        }
            
         base.OnLoad(e);
}

然后在子窗体代码中加入:

public Login(FrmLogin frm):this()  //通过构造函数将FrmLogin也就是父窗体取到
{
            this.frmLogin = frm;
            tRepository = new T_HuntersRepository();
}

private void BtnStart_OnClick(object sender, RoutedEventArgs e)
{
            if (tRepository.Login(userName.Text, userPassword.Text))
            {                
                Form1 form1=new Form1();
                form1.Show();
                this.Opacity = 0;            //改变自己的透明度
                frmLogin.MyOpacity = 0;      //在这里改变父窗体的透明度
            }
            else
            {
                MessageBox.Show("用检查用户名和密码!", "系统提示:");
            }
        }

简单的界面如图:技术分享,绿色部分为WPF的UserControl,红色为Winform的窗体,点击登录成功后,两者都会隐藏掉。

转载请注明:【帅刺猬课堂】,如果有任何疑问请QQ联系:363608715

 

【帅刺猬课堂】Winform中使用WPF的UserControl

标签:

原文地址:http://www.cnblogs.com/WPFBlog/p/4259324.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!