//################################################################################################## // // Custom Visualization Core library // Copyright (C) 2015 Ceetron Solutions AS // // This library may be used under the terms of either the GNU General Public License or // the GNU Lesser General Public License as follows: // // GNU General Public License Usage // This library 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. // // This library 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 at <> // for more details. // // GNU Lesser General Public License Usage // This library is free software; you can redistribute it and/or modify // it under the terms of the GNU Lesser General Public License as published by // the Free Software Foundation; either version 2.1 of the License, or // (at your option) any later version. // // This library 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 Lesser General Public License at <> // for more details. // //################################################################################################## #pragma once #include "cafNavigationPolicy.h" #include namespace cvf { class ManipulatorTrackball; class Ray; } class QMouseEvent; namespace caf { class RotationSensitivityCalculator { public: RotationSensitivityCalculator() : m_lastPosX(0) , m_lastPosY(0) , m_lastMouseVelocityLenght(200) , m_isEnabled(false) , m_fixedSensitivity(std::numeric_limits::infinity()) {} void enableAdaptiveRotationSensitivity(bool enable) { m_isEnabled = enable; m_fixedSensitivity = std::numeric_limits::infinity(); } void enableFixedSensitivity(double senstivity) { m_isEnabled = true; m_fixedSensitivity = senstivity;} void init(QMouseEvent* eventAtRotationStart); double calculateSensitivity(QMouseEvent* eventWhenRotating); private: bool m_isEnabled; int m_lastPosX; /// Previous mouse position int m_lastPosY; unsigned long m_lastTime; double m_lastMouseVelocityLenght; double m_fixedSensitivity; }; } // End namespace caf namespace caf { //-------------------------------------------------------------------------------------------------- /// This class is a work in progress to consolidate the different navigation policies that are similar. /// It is not yet finished. We need to extract the Pan, Rotation, ... etc. codes from the /// special input event handlers and invoke those general methods from the event handlers instead. /// Some of the protected variables in this class is used by the /// derived classes, and should rather be used from the general methods in this class and thus be private /// //-------------------------------------------------------------------------------------------------- class TrackBallBasedNavigation: public NavigationPolicy { public: TrackBallBasedNavigation(); ~TrackBallBasedNavigation() override; void enableEventEating(bool enable) { m_consumeEvents = enable; } void enableRotation(bool enable) { m_isRotationEnabled = enable; } void enableAdaptiveRotationSensitivity(bool enable) { m_roationSensitivityCalculator.enableAdaptiveRotationSensitivity(enable); } void enableFixedSensitivity(double senstivity) { m_roationSensitivityCalculator.enableFixedSensitivity(senstivity); } protected: // General navigation policy overrides void init() override; void setView( const cvf::Vec3d& alongDirection, const cvf::Vec3d& upDirection ) override; cvf::Vec3d pointOfInterest() override; void setPointOfInterest(cvf::Vec3d poi) override; void pickAndSetPointOfInterest(int winPosX, int winPosY); void updatePointOfInterestDuringZoomIfNecessary(int winPosX, int winPosY); void forcePointOfInterestUpdateDuringNextWheelZoom(); // Track ball navigation specific void initializeRotationCenter(); cvf::ref m_trackball; bool m_isRotCenterInitialized; cvf::Vec3d m_pointOfInterest; RotationSensitivityCalculator m_roationSensitivityCalculator; bool m_isNavigating; bool m_hasMovedMouseDuringNavigation; void cvfEventPos(int qtX, int qtY, int* x, int* y); // Zooming towards cursor cvf::ref createZoomRay(int cvfXPos, int cvfYPos); void zoomAlongRay( cvf::Ray* ray, int delta ); bool m_isZooming; cvf::ref m_zoomRay; int m_lastPosX; /// Previous mouse position int m_lastPosY; bool isSupposedToConsumeEvents() { return m_consumeEvents; } bool isRotationEnabled() { return m_isRotationEnabled; } private: void updateWheelZoomPosition(int winPosX, int winPosY); bool shouldRaytraceForNewPoiDuringWheelZoom(int winPosX, int winPosY) const; private: bool m_consumeEvents; bool m_isRotationEnabled; int m_lastWheelZoomPosX; int m_lastWheelZoomPosY; }; } // End namespace caf