zoukankan      html  css  js  c++  java
  • Winform开发中的窗体重复及灵活切换问题

    Winform开发中的窗体重复及灵活显示问题

    1.问题引入

    在项目中需要实现主窗体点击按钮后打开子窗体,但是如果不限制的话每次点击都会打开一个新窗体,用户体验不好还浪费内存。所以这里要做的是限制每个子窗体只可以打开一次,如果打开后没有关闭子窗体或者子窗体被最小化了,就直接把已打开的窗体激活并置顶显示。同时还要满足不同的子窗体是可以共存的,也就是只能同时有一个子窗体A,子窗体B,子窗体C……但是子窗体ABC之间是可以同时存在并互相切换的。

    2.解决思路

    这里我的做法是写两个方法:ShowOpenForm()用来激活已打开的窗体,同时返回Boolean值对应当前窗体的打开状态,NewForm()用于第一次打开新窗体的时候实例化窗体对象,并设置相关参数。

    3.参考代码

    整体结构

    ShowOpenForm()方法:

     1  private Boolean ShowOpenForm(string frmName)
     2         {
     3             //Application .OpenForms为已打开的窗体
     4             foreach (Form frm in Application.OpenForms)
     5             {
     6                 if (frm.Name  == frmName)//如果传递的窗体名称参数已经存在
     7                 {
     8                     frm.Activate();//激活已有窗体
     9                     if (frm.WindowState == FormWindowState.Minimized)//如果已有窗体被最小化了
    10                     {
    11                         frm.WindowState = FormWindowState.Normal;//恢复被最小化窗体的显示
    12                     }
    13                     return false;//返回false说明窗体已打开
    14                 }               
    15             }
    16             return true;//已打开的窗体里没有作为参数传递的窗体,则返回true
    17         }

    NewForm()方法:

    1  private void NewForm(Form objForm)
    2         {            
    3             objForm.Show();//显示要打开的窗体的
    4             objForm.Top = objForm.Top + 64;//项目需要,显示界面下移64像素
    5         }

    示例Click事件:

    1  private void tsbVoucherQuery_Click(object sender, EventArgs e)
    2         {
    3             if (ShowOpenForm("FrmVoucherQuery"))//如果返回的Boolean值为true,则窗体没打开,调用NewForm()方法
    4             {
    5                 NewForm(new FrmVoucherQuery()); //调用打开新窗体方法,并直接实例化要打开的窗体作为参数窗体               
    6             }
    7         }
  • 相关阅读:
    c++ 动态判断基类指针指向的子类类型(typeid)
    qt在GUI显示时,将调试信息输出到控制台的设置
    Qt库版查询
    Qt动态库静态库的创建、使用、多级库依赖、动态库改成静态库等详细说明
    ICMP timestamp 请求响应漏洞
    linux 防火墙 ufw使用
    MySQL--binlog和relay log的生成和删除
    SSD 相关基础知识
    python36--将数据保存为excel
    MySQL 5.7并发复制和mysqldump相互阻塞引起的复制延迟
  • 原文地址:https://www.cnblogs.com/xtualong/p/8094477.html
Copyright © 2011-2022 走看看