前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >wpf、winform仿QQ靠边隐藏

wpf、winform仿QQ靠边隐藏

作者头像
晓晨
发布2018-06-22 14:51:29
6760
发布2018-06-22 14:51:29
举报
文章被收录于专栏:晓晨的专栏晓晨的专栏

先说下下面的代码和demo是wpf的,如果winform要用,改动不大的。

实现思路: 通过定时刷新鼠标位置 和 窗体坐标 进行计算 来控制窗体的隐藏 显示 

代码都有详细的注释

代码语言:javascript
复制
//窗体状态 true为显示 false为隐藏
        private bool IsHide = false;
        //鼠标状态 true为进入窗体 false为离开窗体
        private bool IsMouseEnter = false;
        //计时器 通过win32api实时获取鼠标位置
        private Timer timer;

        public MainWindow()
        {
            InitializeComponent();
            timer = new Timer();
            timer.Interval = 300;
            timer.Tick += new EventHandler(timer_Tick);
            
        }

        void timer_Tick(object sender, EventArgs e)
        {
            MousePosition.CurrentPoint point;
            MousePosition.MouseMove(out point);
           //判断鼠标是否进入窗体
            if (point.X >= this.Left && point.X <= this.Left + this.Width&&point.Y>=this.Top&&point.Y<=this.Top+this.Height)
            {
                //鼠标在窗体内部
                IsMouseEnter = true;
            }
            else
            {
                //鼠标离开窗体
                IsMouseEnter = false;
            }

            //判断窗体是否在隐藏状态
            if (IsHide)
            {
                //如果在隐藏状态 且 横坐标在窗体横坐标方位 纵坐标小于等于20 则显示窗体 并把窗体状态设置为显示
                if (point.X >= this.Left && point.X <= this.Left + this.Width)
                {
                    if (point.Y <= 20)
                    {
                        this.Top = 0;//显示窗体
                        IsHide = false;//把窗体状态设置为显示
                    }
                }
            }
            else
            {
                //如果在显示状态 且纵坐标小于等于20 切鼠标不在窗体内 则隐藏窗体

                if (this.Top <= 20 && !IsMouseEnter)
                {
                    this.Top = 0 - this.Width;//隐藏窗体
                    IsHide = true;
                }
            }
        }

        private void Window_Loaded(object sender, RoutedEventArgs e)
        {
            timer.Start();
        }
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2016-05-03 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档