《基于MFC的OpenGL编程》Part 6 Keyboard and Mouse Control

简介:
在上一篇的基础上加入对键盘和鼠标的事件处理程序,以便用其来控制3D物体的旋转和移动。
1,首先在CCY457OpenGLView类中为WM_KEYDOWN,  WM_LBUTTONDOWN, WM_LBUTTONUP 和 WM_MOUSEMOVE四个事件加入事件处理函数。

2,在CCY457OpenGLView.h中加入下列用于控制旋转和移动的变量:

    GLfloat m_xAngle;
    GLfloat m_yAngle;
    GLfloat m_xPos;
    GLfloat m_yPos;
    CPoint m_MouseDownPoint;
并在构造函数中初始化:

复制代码
CCY457OpenGLView::CCY457OpenGLView()
{
    m_xPos = 0.0f;
    m_yPos = 0.0f;
    m_xAngle = 0.0f;
    m_yAngle = 0.0f;
}
复制代码
3,加入绘制代码:

复制代码
void COpenGLView::RenderScene ()
{
    glLoadIdentity();
    glTranslatef(m_xPos, m_yPos, -5.0f);
    glRotatef(m_xAngle, 1.0f,0.0f,0.0f);
    glRotatef(m_yAngle, 0.0f,1.0f,0.0f);

    glutWireCube(1.0f);
}
复制代码
4,为四个事件处理函数加入控制代码

复制代码
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);
}
复制代码


本文转自Phinecos(洞庭散人)博客园博客,原文链接:http://www.cnblogs.com/phinecos/archive/2008/11/05/1327443.html,如需转载请自行联系原作者
目录
相关文章
|
Android开发 异构计算
Android OpenGL ES(八)----纹理编程框架(二)
Android OpenGL ES(八)----纹理编程框架(二)
190 0
Android OpenGL ES(八)----纹理编程框架(二)
|
存储 Java API
Android OpenGL ES(八)----纹理编程框架(一)
Android OpenGL ES(八)----纹理编程框架(一)
318 0
Android OpenGL ES(八)----纹理编程框架(一)
|
Android开发
Android OpenGL ES(三)----编程框架(二)
Android OpenGL ES(三)----编程框架(二)
123 0
Android OpenGL ES(三)----编程框架(二)
|
Java API Android开发
Android OpenGL ES(三)----编程框架(一)
Android OpenGL ES(三)----编程框架(一)
128 0
|
iOS开发 异构计算
了解 OpenGL ES实现自定义编程粒子效果 思路
本案例旨在于了解OpenGL ES中自定义编程粒子效果的整体实现思路。
199 0
了解 OpenGL ES实现自定义编程粒子效果 思路