diff --git a/Modules/Wrappers/ApplicationEngine/include/otbWrapperApplication.h b/Modules/Wrappers/ApplicationEngine/include/otbWrapperApplication.h index 9c83a78636b2390122104cb841870a8b87492c66..955a76b4359918001c2a1a4fa58bd68147a37c71 100644 --- a/Modules/Wrappers/ApplicationEngine/include/otbWrapperApplication.h +++ b/Modules/Wrappers/ApplicationEngine/include/otbWrapperApplication.h @@ -247,6 +247,20 @@ public: */ void SetDefaultParameterFloat(std::string parameter, float value); + /** Set a default pixel type for an output image parameter + * + * \param[in] parameter Name of the output image parameter + * \param[in] type Default pixel type + */ + void SetDefaultOutputPixelType(std::string parameter, ImagePixelType type); + + /** Set a default complex pixel type for an output complex image parameter + * + * \param[in] parameter Name of the output complex image parameter + * \param[in] type Default complex pixel type + */ + void SetDefaultOutputComplexPixelType(std::string parameter, ComplexImagePixelType type); + /* Set a minimum int value, must used in the * DoInit when setting a value by default * for the parameter diff --git a/Modules/Wrappers/ApplicationEngine/include/otbWrapperComplexOutputImageParameter.h b/Modules/Wrappers/ApplicationEngine/include/otbWrapperComplexOutputImageParameter.h index 6500d54621d307f5f9a18db2d7e5e58d5617a413..5edf833fba0223b968eb6e8170199453c066996b 100644 --- a/Modules/Wrappers/ApplicationEngine/include/otbWrapperComplexOutputImageParameter.h +++ b/Modules/Wrappers/ApplicationEngine/include/otbWrapperComplexOutputImageParameter.h @@ -61,14 +61,27 @@ public: /** Return any value */ ImageBaseType* GetValue( void ); - /** Set/Get PixelType to be used when saving */ + /** Set/Get m_ComplexPixelType to be used when saving */ itkSetMacro(ComplexPixelType, ComplexImagePixelType); itkGetMacro(ComplexPixelType, ComplexImagePixelType); + /** Set/Get m_DefaultComplexPixelType*/ + itkSetMacro(DefaultComplexPixelType, ComplexImagePixelType); + itkGetMacro(DefaultComplexPixelType, ComplexImagePixelType); + /** Set/Get available RAM value */ itkSetMacro(RAMValue, unsigned int); itkGetMacro(RAMValue, unsigned int); + /** Implement the reset method (replace pixel type by default type) */ + virtual void Reset() + { + m_ComplexPixelType = m_DefaultComplexPixelType; + } + + /** Static method to convert pixel type into string */ + static std::string ConvertPixelTypeToString(ComplexImagePixelType type); + /** Return true if a filename is set */ bool HasValue() const; @@ -106,7 +119,7 @@ protected: ImageBaseType::Pointer m_Image; std::string m_FileName; ComplexImagePixelType m_ComplexPixelType; - + ComplexImagePixelType m_DefaultComplexPixelType; typedef otb::ImageFileWriter<ComplexFloatImageType> ComplexFloatWriterType; typedef otb::ImageFileWriter<ComplexDoubleImageType> ComplexDoubleWriterType; diff --git a/Modules/Wrappers/ApplicationEngine/include/otbWrapperOutputImageParameter.h b/Modules/Wrappers/ApplicationEngine/include/otbWrapperOutputImageParameter.h index a8dc212a7c314f05c640be02591a015b4b0eff45..3313e5a8d201cc230bc33d2b11fd533d9a0f8f32 100644 --- a/Modules/Wrappers/ApplicationEngine/include/otbWrapperOutputImageParameter.h +++ b/Modules/Wrappers/ApplicationEngine/include/otbWrapperOutputImageParameter.h @@ -66,10 +66,23 @@ public: itkSetMacro(PixelType, ImagePixelType); itkGetMacro(PixelType, ImagePixelType); + /** Set/Get DefaultPixelType */ + itkSetMacro(DefaultPixelType, ImagePixelType); + itkGetMacro(DefaultPixelType, ImagePixelType); + /** Set/Get available RAM value */ itkSetMacro(RAMValue, unsigned int); itkGetMacro(RAMValue, unsigned int); + /** Implement the reset method (replace pixel type by default type) */ + virtual void Reset() + { + m_PixelType = m_DefaultPixelType; + } + + /** Static method to convert pixel type into string */ + static std::string ConvertPixelTypeToString(ImagePixelType type); + /** Return true if a filename is set */ bool HasValue() const; @@ -113,6 +126,7 @@ protected: ImageBaseType::Pointer m_Image; std::string m_FileName; ImagePixelType m_PixelType; + ImagePixelType m_DefaultPixelType; typedef otb::ImageFileWriter<UInt8ImageType> UInt8WriterType; typedef otb::ImageFileWriter<Int16ImageType> Int16WriterType; diff --git a/Modules/Wrappers/ApplicationEngine/src/otbWrapperApplication.cxx b/Modules/Wrappers/ApplicationEngine/src/otbWrapperApplication.cxx index 8176e2f7ff99e11544d58e04538a2ecd1ff6a6f0..2612a7cb97f475038c835f2b678e4fcefe6508b0 100644 --- a/Modules/Wrappers/ApplicationEngine/src/otbWrapperApplication.cxx +++ b/Modules/Wrappers/ApplicationEngine/src/otbWrapperApplication.cxx @@ -657,6 +657,29 @@ void Application::SetDefaultParameterFloat(std::string parameter, float value) } } +void Application::SetDefaultOutputPixelType(std::string parameter, ImagePixelType type) +{ + Parameter* param = GetParameterByKey(parameter); + OutputImageParameter* paramDown = dynamic_cast<OutputImageParameter*>(param); + if (paramDown) + { + paramDown->SetDefaultPixelType(type); + paramDown->SetPixelType(type); + } +} + +void +Application::SetDefaultOutputComplexPixelType(std::string parameter, ComplexImagePixelType type) +{ + Parameter* param = GetParameterByKey(parameter); + ComplexOutputImageParameter* paramDown = dynamic_cast<ComplexOutputImageParameter*>(param); + if (paramDown) + { + paramDown->SetDefaultComplexPixelType(type); + paramDown->SetComplexPixelType(type); + } +} + void Application::SetMinimumParameterIntValue(std::string parameter, int value) { Parameter* param = GetParameterByKey(parameter); diff --git a/Modules/Wrappers/ApplicationEngine/src/otbWrapperComplexOutputImageParameter.cxx b/Modules/Wrappers/ApplicationEngine/src/otbWrapperComplexOutputImageParameter.cxx index e87df1353be23dbf39cf9aef5df092132b84f94c..d4f157e02eb55f5f230e8edfe2bd622ae5801937 100644 --- a/Modules/Wrappers/ApplicationEngine/src/otbWrapperComplexOutputImageParameter.cxx +++ b/Modules/Wrappers/ApplicationEngine/src/otbWrapperComplexOutputImageParameter.cxx @@ -26,7 +26,9 @@ namespace Wrapper { ComplexOutputImageParameter::ComplexOutputImageParameter() - : m_ComplexPixelType(ComplexImagePixelType_float), m_RAMValue(0) + : m_ComplexPixelType(ComplexImagePixelType_float), + m_DefaultComplexPixelType(ComplexImagePixelType_float), + m_RAMValue(0) { this->SetName("Complex Output Image"); this->SetKey("cout"); @@ -36,6 +38,26 @@ ComplexOutputImageParameter::~ComplexOutputImageParameter() { } +std::string +ComplexOutputImageParameter::ConvertPixelTypeToString(ComplexImagePixelType type) +{ + std::string ret; + switch(type) + { + case ComplexImagePixelType_float: + { + ret = "cfloat"; + break; + } + case ComplexImagePixelType_double: + { + ret = "cdouble"; + break; + } + } + return ret; +} + void ComplexOutputImageParameter::InitializeWriters() { m_ComplexFloatWriter = ComplexFloatWriterType::New(); diff --git a/Modules/Wrappers/ApplicationEngine/src/otbWrapperOutputImageParameter.cxx b/Modules/Wrappers/ApplicationEngine/src/otbWrapperOutputImageParameter.cxx index 47498fa83474a3d4095ba163854c517c5c3ae17e..ec02594f477975de87349a3276a0e9c162e40d72 100644 --- a/Modules/Wrappers/ApplicationEngine/src/otbWrapperOutputImageParameter.cxx +++ b/Modules/Wrappers/ApplicationEngine/src/otbWrapperOutputImageParameter.cxx @@ -25,7 +25,9 @@ namespace Wrapper { OutputImageParameter::OutputImageParameter() - : m_PixelType(ImagePixelType_float), m_RAMValue(0) + : m_PixelType(ImagePixelType_float), + m_DefaultPixelType(ImagePixelType_float), + m_RAMValue(0) { this->SetName("Output Image"); this->SetKey("out"); @@ -36,6 +38,50 @@ OutputImageParameter::~OutputImageParameter() { } +std::string OutputImageParameter::ConvertPixelTypeToString(ImagePixelType type) +{ + std::string ret; + switch(type) + { + case ImagePixelType_uint8: + { + ret = "uint8"; + break; + } + case ImagePixelType_int16: + { + ret = "int16"; + break; + } + case ImagePixelType_uint16: + { + ret = "uint16"; + break; + } + case ImagePixelType_int32: + { + ret = "int32"; + break; + } + case ImagePixelType_uint32: + { + ret = "uint32"; + break; + } + case ImagePixelType_float: + { + ret = "float"; + break; + } + case ImagePixelType_double: + { + ret = "double"; + break; + } + } + return ret; +} + void OutputImageParameter::InitializeWriters() { m_UInt8Writer = UInt8WriterType::New();