Mercurial > hg > orthanc-stone
view Samples/Sdl/FusionMprSdl.h @ 1019:29f5f2031310
Added a way to specificy which structures are to be initially displayed (the
default being ALL structures displayed) + the loader maintains a list of
structure display state, that can be modified continuously + the cache now takes
the initial list of structure into account for computing the entry + added methods
to change the loaded structure visibility + disabled the alternate loaders
(DicomStructureSetLoader2 and friends) + disabled corresponding tests
author | Benjamin Golinvaux <bgo@osimis.io> |
---|---|
date | Fri, 27 Sep 2019 13:32:05 +0200 |
parents | eaaa9b574e05 |
children | 2d8ab34c8c91 |
line wrap: on
line source
/** * Stone of Orthanc * Copyright (C) 2012-2016 Sebastien Jodogne, Medical Physics * Department, University Hospital of Liege, Belgium * Copyright (C) 2017-2019 Osimis S.A., Belgium * * This program is free software: you can redistribute it and/or * modify it under the terms of the GNU Affero General Public License * as published by the Free Software Foundation, either version 3 of * the License, or (at your option) any later version. * * This program 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 * Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with this program. If not, see <http://www.gnu.org/licenses/>. **/ #include "../../Framework/Viewport/SdlViewport.h" #include "../../Framework/Messages/IObserver.h" #include "../../Framework/Messages/IMessageEmitter.h" #include "../../Framework/Oracle/OracleCommandExceptionMessage.h" #include "../../Framework/Scene2DViewport/ViewportController.h" #include "../../Framework/Volumes/DicomVolumeImage.h" #include "../../Framework/Oracle/ThreadedOracle.h" #include <boost/enable_shared_from_this.hpp> #include <boost/thread.hpp> #include <boost/noncopyable.hpp> #include <SDL.h> namespace OrthancStone { class OpenGLCompositor; class IVolumeSlicer; class ILayerStyleConfigurator; class DicomStructureSetLoader; class IOracle; class ThreadedOracle; class VolumeSceneLayerSource; class NativeFusionMprApplicationContext; class SdlOpenGLViewport; enum FusionMprGuiTool { FusionMprGuiTool_Rotate = 0, FusionMprGuiTool_Pan, FusionMprGuiTool_Zoom, FusionMprGuiTool_LineMeasure, FusionMprGuiTool_CircleMeasure, FusionMprGuiTool_AngleMeasure, FusionMprGuiTool_EllipseMeasure, FusionMprGuiTool_LAST }; const char* MeasureToolToString(size_t i); static const unsigned int FONT_SIZE_0 = 32; static const unsigned int FONT_SIZE_1 = 24; class Scene2D; class UndoStack; /** This application subclasses IMessageEmitter to use a mutex before forwarding Oracle messages (that can be sent from multiple threads) */ class FusionMprSdlApp : public IObserver , public boost::enable_shared_from_this<FusionMprSdlApp> , public IMessageEmitter { public: // 12 because. FusionMprSdlApp(MessageBroker& broker); void PrepareScene(); void Run(); void SetInfoDisplayMessage(std::string key, std::string value); void DisableTracker(); Scene2D& GetScene(); const Scene2D& GetScene() const; void HandleApplicationEvent(const SDL_Event& event); /** This method is called when the scene transform changes. It allows to recompute the visual elements whose content depend upon the scene transform */ void OnSceneTransformChanged( const ViewportController::SceneTransformChanged& message); virtual void EmitMessage(const IObserver& observer, const IMessage& message) ORTHANC_OVERRIDE { try { boost::unique_lock<boost::shared_mutex> lock(mutex_); oracleObservable_.EmitMessage(observer, message); } catch (Orthanc::OrthancException& e) { LOG(ERROR) << "Exception while emitting a message: " << e.What(); throw; } } private: #if 1 // if threaded (not wasm) MessageBroker& broker_; IObservable oracleObservable_; ThreadedOracle oracle_; boost::shared_mutex mutex_; // to serialize messages from the ThreadedOracle #endif void SelectNextTool(); /** This returns a random point in the canvas part of the scene, but in scene coordinates */ ScenePoint2D GetRandomPointInScene() const; boost::shared_ptr<IFlexiblePointerTracker> TrackerHitTest(const PointerEvent& e); boost::shared_ptr<IFlexiblePointerTracker> CreateSuitableTracker( const SDL_Event& event, const PointerEvent& e); void TakeScreenshot( const std::string& target, unsigned int canvasWidth, unsigned int canvasHeight); /** This adds the command at the top of the undo stack */ void Commit(boost::shared_ptr<TrackerCommand> cmd); void Undo(); void Redo(); // TODO private void Handle(const DicomVolumeImage::GeometryReadyMessage& message); void Handle(const OracleCommandExceptionMessage& message); void SetVolume1( int depth, const boost::shared_ptr<IVolumeSlicer>& volume, ILayerStyleConfigurator* style); void SetVolume2( int depth, const boost::shared_ptr<IVolumeSlicer>& volume, ILayerStyleConfigurator* style); void SetStructureSet( int depth, const boost::shared_ptr<DicomStructureSetLoader>& volume); private: void DisplayFloatingCtrlInfoText(const PointerEvent& e); void DisplayInfoText(); void HideInfoText(); private: CoordinateSystem3D plane_; boost::shared_ptr<VolumeSceneLayerSource> source1_, source2_, source3_; /** WARNING: the measuring tools do store a reference to the scene, and it paramount that the scene gets destroyed AFTER the measurement tools. */ boost::shared_ptr<ViewportController> controller_; std::map<std::string, std::string> infoTextMap_; boost::shared_ptr<IFlexiblePointerTracker> activeTracker_; //static const int LAYER_POSITION = 150; int TEXTURE_2x2_1_ZINDEX; int TEXTURE_1x1_ZINDEX; int TEXTURE_2x2_2_ZINDEX; int LINESET_1_ZINDEX; int LINESET_2_ZINDEX; int FLOATING_INFOTEXT_LAYER_ZINDEX; int FIXED_INFOTEXT_LAYER_ZINDEX; FusionMprGuiTool currentTool_; boost::shared_ptr<UndoStack> undoStack_; SdlOpenGLViewport viewport_; }; }