| // This file is part of Eigen, a lightweight C++ template library | 
 | // for linear algebra. | 
 | // | 
 | // Copyright (C) 2008 Gael Guennebaud <gael.guennebaud@inria.fr> | 
 | // | 
 | // This Source Code Form is subject to the terms of the Mozilla | 
 | // Public License v. 2.0. If a copy of the MPL was not distributed | 
 | // with this file, You can obtain one at http://mozilla.org/MPL/2.0/. | 
 |  | 
 | #ifndef EIGEN_TRACKBALL_H | 
 | #define EIGEN_TRACKBALL_H | 
 |  | 
 | #include <Eigen/Geometry> | 
 |  | 
 | class Camera; | 
 |  | 
 | class Trackball { | 
 |  public: | 
 |   enum Mode { Around, Local }; | 
 |  | 
 |   Trackball() : mpCamera(0) {} | 
 |  | 
 |   void start(Mode m = Around) { | 
 |     mMode = m; | 
 |     mLastPointOk = false; | 
 |   } | 
 |  | 
 |   void setCamera(Camera* pCam) { mpCamera = pCam; } | 
 |  | 
 |   void track(const Eigen::Vector2i& newPoint2D); | 
 |  | 
 |  protected: | 
 |   bool mapToSphere(const Eigen::Vector2i& p2, Eigen::Vector3f& v3); | 
 |  | 
 |   Camera* mpCamera; | 
 |   Eigen::Vector3f mLastPoint3D; | 
 |   Mode mMode; | 
 |   bool mLastPointOk; | 
 | }; | 
 |  | 
 | #endif  // EIGEN_TRACKBALL_H |