zoukankan      html  css  js  c++  java
  • 鼠标拖动物体DEMO

    在项目中,为了是设计更人性化,经常会要用鼠标去拖动物体,于是我就花时间写了个demo。

    之前我没有知道有MOUSEMOVE这个消息,于是就自己去想用LBUTTONDOWN和LBUTTONUP去实现MOUSEMOVE这个功能,最后悲剧了。

    开始我的想法是这样的,用POINT记录前后两次鼠标的位置,然后通过射线碰撞求出两个交点,进而求出平移矩阵。

    定义结构体记录鼠标点击的信息。

    typedef struct CursorInfo

    {

    Point oldpoint;

    Point newpoint;

    bool oldclick;

    }CursorInfo;

    响应鼠标点击事件:

    1、  LBUTTONDOWN。如果oldclickfalse,则令oldclicktrue,并记录鼠标点击位置oldpoint;如果oldclicktrue,则记录当前鼠标点击位置newpoint,并将oldclick置为false。通过oldpointnewpoint计算平移矩阵与物体原来的矩阵相乘即可。只有当oldpoint与物体相交时才计算平移矩阵并且进行矩阵的相关运算。

    2、  LBUTTONDOWNUPoldclick置为false

    后来我发现,如果你一直按着鼠标左键,是只响应一次LBUTTONDOWN消息的,这样的话就无法执行oldclick为true的情况,也几是说无法移动物体。

    在我查看LBUTTONDOWN的宏定义的时候发现了MOUSEMOVE这个消息,然后就想出了响应鼠标移动的消息。有了MOUSEMOVE,整个算法就很简单了,只要在LBUTTONDOWN和LBUTTONUP一对消息之间对MOUSEMOVE消息进行处理就行了,也就是不停的获取鼠标的位置,利用新旧两个鼠标的位置就可以求出平移矩阵,主要代码如下

    代码
    //改变移动后的物体的矩阵,uMsg为消息,World为物体原来的矩阵,plane为与xoy平面平行的平面,即y=plane
        void MoveMesh(UINT uMsg, ID3DXMesh *pMesh, D3DXMATRIX &World, float Plane)
        {
            
    float u, v, t;
            ::GetCursorPos(
    &m_NewPoint);
            ::ScreenToClient(DXUTGetHWND(), 
    &m_NewPoint);

            
    switch(uMsg)
            {
            
    case WM_LBUTTONDOWN:
                {
                    
    if!m_LClick )
                    {
                        m_LClick 
    = true;
                        m_Pick 
    = m_pPickManager->IsPick(m_NewPoint.x, m_NewPoint.y, pMesh, World, t, u, v );        
                        m_OldPoint 
    = m_NewPoint;            
                    }
                }
                
    break;

            
    case WM_LBUTTONUP:
                {
                    m_LClick 
    = false;
                    m_Pick 
    = false;
                }
                
    break;

            
    case WM_MOUSEMOVE:
                
    if( m_Pick )
                {
                    ::GetCursorPos(
    &m_NewPoint);
                    ::ScreenToClient(DXUTGetHWND(), 
    &m_NewPoint);
                    
    if(m_pPickManager->IsPick(m_OldPoint.x, m_OldPoint.y, pMesh, World, t, u, v ))
                    {
                        D3DXMATRIX world;
                        CaculateMatrix( world, m_OldPoint, m_NewPoint, Plane  );
                        World 
    *= world;
                    }
                    m_OldPoint 
    = m_NewPoint;            
                }
                
    break;
            }
        }

     

  • 相关阅读:
    《A First Course in Probability》-chaper4-离散型随机变量-随机变量函数的期望
    《训练指南》——7.17
    《A First Course in Probability》-chaper4-离散型随机变量-负二项分布
    《A First Course in Probability》-chaper5-连续型随机变量-正态分布
    《University Calculus》-chaper8-无穷序列和无穷级数-比值审敛法
    Scheme实现二叉查找树及基本操作(添加、删除、并、交)
    hdu5884(多叉哈夫曼树)
    uva10857(状态压缩DP)
    hdu4055
    Controlled Tournament(状态压缩DP)
  • 原文地址:https://www.cnblogs.com/littlethank/p/1816248.html
Copyright © 2011-2022 走看看