dhewm3/neo/tools/radiant/RotateDlg.cpp

138 lines
3.8 KiB
C++
Raw Normal View History

2011-11-22 21:28:15 +00:00
/*
===========================================================================
Doom 3 GPL Source Code
Copyright (C) 1999-2011 id Software LLC, a ZeniMax Media company.
2011-11-22 21:28:15 +00:00
2011-12-06 16:14:59 +00:00
This file is part of the Doom 3 GPL Source Code ("Doom 3 Source Code").
2011-11-22 21:28:15 +00:00
Doom 3 Source Code is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
Doom 3 Source Code is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with Doom 3 Source Code. If not, see <http://www.gnu.org/licenses/>.
In addition, the Doom 3 Source Code is also subject to certain additional terms. You should have received a copy of these additional terms immediately following the terms and conditions of the GNU General Public License which accompanied the Doom 3 Source Code. If not, please request a copy in writing from id Software at the address below.
If you have questions concerning this license or the applicable additional terms, you may contact in writing id Software LLC, c/o ZeniMax Media Inc., Suite 120, Rockville, Maryland 20850 USA.
===========================================================================
*/
#include "../../idlib/precompiled.h"
#pragma hdrstop
#include "qe3.h"
#include "Radiant.h"
#include "RotateDlg.h"
#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif
/////////////////////////////////////////////////////////////////////////////
// CRotateDlg dialog
CRotateDlg::CRotateDlg(CWnd* pParent /*=NULL*/)
: CDialog(CRotateDlg::IDD, pParent)
{
//{{AFX_DATA_INIT(CRotateDlg)
m_strX = _T("");
m_strY = _T("");
m_strZ = _T("");
//}}AFX_DATA_INIT
}
void CRotateDlg::DoDataExchange(CDataExchange* pDX)
{
CDialog::DoDataExchange(pDX);
//{{AFX_DATA_MAP(CRotateDlg)
DDX_Control(pDX, IDC_SPIN3, m_wndSpin3);
DDX_Control(pDX, IDC_SPIN2, m_wndSpin2);
DDX_Control(pDX, IDC_SPIN1, m_wndSpin1);
DDX_Text(pDX, IDC_ROTX, m_strX);
DDX_Text(pDX, IDC_ROTY, m_strY);
DDX_Text(pDX, IDC_ROTZ, m_strZ);
//}}AFX_DATA_MAP
}
BEGIN_MESSAGE_MAP(CRotateDlg, CDialog)
//{{AFX_MSG_MAP(CRotateDlg)
ON_BN_CLICKED(IDC_APPLY, OnApply)
ON_NOTIFY(UDN_DELTAPOS, IDC_SPIN1, OnDeltaposSpin1)
ON_NOTIFY(UDN_DELTAPOS, IDC_SPIN2, OnDeltaposSpin2)
ON_NOTIFY(UDN_DELTAPOS, IDC_SPIN3, OnDeltaposSpin3)
//}}AFX_MSG_MAP
END_MESSAGE_MAP()
/////////////////////////////////////////////////////////////////////////////
// CRotateDlg message handlers
void CRotateDlg::OnOK()
2011-11-22 21:28:15 +00:00
{
OnApply();
CDialog::OnOK();
}
void CRotateDlg::OnApply()
2011-11-22 21:28:15 +00:00
{
UpdateData(TRUE);
float f = atof(m_strX);
if (f != 0.0)
Select_RotateAxis(0,f);
2011-11-22 21:28:15 +00:00
f = atof(m_strY);
if (f != 0.0)
Select_RotateAxis(1,f);
2011-11-22 21:28:15 +00:00
f = atof(m_strZ);
if (f != 0.0)
Select_RotateAxis(2,f);
2011-11-22 21:28:15 +00:00
}
BOOL CRotateDlg::OnInitDialog()
2011-11-22 21:28:15 +00:00
{
CDialog::OnInitDialog();
m_wndSpin1.SetRange(0, 359);
m_wndSpin2.SetRange(0, 359);
m_wndSpin3.SetRange(0, 359);
return TRUE; // return TRUE unless you set the focus to a control
// EXCEPTION: OCX Property Pages should return FALSE
2011-11-22 21:28:15 +00:00
}
void CRotateDlg::OnDeltaposSpin1(NMHDR* pNMHDR, LRESULT* pResult)
2011-11-22 21:28:15 +00:00
{
NM_UPDOWN* pNMUpDown = (NM_UPDOWN*)pNMHDR;
Select_RotateAxis(0, pNMUpDown->iDelta);
*pResult = 0;
}
void CRotateDlg::OnDeltaposSpin2(NMHDR* pNMHDR, LRESULT* pResult)
2011-11-22 21:28:15 +00:00
{
NM_UPDOWN* pNMUpDown = (NM_UPDOWN*)pNMHDR;
Select_RotateAxis(1, pNMUpDown->iDelta);
*pResult = 0;
}
void CRotateDlg::OnDeltaposSpin3(NMHDR* pNMHDR, LRESULT* pResult)
2011-11-22 21:28:15 +00:00
{
NM_UPDOWN* pNMUpDown = (NM_UPDOWN*)pNMHDR;
Select_RotateAxis(2, pNMUpDown->iDelta);
*pResult = 0;
}
void CRotateDlg::ApplyNoPaint()
{
}