zoukankan      html  css  js  c++  java
  • c#最大化最小化事件

    const int WM_SYSCOMMAND = 0x112;
    const int SC_CLOSE = 0xF060;
    const int SC_MINIMIZE = 0xF020;
    const int SC_MAXIMIZE = 0xF030;
    protected override void WndProc(ref Message m)
    {
        if (m.Msg == WM_SYSCOMMAND)
        {
            if (m.WParam.ToInt32() == SC_MINIMIZE)
            {
                this.Visible = false;
                return;
            }
        }
        base.WndProc(ref m);
    }
     

    捕获窗体的最大化最小化按钮的事件

            protected override void OnResize(EventArgs e) 
            { 
                if(WindowState == FormWindowState.Maximized) 
                { 
                    //最大化时所需的操作 
                    MessageBox.Show("max");
                } 
                else if(WindowState == FormWindowState.Minimized) 
                { 
                    //最小化时所需的操作
                    MessageBox.Show("min");
                } 
            }  


    *****但是问题出现了,最大化以后,内部的控件不能随anchar发生变化。。。。。,问题出在哪里呢?
    于是又找到了一些代码,如下

    虽然Form类没有提供Minimize的事件,但还是可以通过重载Deactive来实现
    当Form失去焦点后,测试WindowState取得Form状态,若为Minimized既是最小化事件。
    本例为最小化后隐藏窗口:

    private void Form1_Deactivate(object sender, EventArgs e)
            {
                if (this.WindowState == FormWindowState.Minimized)
                    this.Visible = false;
            }

    还有种方法更加直接,重载WndProc:

    const int WM_SYSCOMMAND = 0x112;
    const int SC_CLOSE = 0xF060;
    const int SC_MINIMIZE = 0xF020;
    const int SC_MAXIMIZE = 0xF030;
    protected override void WndProc(ref Message m)
    {
        if (m.Msg == WM_SYSCOMMAND)
        {
            if (m.WParam.ToInt32() == SC_MINIMIZE)
            {
                this.Visible = false;
                return;
            }
        }
        base.WndProc(ref m);
    }

    **具体原因不知道,最后重载WndProc取得成功,但是上面的代码为什么就不行呢?我会继续跟踪。以后会不断地补充

  • 相关阅读:
    聊聊ES6中的generator
    generator-yield到底是个啥
    jquery 常用方法中那些我不知道的事
    jquery 获取textarea文本值详解
    数组去重
    五指棋人机大战之ai篇
    五指棋人机大战之ui篇
    css控制背景图像不随滚动条的滚动而滚动
    用canvas画会旋转的伞
    CSS3 实现太极图案
  • 原文地址:https://www.cnblogs.com/hdl217/p/1768321.html
Copyright © 2011-2022 走看看