# HG changeset patch # User Sebastien Jodogne # Date 1621523130 -7200 # Node ID de7cea710008bd2a4c32bda2c8887fc440c02406 # Parent 5a872e69c74ff1ca15ed1d6c797dbe3df19b11bb recovery of old SdlSimpleViewer sample diff -r 5a872e69c74f -r de7cea710008 Applications/Samples/Sdl/SingleFrameViewer/SdlSimpleViewer.cpp --- a/Applications/Samples/Sdl/SingleFrameViewer/SdlSimpleViewer.cpp Thu May 20 14:48:51 2021 +0200 +++ b/Applications/Samples/Sdl/SingleFrameViewer/SdlSimpleViewer.cpp Thu May 20 17:05:30 2021 +0200 @@ -19,6 +19,11 @@ **/ + +#define SAMPLE_USE_OPENGL 1 +#define SAMPLE_USE_ANNOTATIONS_LAYER 1 + + #include "SdlSimpleViewerApplication.h" #include "../SdlHelpers.h" #include "../../Common/SampleHelpers.h" @@ -70,13 +75,21 @@ std::cout << desc << std::endl; std::cout << std::endl << "Keyboard shorcuts:" << std::endl +#if SAMPLE_USE_ANNOTATIONS_LAYER == 1 + << " a\tCreate angle annotations" << std::endl + << " c\tCreate circle annotations" << std::endl + << " d\tDelete mode for annotations" << std::endl + << " e\tEdit mode, don't create annotation (default)" << std::endl + << " l\tCreate line annotations" << std::endl +#else << " a\tEnable/disable the angle annotation tool" << std::endl + << " l\tEnable/disable the line annotation tool" << std::endl + << " r\tRedo the last edit to the annotation tools" << std::endl + << " u\tUndo the last edit to the annotation tools" << std::endl +#endif << " f\tToggle fullscreen display" << std::endl - << " l\tEnable/disable the line annotation tool" << std::endl << " q\tExit" << std::endl - << " r\tRedo the last edit to the annotation tools" << std::endl << " s\tFit the viewpoint to the image" << std::endl - << " u\tUndo the last edit to the annotation tools" << std::endl << std::endl << "Mouse buttons:" << std::endl << " left \tChange windowing, or edit annotation" << std::endl << " center\tMove the viewpoint, or edit annotation" << std::endl @@ -144,8 +157,7 @@ //Orthanc::Logging::EnableTraceLevel(true); { - -#if 0 +#if SAMPLE_USE_OPENGL == 1 boost::shared_ptr viewport = OrthancStone::SdlOpenGLViewport::Create("Stone of Orthanc", 800, 600); #else @@ -153,7 +165,9 @@ OrthancStone::SdlCairoViewport::Create("Stone of Orthanc", 800, 600); #endif +#if SAMPLE_USE_ANNOTATIONS_LAYER != 1 boost::shared_ptr undoStack(new OrthancStone::UndoStack); +#endif OrthancStone::GenericLoadersContext context(1, 4, 1); @@ -170,9 +184,16 @@ std::unique_ptr lock(viewport->Lock()); lock->GetCompositor().SetFont(0, font, 16, Orthanc::Encoding_Latin1); - //lock->GetController().SetUndoStack(undoStack); + +#if SAMPLE_USE_ANNOTATIONS_LAYER != 1 + lock->GetController().SetUndoStack(undoStack); +#endif } +#if SAMPLE_USE_ANNOTATIONS_LAYER == 1 + OrthancStone::AnnotationsSceneLayer annotations(10); + annotations.SetActiveTool(OrthancStone::AnnotationsSceneLayer::Tool_Edit); +#else ActiveTool activeTool = ActiveTool_None; boost::shared_ptr lineMeasureTool(OrthancStone::LineMeasureTool::Create(viewport)); @@ -182,17 +203,7 @@ boost::shared_ptr angleMeasureTool(OrthancStone::AngleMeasureTool::Create(viewport)); bool angleMeasureFirst = true; angleMeasureTool->Disable(); - - OrthancStone::AnnotationsSceneLayer annotations(10); - annotations.SetActiveTool(OrthancStone::AnnotationsSceneLayer::Tool_Angle); - - { - Json::Value v; - annotations.Serialize(v); - std::cout << v.toStyledString() << std::endl; - annotations.Clear(); - annotations.Unserialize(v); - } +#endif boost::shared_ptr application( SdlSimpleViewerApplication::Create(context, viewport)); @@ -254,6 +265,7 @@ stop = true; break; +#if SAMPLE_USE_ANNOTATIONS_LAYER != 1 case SDLK_u: { std::unique_ptr lock(viewport->Lock()); @@ -263,7 +275,9 @@ } break; } +#endif +#if SAMPLE_USE_ANNOTATIONS_LAYER != 1 case SDLK_r: { std::unique_ptr lock(viewport->Lock()); @@ -273,8 +287,30 @@ } break; } +#endif + +#if SAMPLE_USE_ANNOTATIONS_LAYER == 1 + case SDLK_c: + annotations.SetActiveTool(OrthancStone::AnnotationsSceneLayer::Tool_Circle); + break; +#endif + +#if SAMPLE_USE_ANNOTATIONS_LAYER == 1 + case SDLK_e: + annotations.SetActiveTool(OrthancStone::AnnotationsSceneLayer::Tool_Edit); + break; +#endif + +#if SAMPLE_USE_ANNOTATIONS_LAYER == 1 + case SDLK_d: + annotations.SetActiveTool(OrthancStone::AnnotationsSceneLayer::Tool_Erase); + break; +#endif case SDLK_l: +#if SAMPLE_USE_ANNOTATIONS_LAYER == 1 + annotations.SetActiveTool(OrthancStone::AnnotationsSceneLayer::Tool_Segment); +#else if (activeTool == ActiveTool_Line) { lineMeasureTool->Disable(); @@ -299,9 +335,13 @@ angleMeasureTool->Disable(); activeTool = ActiveTool_Line; } +#endif break; case SDLK_a: +#if SAMPLE_USE_ANNOTATIONS_LAYER == 1 + annotations.SetActiveTool(OrthancStone::AnnotationsSceneLayer::Tool_Angle); +#else if (activeTool == ActiveTool_Angle) { angleMeasureTool->Disable(); @@ -333,6 +373,7 @@ angleMeasureTool->Enable(); activeTool = ActiveTool_Angle; } +#endif break; default: @@ -355,12 +396,13 @@ case SDL_MOUSEBUTTONDOWN: { boost::shared_ptr t; - + +#if SAMPLE_USE_ANNOTATIONS_LAYER == 1 if (p.GetMouseButton() == OrthancStone::MouseButton_Left) { t.reset(annotations.CreateTracker(p.GetMainPosition(), lock->GetController().GetScene())); } - +#else if (t.get() == NULL) { switch (activeTool) @@ -380,6 +422,7 @@ throw Orthanc::OrthancException(Orthanc::ErrorCode_NotImplemented); } } +#endif if (t.get() != NULL) { @@ -396,6 +439,7 @@ } case SDL_MOUSEMOTION: +#if SAMPLE_USE_ANNOTATIONS_LAYER == 1 if (lock->GetController().HandleMouseMove(p)) { lock->Invalidate(); @@ -411,6 +455,13 @@ paint = true; } } +#else + if (lock->GetController().HandleMouseMove(p)) + { + lock->Invalidate(); + paint = true; + } +#endif break; case SDL_MOUSEBUTTONUP: @@ -427,10 +478,12 @@ if (paint) { +#if SAMPLE_USE_ANNOTATIONS_LAYER == 1 { std::unique_ptr lock(viewport->Lock()); annotations.Render(lock->GetController().GetScene()); } +#endif viewport->Paint(); }