C# 笔记4——如何实现单击放大全屏和退出全屏

C# 笔记4——如何实现单击放大全屏和退出全屏

      由于工作需求,需要实现单击放大和退出全屏功能,想了一下,即单击放大时候把播放视频的picturebox的大小设置和屏幕宽高相同、位置设置为屏幕左上角(0,0)即可,单击退出全屏时候把控件大小和位置恢复到初始位置即可。
      需要注意的是若控件在某一个panel中,也需要如上设置panel的位置和宽高,否则无法达到理想效果;对于需要全屏的控件最好将其单独放在一个panel中,否则容易出现其它控件叠加到放大控件上的不良效果。
      主要思路说完了,开始晒代码了!

单击按钮代码如下:

private void RealPlayWnd_Click(object sender, EventArgs e)
        {
            Rectangle rect = new Rectangle();
            //rect = Screen.GetWorkingArea(this) ;//获取工作分辨率会出现一个问题,若任务栏放在最左边,则会在最右边留下任务栏的宽度
            rect = Screen.GetBounds(this);
            if (!video_max)
            {
                //放大
                this.RealPlayWnd.Dock = DockStyle.Fill;     //DockStyle.None
                this.FormBorderStyle = FormBorderStyle.None;
                //this.WindowState = FormWindowState.Maximized; 不需要
                this.MaximumSize = new Size(rect.Width, rect.Height);
                //设置相应控件的位置
                this.Location = new System.Drawing.Point(0, 0);
                this.panel_rt_video.Location = new System.Drawing.Point(0, 0);
                this.panel_rt_video_pic.Location = new System.Drawing.Point(0, 0);
                //设置主窗体和相应控件的宽高
                this.Width = rect.Width;
                this.Height = rect.Height;
                panel_rt_video.Width = rect.Width;
                panel_rt_video.Height = rect.Height;
                panel_rt_video_pic.Width = rect.Width;
                panel_rt_video_pic.Height = rect.Height;
                this.RealPlayWnd.Width = rect.Width;
                this.RealPlayWnd.Height = rect.Height;
                video_max = true;
            }
            else {
                //缩小
                this.RealPlayWnd.Dock = DockStyle.None;     //DockStyle.None
                this.FormBorderStyle = FormBorderStyle.Sizable;
                //恢复各个控件的宽高
                this.Width = 1200;
                this.Height = 750;
                panel_rt_video.Width = 977;
                panel_rt_video.Height = 590;
                panel_rt_video_pic.Width = 610;
                panel_rt_video_pic.Height = 410;
                this.RealPlayWnd.Width = 593;
                this.RealPlayWnd.Height = 401;
                //恢复各个窗体的初始位置
                this.Location = new Point((rect.Width - this.Width) / 2, (rect.Height - this.Height) / 2);
                this.panel_rt_video.Location = new Point(202, 119);
                this.panel_rt_video_pic.Location = new Point(274, 18);
                video_max = false;
            }
        }


      如上,需要放大和缩小的有主窗体、两个panel(panel_rt_video,panel_rt_video_pic)和一个picturebox(RealPlayWnd),放大前需要获取显示屏的大小,然后设置放大控件的Dock(RealPlayWnd.Dock = DockStyle.Fill )属性为Fill、设置form的FormBorderStyle(this.FormBorderStyle = FormBorderStyle.None;)属性为None,最后设置与之相关控件的位置和大小就可以了;退出放大几乎就干一些还原工作了,把放大的属性恢复到初始状态即可。


截图如下:

未放大


已放大




      至此,已经可以初步实现放大全屏和退出全屏的功能了!


评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

昕光xg

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值