Mercurial > hg > orthanc-stone
diff Framework/Scene2DViewport/MeasureCommands.cpp @ 1331:ab81ee8fce1f broker
- Viewport is not passed and stored as a shared_ptr instead
of raw reference.
- ViewportController can now be injected with an undo
stack (not a ctor param anymore, as a preparation for the
move of the undo stack to an interactor)
- Added (temp) flag to disable emscripten events registration
in the WebAssemblyViewport (because legacy client code
deals with them directly)
- Added emscripten_clear_timeout in ~WebGLViewportsRegistry
- Removed GenericToolbox::HoldingRef whose responsibility is
better served with proper callback un-registration.
author | Benjamin Golinvaux <bgo@osimis.io> |
---|---|
date | Mon, 30 Mar 2020 14:23:46 +0200 |
parents | a5326ce4f24b |
children |
line wrap: on
line diff
--- a/Framework/Scene2DViewport/MeasureCommands.cpp Mon Mar 30 08:47:30 2020 +0200 +++ b/Framework/Scene2DViewport/MeasureCommands.cpp Mon Mar 30 14:23:46 2020 +0200 @@ -29,7 +29,7 @@ { void CreateMeasureCommand::Undo() { - std::unique_ptr<OrthancStone::IViewport::ILock> lock(viewport_.Lock()); + std::unique_ptr<OrthancStone::IViewport::ILock> lock(viewport_->Lock()); // simply disable the measure tool upon undo GetMeasureTool()->Disable(); lock->GetController().RemoveMeasureTool(GetMeasureTool()); @@ -37,12 +37,12 @@ void CreateMeasureCommand::Redo() { - std::unique_ptr<OrthancStone::IViewport::ILock> lock(viewport_.Lock()); + std::unique_ptr<OrthancStone::IViewport::ILock> lock(viewport_->Lock()); GetMeasureTool()->Enable(); lock->GetController().AddMeasureTool(GetMeasureTool()); } - CreateMeasureCommand::CreateMeasureCommand(IViewport& viewport) + CreateMeasureCommand::CreateMeasureCommand(boost::shared_ptr<IViewport> viewport) : MeasureCommand(viewport) { @@ -56,7 +56,7 @@ void DeleteMeasureCommand::Redo() { - std::unique_ptr<OrthancStone::IViewport::ILock> lock(viewport_.Lock()); + std::unique_ptr<OrthancStone::IViewport::ILock> lock(viewport_->Lock()); // simply disable the measure tool upon undo GetMeasureTool()->Disable(); lock->GetController().RemoveMeasureTool(GetMeasureTool()); @@ -64,7 +64,7 @@ void DeleteMeasureCommand::Undo() { - std::unique_ptr<OrthancStone::IViewport::ILock> lock(viewport_.Lock()); + std::unique_ptr<OrthancStone::IViewport::ILock> lock(viewport_->Lock()); GetMeasureTool()->Enable(); lock->GetController().AddMeasureTool(GetMeasureTool()); } @@ -75,18 +75,18 @@ // we thus leave it as is } - DeleteMeasureCommand::DeleteMeasureCommand(boost::shared_ptr<MeasureTool> measureTool, IViewport& viewport) + DeleteMeasureCommand::DeleteMeasureCommand(boost::shared_ptr<MeasureTool> measureTool, boost::shared_ptr<IViewport> viewport) : MeasureCommand(viewport) , mementoOriginal_(measureTool->GetMemento()) , measureTool_(measureTool) , mementoModified_(measureTool->GetMemento()) { - std::unique_ptr<OrthancStone::IViewport::ILock> lock(viewport_.Lock()); + std::unique_ptr<OrthancStone::IViewport::ILock> lock(viewport_->Lock()); GetMeasureTool()->Disable(); lock->GetController().RemoveMeasureTool(GetMeasureTool()); } - EditMeasureCommand::EditMeasureCommand(boost::shared_ptr<MeasureTool> measureTool, IViewport& viewport) + EditMeasureCommand::EditMeasureCommand(boost::shared_ptr<MeasureTool> measureTool, boost::shared_ptr<IViewport> viewport) : MeasureCommand(viewport) , mementoOriginal_(measureTool->GetMemento()) , mementoModified_(measureTool->GetMemento())