You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
378 lines
9.9 KiB
378 lines
9.9 KiB
/*=========================================================================
|
|
|
|
Program: Visualization Toolkit
|
|
Module: $RCSfile: vtkInteractorStyleJoystickCamera.cxx,v $
|
|
|
|
Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
|
|
All rights reserved.
|
|
See Copyright.txt or http://www.kitware.com/Copyright.htm for details.
|
|
|
|
This software is distributed WITHOUT ANY WARRANTY; without even
|
|
the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
|
|
PURPOSE. See the above copyright notice for more information.
|
|
|
|
=========================================================================*/
|
|
#include "vtkInteractorStyleJoystickCamera.h"
|
|
|
|
#include "vtkCamera.h"
|
|
#include "vtkCommand.h"
|
|
#include "vtkMath.h"
|
|
#include "vtkObjectFactory.h"
|
|
#include "vtkRenderer.h"
|
|
#include "vtkRenderWindowInteractor.h"
|
|
|
|
vtkCxxRevisionMacro(vtkInteractorStyleJoystickCamera, "$Revision: 1.30 $");
|
|
vtkStandardNewMacro(vtkInteractorStyleJoystickCamera);
|
|
|
|
//----------------------------------------------------------------------------
|
|
vtkInteractorStyleJoystickCamera::vtkInteractorStyleJoystickCamera()
|
|
{
|
|
// Use timers to handle continous interaction
|
|
|
|
this->UseTimers = 1;
|
|
}
|
|
|
|
//----------------------------------------------------------------------------
|
|
vtkInteractorStyleJoystickCamera::~vtkInteractorStyleJoystickCamera()
|
|
{
|
|
}
|
|
|
|
//----------------------------------------------------------------------------
|
|
// Mouse events
|
|
//----------------------------------------------------------------------------
|
|
void vtkInteractorStyleJoystickCamera::OnMouseMove()
|
|
{
|
|
int x = this->Interactor->GetEventPosition()[0];
|
|
int y = this->Interactor->GetEventPosition()[1];
|
|
|
|
switch (this->State)
|
|
{
|
|
case VTKIS_ROTATE:
|
|
case VTKIS_PAN:
|
|
case VTKIS_DOLLY:
|
|
case VTKIS_SPIN:
|
|
this->FindPokedRenderer(x, y);
|
|
this->InvokeEvent(vtkCommand::InteractionEvent, NULL);
|
|
break;
|
|
}
|
|
}
|
|
|
|
//----------------------------------------------------------------------------
|
|
void vtkInteractorStyleJoystickCamera::OnLeftButtonDown()
|
|
{
|
|
this->FindPokedRenderer(this->Interactor->GetEventPosition()[0],
|
|
this->Interactor->GetEventPosition()[1]);
|
|
if (this->CurrentRenderer == NULL)
|
|
{
|
|
return;
|
|
}
|
|
|
|
if (this->Interactor->GetShiftKey())
|
|
{
|
|
if (this->Interactor->GetControlKey())
|
|
{
|
|
this->StartDolly();
|
|
}
|
|
else
|
|
{
|
|
this->StartPan();
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (this->Interactor->GetControlKey())
|
|
{
|
|
this->StartSpin();
|
|
}
|
|
else
|
|
{
|
|
this->StartRotate();
|
|
}
|
|
}
|
|
}
|
|
|
|
//----------------------------------------------------------------------------
|
|
void vtkInteractorStyleJoystickCamera::OnLeftButtonUp()
|
|
{
|
|
switch (this->State)
|
|
{
|
|
case VTKIS_DOLLY:
|
|
this->EndDolly();
|
|
break;
|
|
|
|
case VTKIS_PAN:
|
|
this->EndPan();
|
|
break;
|
|
|
|
case VTKIS_SPIN:
|
|
this->EndSpin();
|
|
break;
|
|
|
|
case VTKIS_ROTATE:
|
|
this->EndRotate();
|
|
break;
|
|
}
|
|
}
|
|
|
|
//----------------------------------------------------------------------------
|
|
void vtkInteractorStyleJoystickCamera::OnMiddleButtonDown()
|
|
{
|
|
this->FindPokedRenderer(this->Interactor->GetEventPosition()[0],
|
|
this->Interactor->GetEventPosition()[1]);
|
|
if (this->CurrentRenderer == NULL)
|
|
{
|
|
return;
|
|
}
|
|
|
|
this->StartPan();
|
|
}
|
|
|
|
//----------------------------------------------------------------------------
|
|
void vtkInteractorStyleJoystickCamera::OnMiddleButtonUp()
|
|
{
|
|
switch (this->State)
|
|
{
|
|
case VTKIS_PAN:
|
|
this->EndPan();
|
|
break;
|
|
}
|
|
}
|
|
|
|
//----------------------------------------------------------------------------
|
|
void vtkInteractorStyleJoystickCamera::OnRightButtonDown()
|
|
{
|
|
this->FindPokedRenderer(this->Interactor->GetEventPosition()[0],
|
|
this->Interactor->GetEventPosition()[1]);
|
|
if (this->CurrentRenderer == NULL)
|
|
{
|
|
return;
|
|
}
|
|
|
|
this->StartDolly();
|
|
}
|
|
|
|
//----------------------------------------------------------------------------
|
|
void vtkInteractorStyleJoystickCamera::OnRightButtonUp()
|
|
{
|
|
switch (this->State)
|
|
{
|
|
case VTKIS_DOLLY:
|
|
this->EndDolly();
|
|
break;
|
|
}
|
|
}
|
|
|
|
//----------------------------------------------------------------------------
|
|
void vtkInteractorStyleJoystickCamera::OnMouseWheelForward()
|
|
{
|
|
this->FindPokedRenderer(this->Interactor->GetEventPosition()[0],
|
|
this->Interactor->GetEventPosition()[1]);
|
|
if (this->CurrentRenderer == NULL)
|
|
{
|
|
return;
|
|
}
|
|
|
|
this->StartDolly();
|
|
double factor = 10.0 * 0.2 * this->MouseWheelMotionFactor;
|
|
this->Dolly(pow((double)1.1, factor));
|
|
this->EndDolly();
|
|
}
|
|
|
|
//----------------------------------------------------------------------------
|
|
void vtkInteractorStyleJoystickCamera::OnMouseWheelBackward()
|
|
{
|
|
this->FindPokedRenderer(this->Interactor->GetEventPosition()[0],
|
|
this->Interactor->GetEventPosition()[1]);
|
|
if (this->CurrentRenderer == NULL)
|
|
{
|
|
return;
|
|
}
|
|
|
|
this->StartDolly();
|
|
double factor = 10.0 * -0.2 * this->MouseWheelMotionFactor;
|
|
this->Dolly(pow((double)1.1, factor));
|
|
this->EndDolly();
|
|
}
|
|
|
|
//----------------------------------------------------------------------------
|
|
void vtkInteractorStyleJoystickCamera::Rotate()
|
|
{
|
|
if (this->CurrentRenderer == NULL)
|
|
{
|
|
return;
|
|
}
|
|
|
|
vtkRenderWindowInteractor *rwi = this->Interactor;
|
|
|
|
double *center = this->CurrentRenderer->GetCenter();
|
|
|
|
double dx = (double)rwi->GetEventPosition()[0] - center[0];
|
|
double dy = (double)rwi->GetEventPosition()[1] - center[1];
|
|
|
|
double *vp = this->CurrentRenderer->GetViewport();
|
|
int *size = rwi->GetSize();
|
|
|
|
double delta_elevation = -20.0/((vp[3] - vp[1])*size[1]);
|
|
double delta_azimuth = -20.0/((vp[2] - vp[0])*size[0]);
|
|
|
|
double rxf = (double)dx * delta_azimuth;
|
|
double ryf = (double)dy * delta_elevation;
|
|
|
|
vtkCamera* camera = this->CurrentRenderer->GetActiveCamera();
|
|
camera->Azimuth(rxf);
|
|
camera->Elevation(ryf);
|
|
camera->OrthogonalizeViewUp();
|
|
|
|
if (this->AutoAdjustCameraClippingRange)
|
|
{
|
|
this->CurrentRenderer->ResetCameraClippingRange();
|
|
}
|
|
|
|
if (rwi->GetLightFollowCamera())
|
|
{
|
|
this->CurrentRenderer->UpdateLightsGeometryToFollowCamera();
|
|
}
|
|
|
|
rwi->Render();
|
|
}
|
|
|
|
//----------------------------------------------------------------------------
|
|
void vtkInteractorStyleJoystickCamera::Spin()
|
|
{
|
|
if (this->CurrentRenderer == NULL)
|
|
{
|
|
return;
|
|
}
|
|
|
|
vtkRenderWindowInteractor *rwi = this->Interactor;
|
|
|
|
double *center = this->CurrentRenderer->GetCenter();
|
|
|
|
// Spin is based on y value
|
|
|
|
double yf = ((double)rwi->GetEventPosition()[1] - (double)center[1])
|
|
/ (double)(center[1]);
|
|
|
|
if (yf > 1)
|
|
{
|
|
yf = 1;
|
|
}
|
|
else if (yf < -1)
|
|
{
|
|
yf = -1;
|
|
}
|
|
|
|
double newAngle = asin(yf) * vtkMath::RadiansToDegrees();
|
|
|
|
vtkCamera* camera = this->CurrentRenderer->GetActiveCamera();
|
|
camera->Roll(newAngle);
|
|
camera->OrthogonalizeViewUp();
|
|
|
|
rwi->Render();
|
|
}
|
|
|
|
//----------------------------------------------------------------------------
|
|
void vtkInteractorStyleJoystickCamera::Pan()
|
|
{
|
|
if (this->CurrentRenderer == NULL)
|
|
{
|
|
return;
|
|
}
|
|
|
|
vtkRenderWindowInteractor *rwi = this->Interactor;
|
|
|
|
double ViewFocus[4];
|
|
double NewPickPoint[4];
|
|
|
|
// Calculate the focal depth since we'll be using it a lot
|
|
|
|
vtkCamera* camera = this->CurrentRenderer->GetActiveCamera();
|
|
camera->GetFocalPoint(ViewFocus);
|
|
this->ComputeWorldToDisplay(ViewFocus[0], ViewFocus[1], ViewFocus[2],
|
|
ViewFocus);
|
|
double focalDepth = ViewFocus[2];
|
|
|
|
this->ComputeDisplayToWorld((double)rwi->GetEventPosition()[0],
|
|
(double)rwi->GetEventPosition()[1],
|
|
focalDepth,
|
|
NewPickPoint);
|
|
|
|
// Get the current focal point and position
|
|
|
|
camera->GetFocalPoint(ViewFocus);
|
|
double *ViewPoint = camera->GetPosition();
|
|
|
|
// Compute a translation vector, moving everything 1/10
|
|
// the distance to the cursor. (Arbitrary scale factor)
|
|
|
|
double MotionVector[3];
|
|
MotionVector[0] = 0.1 * (ViewFocus[0] - NewPickPoint[0]);
|
|
MotionVector[1] = 0.1 * (ViewFocus[1] - NewPickPoint[1]);
|
|
MotionVector[2] = 0.1 * (ViewFocus[2] - NewPickPoint[2]);
|
|
|
|
camera->SetFocalPoint(MotionVector[0] + ViewFocus[0],
|
|
MotionVector[1] + ViewFocus[1],
|
|
MotionVector[2] + ViewFocus[2]);
|
|
|
|
camera->SetPosition(MotionVector[0] + ViewPoint[0],
|
|
MotionVector[1] + ViewPoint[1],
|
|
MotionVector[2] + ViewPoint[2]);
|
|
|
|
if (rwi->GetLightFollowCamera())
|
|
{
|
|
this->CurrentRenderer->UpdateLightsGeometryToFollowCamera();
|
|
}
|
|
|
|
rwi->Render();
|
|
}
|
|
|
|
//----------------------------------------------------------------------------
|
|
void vtkInteractorStyleJoystickCamera::Dolly()
|
|
{
|
|
if (this->CurrentRenderer == NULL)
|
|
{
|
|
return;
|
|
}
|
|
|
|
vtkRenderWindowInteractor *rwi = this->Interactor;
|
|
double *center = this->CurrentRenderer->GetCenter();
|
|
double dy = (double)rwi->GetEventPosition()[1] - (double)center[1];
|
|
double dyf = 0.5 * dy / (double)center[1];
|
|
this->Dolly(pow((double)1.1, dyf));
|
|
}
|
|
|
|
//----------------------------------------------------------------------------
|
|
void vtkInteractorStyleJoystickCamera::Dolly(double factor)
|
|
{
|
|
if (this->CurrentRenderer == NULL)
|
|
{
|
|
return;
|
|
}
|
|
|
|
vtkCamera* camera = this->CurrentRenderer->GetActiveCamera();
|
|
if (camera->GetParallelProjection())
|
|
{
|
|
camera->SetParallelScale(camera->GetParallelScale() / factor);
|
|
}
|
|
else
|
|
{
|
|
camera->Dolly(factor);
|
|
if (this->AutoAdjustCameraClippingRange)
|
|
{
|
|
this->CurrentRenderer->ResetCameraClippingRange();
|
|
}
|
|
}
|
|
|
|
if (this->Interactor->GetLightFollowCamera())
|
|
{
|
|
this->CurrentRenderer->UpdateLightsGeometryToFollowCamera();
|
|
}
|
|
|
|
this->Interactor->Render();
|
|
}
|
|
|
|
//----------------------------------------------------------------------------
|
|
void vtkInteractorStyleJoystickCamera::PrintSelf(ostream& os, vtkIndent indent)
|
|
{
|
|
this->Superclass::PrintSelf(os,indent);
|
|
}
|
|
|