]> Creatis software - clitk.git/blobdiff - tools/clitkConeBeamProjectImageGenericFilter.cxx
Romulo:
[clitk.git] / tools / clitkConeBeamProjectImageGenericFilter.cxx
index 248693876b408450c29fcf411b8b7fb6728b650d..ff775d049b21e72155bd2d4d7b36222b7801132c 100755 (executable)
@@ -131,16 +131,18 @@ namespace clitk
       }
     filter->SetEdgePaddingValue(static_cast<OutputPixelType>(m_ArgsInfo.pad_arg));
 
-    // Panel position (hard coded values for the elekta synergy)
-    // Two be more precise, one should read the specific values for each angle in Frame.dbf
     DD(m_ArgsInfo.panel_position_arg);
-    if (strcmp(m_ArgsInfo.panel_position_arg,"small") ==0)
-      filter->SetPanelShift(0.);
-    else if (strcmp(m_ArgsInfo.panel_position_arg,"medium") ==0)
-      filter->SetPanelShift(114.84);
-    else if (strcmp(m_ArgsInfo.panel_position_arg,"large") ==0)
-      filter->SetPanelShift(190.);
-    else assert(false); //Unsupported panel position
+    if (m_ArgsInfo.panel_shift_given) // one should read the specific values for each angle in Frame.dbf
+      filter->SetPanelShift(m_ArgsInfo.panel_shift_arg);
+    else { // approximate panel positions hard coded values for the elekta synergy
+      if (strcmp(m_ArgsInfo.panel_position_arg,"small") ==0)
+        filter->SetPanelShift(0.);
+      else if (strcmp(m_ArgsInfo.panel_position_arg,"medium") ==0)
+        filter->SetPanelShift(114.84);
+      else if (strcmp(m_ArgsInfo.panel_position_arg,"large") ==0)
+        filter->SetPanelShift(190.);
+      else assert(false); //Unsupported panel position
+    }
     // Output image info
     if (m_ArgsInfo.like_given)
       {