IEnumEntry.h 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143
  1. //-----------------------------------------------------------------------------
  2. // (c) 2006 by Basler Vision Technologies
  3. // Section: Vision Components
  4. // Project: GenApi
  5. // Author: Margret Albrecht
  6. // $Header$
  7. //
  8. // License: This file is published under the license of the EMVA GenICam Standard Group.
  9. // A text file describing the legal terms is included in your installation as 'GenICam_license.pdf'.
  10. // If for some reason you are missing this file please contact the EMVA or visit the website
  11. // (http://www.genicam.org) for a full copy.
  12. //
  13. // THIS SOFTWARE IS PROVIDED BY THE EMVA GENICAM STANDARD GROUP "AS IS"
  14. // AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
  15. // THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
  16. // PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE EMVA GENICAM STANDARD GROUP
  17. // OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
  18. // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
  19. // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
  20. // OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
  21. // WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
  22. // ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
  23. // POSSIBILITY OF SUCH DAMAGE.
  24. //-----------------------------------------------------------------------------
  25. /*!
  26. \file
  27. \ingroup GenApi_PublicInterface
  28. */
  29. #ifndef GENAPI_IENUMENTRY_H
  30. #define GENAPI_IENUMENTRY_H
  31. #include <Base/GCString.h>
  32. #include <GenApi/GenApiDll.h>
  33. #include <GenApi/IValue.h>
  34. #ifdef _MSC_VER
  35. # pragma warning ( push )
  36. # pragma warning ( disable : 4251 ) // XXX needs to have dll-interface to be used by clients of class YYY
  37. #endif
  38. namespace GENAPI_NAMESPACE
  39. {
  40. //*************************************************************
  41. // IEnumEntry interface
  42. //*************************************************************
  43. /**
  44. \brief Interface of single enum value
  45. \ingroup GenApi_PublicInterface
  46. */
  47. /*! Maps of Enum Values to symbolic values */
  48. interface GENAPI_DECL_ABSTRACT IEnumEntry : virtual public IValue
  49. {
  50. public:
  51. //! Get numeric enum value
  52. virtual int64_t GetValue() = 0;
  53. //! Get symbolic enum value
  54. virtual GENICAM_NAMESPACE::gcstring GetSymbolic()const = 0;
  55. //! Get double number associated with the entry
  56. virtual double GetNumericValue() = 0;
  57. //! Indicates if the corresponding EnumEntry is self clearing
  58. virtual bool IsSelfClearing() = 0;
  59. };
  60. //*************************************************************
  61. // CEnumEntryRef class
  62. //*************************************************************
  63. #ifndef DOXYGEN_IGNORE
  64. /**
  65. \internal
  66. \brief Reference to an IEnumEntry pointer
  67. \ingroup GenApi_PublicImpl
  68. */
  69. template <class T>
  70. class CEnumEntryRefT : public CValueRefT<T>
  71. {
  72. typedef CValueRefT<T> ref;
  73. public:
  74. /*--------------------------------------------------------*/
  75. // IEnumEntry
  76. /*--------------------------------------------------------*/
  77. //! Get numeric enum value
  78. virtual int64_t GetValue()
  79. {
  80. if(ref::m_Ptr)
  81. return ref::m_Ptr->GetValue();
  82. else
  83. throw ACCESS_EXCEPTION("Feature not present (reference not valid)");
  84. }
  85. //! Get symbolic enum value
  86. virtual GENICAM_NAMESPACE::gcstring GetSymbolic()const
  87. {
  88. if(ref::m_Ptr)
  89. return ref::m_Ptr->GetSymbolic();
  90. else
  91. throw ACCESS_EXCEPTION("Feature not present (reference not valid)");
  92. }
  93. //! Get numeric enum value
  94. virtual double GetNumericValue()
  95. {
  96. if(ref::m_Ptr)
  97. return ref::m_Ptr->GetNumericValue();
  98. else
  99. throw ACCESS_EXCEPTION("Feature not present (reference not valid)");
  100. }
  101. //! Indicates if the corresponding EnumEntry is self clearing
  102. virtual bool IsSelfClearing()
  103. {
  104. if(ref::m_Ptr)
  105. return ref::m_Ptr->IsSelfClearing();
  106. else
  107. throw ACCESS_EXCEPTION("Feature not present (reference not valid)");
  108. }
  109. };
  110. //! Reference to an IEnumEntry pointer
  111. //! \ingroup GenApi_PublicImpl
  112. typedef CEnumEntryRefT<IEnumEntry> CEnumEntryRef;
  113. #endif
  114. }
  115. #ifdef _MSC_VER
  116. # pragma warning ( pop )
  117. #endif
  118. #endif // ifndef GENAPI_IENUMENTRY_H