• OpenGL鼠标旋转代码


    void COpenGLView::OnKeyDown(UINT nChar, UINT nRepCnt, UINT nFlags)

    {

    // TODO: Add your message handler code here and/or call default

    switch (nChar)

    {

    case VK_UP:                m_yPos = m_yPos + 0.1f;

    break;

    case VK_DOWN:        m_yPos = m_yPos - 0.1f;

    break;

    case VK_LEFT:        m_xPos = m_xPos - 0.1f;

    break;

    case VK_RIGHT: m_xPos = m_xPos + 0.1f;

    break;

    default:                MessageBox("Press the arrow keys only");

    break;

    }                

       

    InvalidateRect(NULL,FALSE);

       

    CView::OnKeyDown(nChar, nRepCnt, nFlags);

    }

       

    void COpenGLView::OnLButtonDown(UINT nFlags, CPoint point)

    {

    // TODO: Add your message handler code here and/or call default

    m_MouseDownPoint=point;

    SetCapture();

       

    CView::OnLButtonDown(nFlags, point);

    }

       

    void COpenGLView::OnLButtonUp(UINT nFlags, CPoint point)

    {

    // TODO: Add your message handler code here and/or call default

    m_MouseDownPoint=CPoint(0,0);

    ReleaseCapture();

       

    CView::OnLButtonUp(nFlags, point);

    }

       

    void COpenGLView::OnMouseMove(UINT nFlags, CPoint point)

    {

    // TODO: Add your message handler code here and/or call default

    // Check if we have captured the mouse

    if (GetCapture()==this)

    {

    //Increment the object rotation angles

    m_xAngle+=(point.y-m_MouseDownPoint.y)/3.6;

    m_yAngle+=(point.x-m_MouseDownPoint.x)/3.6;

    //Redraw the view

    InvalidateRect(NULL,FALSE);

    //Set the mouse point

    m_MouseDownPoint=point;

    };

       

    CView::OnMouseMove(nFlags, point);

    }

    然后在glRatate(m_xAngle...);方法中设置旋转即可

  • 相关阅读:
    左偏树
    “今日头条杯”首届湖北省大学程序设计竞赛现场赛
    最短路
    BP神经网络算法改进
    图论学习路线
    差分演化算法
    51Nod 1413 权势二进制
    51Nod 1315 合法整数集
    Treap(树堆)
    今日头条杯2018湖北省大学生程序设计竞赛(网络赛)
  • 原文地址:https://www.cnblogs.com/sunliming/p/2085655.html
Copyright © 2020-2023  润新知