制做像QQ那种自动停靠.自动收缩的窗口.

1.首先处理自动停靠.
    1).建立一个对话框类CDlg.
    2).
        ///dlg.h
          class CDlg
        {
            private:
                   bool m_isAutoHide; //窗口是否可以自动隐藏
                   bool m_isWinHide; // 窗口是否隐藏
               ...........
        }

      ///dlg.cpp
         .....
    void CDlg::OnMove(int x, int y)
    {
         CDialog::OnMove(x, y);
         
         ///窗口从显示到隐藏时,不做其它操作
        if(m_isWinHide)
         {
              return;
         }
         
         CRect tRect;
         GetWindowRect(tRect);
         if(tRect.top<10)
         {///如果窗口移动后的位置和到屏幕上方的距离小于10
           ///就使窗口停靠到屏幕上方.

              tRect.bottom-= tRect.top;
              tRect.top= 0;
              MoveWindow(tRect);
               ///窗口停靠后就可以自动隐藏
              m_isAutoHide= true;
          }
         else
         {
               ///如窗口没有停靠就不可以自动隐藏
              m_isAutoHide= false;
         }
 
       }

    void CDlg::OnMoving(UINT fwSide, LPRECT pRect)
    {
        if((pRect->top < 10)
          && (!m_isAutoHide) )
        {///如果窗口移动到的位置和到屏幕上方的距离小于10
           ///就使窗口停靠到屏幕上方.

                pRect->bottom-= pRect->top;
                pRect->top= 0;
                m_isAutoHide= true;
        }

        CDialog::OnMoving(fwSide, pRect);
    }
2.处理自动收缩
      //dlg.h
        class CDlg
         {
                .....
                LRESULT  OnMouseLeave( HWND hwnd, UINT msg,
                                              WPARAM  wParam,LPARAM lParam  );
         }

     //dlg.cpp
            BEGIN_MESSAGE_MAP(CDlg, CDialog)
                  ON_MESSAGE(WM_MOUSELEAVE,OnMouseLeave)
            END_MESSAGE_MAP()
      .......

     LRESULT CDlg::OnMouseLeave(HWND hwnd, UINT msg, WPARAM wParam,                                                                   LPARAM lParam  )
        {
             if(m_isAutoHide)
             {
                  CPoint tPoint;
                  GetCursorPos(&tPoint);
                  CRect tRect;
                  GetWindowRect(&tRect);
                  if(!(tRect.PtInRect(tPoint)))
                  {
                      m_isWinHide=true;
                   tRect.top= tRect.top - tRect.bottom +5;
                   tRect.bottom= 5;
                   MoveWindow(tRect);

                   ::SetWindowPos(
                            ::GetDesktopWindow()
                            ,HWND_TOPMOST,tRect.left,tRect.top
                            ,tRect.Width(),tRect.Height    ()
                            ,SWP_SHOWWINDOW);
                 }
            }
      return TRUE;
    }


    void CDlg::OnMouseMove(UINT nFlags, CPoint point)
        {
                 if(m_isWinHide)
                 {
                      CRect tRect;
                      GetWindowRect(&tRect);
                     tRect.bottom+= (tRect.bottom-tRect.top-5);
                     tRect.top=0;
                     MoveWindow(tRect);
                     m_isWinHide= false;
                  }

                    TRACKMOUSEEVENT EventTrack;
                      EventTrack.cbSize= sizeof(TRACKMOUSEEVENT);
                      EventTrack.dwFlags= TME_LEAVE;
                      EventTrack.hwndTrack= this->m_hWnd;
                      _TrackMouseEvent(&EventTrack);

            CDialog::OnMouseMove(nFlags, point);

        }

<完成>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
YOLO高分设计资源源码,详情请查看资源内容中使用说明 YOLO高分设计资源源码,详情请查看资源内容中使用说明 YOLO高分设计资源源码,详情请查看资源内容中使用说明 YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明
### 回答1: 自动QQ信息脚本.bat是一种批处理脚本,用于实现在Windows系统下自动发送QQ信息的功能。下面是一个简单的实现例子。 首先,我们需要使用一个文本编辑器(如记事本)创建一个新的批处理文件,并将其命名为"自动QQ信息脚本.bat"。然后在脚本中使用以下代码: ``` @echo off REM 设置QQ号码和消息内容 set qqNumber=你的QQ号码 set message=你要发送的消息内容 REM 启动QQ并登录 start "" "C:\Program Files (x86)\Tencent\QQ\QQ.exe" timeout /t 10 REM 等待QQ窗口加载完成 REM 根据实际情况可能需要调整timeout命令中的等待时间 REM 发送消息 echo %message% | clip timeout /t 1 REM 复制消息内容到剪贴板 REM 激活QQ窗口 taskkill /f /im QQ.exe timeout /t 1 REM 关闭QQ start "" "C:\Program Files (x86)\Tencent\QQ\QQ.exe" timeout /t 10 REM 重新启动QQ并登录 REM 粘贴并发送消息 echo qqNumber | clip timeout /t 1 REM 复制QQ号码到剪贴板 REM 这里假设QQ的发送消息快捷键是Ctrl + V REM 如果不是,请根据实际情况调整 REM 激活QQ窗口 taskkill /f /im QQ.exe timeout /t 1 REM 关闭QQ REM 删除剪贴板中的内容,确保安全 echo off | clip ``` 在上述代码中,我们首先设置了QQ号码和要发送的消息内容。接下来,通过启动QQ并登录,等待QQ窗口加载完成。然后,我们将消息内容复制到剪贴板,并重新启动QQ并登录。最后,通过粘贴方式将消息内容发送给指定的QQ号码。 需要注意的是,以上仅为一个简单的实现示例,具体的操作和路径可能需要根据你的QQ应用程序位置和操作习惯进行调整。同时,使用此脚本需要确保系统已安装QQ和正确设置QQ的一些相关配置。 希望以上回答对你有所帮助! ### 回答2: 自动qq信息脚本.bat是一种批处理脚本,用于自动化发送消息到QQ聊天窗口。 该脚本利用Windows的命令行功能,通过模拟人工操作,实现自动发送QQ信息的功能。以下是一个简单的实现: 1. 首先,创建一个文本文件,重命名为auto_send_qq_message.bat。 2. 打开该文件,输入以下命令: ```bat @echo off echo set WshShell = WScript.CreateObject("WScript.Shell") > sendmsg.vbs echo WshShell.SendKeys "%" >> sendmsg.vbs echo WshShell.SendKeys " QQ号码" >> sendmsg.vbs echo WshShell.SendKeys "{ENTER}" >> sendmsg.vbs echo pause >> sendmsg.vbs start sendmsg.vbs ``` 3. 替换"QQ号码"为你要发送消息的好友的QQ号码。 4. 保存并退出文件。 5. 双击运行该批处理脚本,会自动打开QQ聊天窗口,并将光标聚焦到输入框中。 6. 输入你要发送的消息内容后,按下回车键,脚本会自动将消息发送给对应的QQ好友。 7. 在消息发送完成后,按下任意键退出脚本。 需要注意的是,该脚本只能自动发送消息到已经打开的QQ聊天窗口,且需要提前将光标聚焦到输入框中。同时,由于该脚本使用了模拟键盘输入的方式,可能会受到系统安全设置的限制。 总结起来,这个自动qq信息脚本.bat可以帮助我们在一定程度上进行自动化发送QQ信息的操作,方便快捷地与好友进行聊天。 ### 回答3: 自动QQ信息脚本.bat是一个批处理脚本,用于自动发送QQ信息。它是基于Windows操作系统下的批处理语言编写的。 实现自动发送QQ信息的脚本需要借助QQ的API或者第三方工具。下面是一个简单的示例脚本: ```bat @echo off REM 设置发送消息的目标QQ号 set qq=1234567890 REM 设置发送的消息内容 set message=你好,这是自动发送的消息! REM 设置QQ程序的路径 set qqPath="C:\Program Files (x86)\Tencent\QQ\Bin\QQ.exe" REM 启动QQ程序 start "" %qqPath% REM 等待QQ程序启动 timeout /t 5 REM 发送消息 echo %message% | clip start "" %qqPath% -SendMsg %qq% REM 等待消息发送完成 timeout /t 5 REM 关闭QQ程序 taskkill /f /im QQ.exe echo 消息已发送! pause ``` 以上是一个简单的自动发送QQ信息的脚本示例。通过设置目标QQ号和消息内容后,脚本会自动启动QQ程序,并等待一段时间后发送消息,然后自动关闭QQ程序。最后打印出消息已发送的提示。 需要注意的是,这只是一个示例脚本,具体的实现可能会因为QQ软件版本的不同而有所调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值