MvGigEDevice.h 8.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205
  1. #ifndef __MV_GIGE_DEVICE_H__
  2. #define __MV_GIGE_DEVICE_H__
  3. #include "MvDeviceBase.h"
  4. namespace MvCamCtrl
  5. {
  6. class CMvGigEDevice : public IMvDevice
  7. {
  8. public:
  9. // ch:打开设备
  10. // en:Open Device
  11. virtual int Open(unsigned int nAccessMode = MV_ACCESS_Exclusive, unsigned short nSwitchoverKey = 0);
  12. // ch:关闭设备
  13. // en:Close Device
  14. virtual int Close();
  15. // ch:判断设备的状态,仅当返回false时,可打开设备
  16. // en:Determines the status of the device, only if false is returned, the device can be opened
  17. virtual bool IsOpen();
  18. // ch:开启抓图
  19. // en:Start Grabbing
  20. virtual int StartGrabbing();
  21. // ch:停止抓图
  22. // en:Stop Grabbing
  23. virtual int StopGrabbing();
  24. // ch:获取设备信息
  25. // en:Get Device Information
  26. virtual int GetDeviceInfo(MV_CC_DEVICE_INFO&);
  27. /** @fn GetGenICamXML(unsigned char* pData, unsigned int nDataSize, unsigned int* pnDataLen)
  28. * @brief 获取设备的XML文件
  29. * @param pData [IN][OUT] - 待拷入的缓存地址
  30. nDataSize [IN] - 缓存大小
  31. pnDataLen [OUT] - xml 文件数据长度
  32. *
  33. * @return 成功,返回MV_OK;失败,返回错误码
  34. * @note 当pData为NULL或nDataSize比实际的xml文件小时,不拷贝数据,由pnDataLen返回xml文件大小;
  35. * 当pData为有效缓存地址,且缓存足够大时,拷贝完整数据,并由pnDataLen返回xml文件大小。
  36. * @fn GetGenICamXML(unsigned char* pData, unsigned int nDataSize, unsigned int* pnDataLen)
  37. * @brief Get Device XML File
  38. * @param pData [IN][OUT] - Cache Address to copy in
  39. nDataSize [IN] - Cache Size
  40. pnDataLen [OUT] - XML File Data Length
  41. *
  42. * @return Success, return MV_OK; Fail, return Error Code
  43. * @note When pData is NULL or nDataSize is smaller than the actual xml file, do not copy data, return xml file size from the pnDataLen;
  44. * When pData is a valid cache address and the cache is large enough, the full data is copied and the xml file size is returned by pnDataLen.
  45. */
  46. virtual int GetGenICamXML(unsigned char* pData, unsigned int nDataSize, unsigned int* pnDataLen);
  47. /** @fn GetOneFrame(unsigned char * pData , unsigned int nDataSize, MV_FRAME_OUT_INFO* pFrameInfo)
  48. * @brief 获取一帧图像数据
  49. * @param pData [IN][OUT] - 数据指针
  50. nDataLen [IN] - 数据长度
  51. pFrameInfo [OUT] - 输出的帧信息
  52. *
  53. * @return 成功,返回MV_OK;失败,返回错误码
  54. * @fn GetOneFrame(unsigned char * pData , unsigned int nDataSize, MV_FRAME_OUT_INFO* pFrameInfo)
  55. * @brief Get One Frame Image Data
  56. * @param pData [IN][OUT] - Data Pointer
  57. nDataLen [IN] - Data Length
  58. pFrameInfo [OUT] - Output Frame Information
  59. *
  60. * @return Success, return MV_OK; Fail, return Error Code
  61. */
  62. virtual int GetOneFrame(unsigned char * pData , unsigned int nDataSize, MV_FRAME_OUT_INFO* pFrameInfo);
  63. // ch:获取GenICam使用的传输层代理类
  64. // en:Get the transport layer agent class used by GenICam
  65. virtual TlProxy GetTlProxy();
  66. virtual ~CMvGigEDevice( void );
  67. CMvGigEDevice( const MV_CC_DEVICE_INFO* pInfo );
  68. // ch:获取网络信息
  69. // en:Get Net Information
  70. virtual int GetNetTransInfo(MV_NETTRANS_INFO* pstInfo);
  71. // ch:强制IP
  72. // en:Force IP
  73. virtual int ForceIp(unsigned int nIP);
  74. // ch:配置IP方式
  75. // en:Configure IP Mode
  76. virtual int SetIpConfig(unsigned int nType);
  77. // ch:获取各种类型的信息
  78. // en:Get Various Types of Information
  79. virtual int GetAllMatchInfo(MV_ALL_MATCH_INFO* pstInfo);
  80. // ch:注册消息异常回调
  81. // en:Register Message Exception Callback
  82. virtual int RegisterExceptionCallBack(void(__stdcall* cbException)(unsigned int nMsgType, void* pUser),
  83. void* pUser);
  84. virtual int SetSingleShot(void(__stdcall* cbSingleShot)(unsigned char* pData , unsigned int nDataLen,
  85. MV_FRAME_OUT_INFO* pFrameInfo, void* pUser),
  86. void* pUser);
  87. // ch:设置设备采集模式
  88. // en:Set Device Aquisition Mode
  89. virtual int SetAcquisitionMode(MV_CAM_ACQUISITION_MODE enMode);
  90. // ch:设备本地升级
  91. // en:Device Local Update
  92. virtual int LocalUpgrade(const void *pFilePathName);
  93. // ch:获取当前升级进度
  94. // en:Get Current Update Process
  95. virtual int GetUpgradeProcess(unsigned int* pnProcess);
  96. virtual int GetOptimalPacketSize();
  97. // ch:显示一帧图像
  98. // en:Display One Frame Image
  99. virtual int Display(void* hWnd);
  100. virtual int SetNetTransMode(unsigned int nType);
  101. virtual int ReadMemory(void *pBuffer, int64_t nAddress, int64_t nLength);
  102. virtual int WriteMemory(const void *pBuffer, int64_t nAddress, int64_t nLength);
  103. // ch:返回值 0驱动不正常,1驱动正常工作
  104. // en:Return Value 0 driver exception, 1 driver work properly
  105. virtual int IsDriverWorking();
  106. // ch:0:不丢弃;1:丢弃
  107. // en:0: Do not throw; 1: Throw
  108. virtual int SetThrowAbnormalImage(int bThrow);
  109. // ch:设置SDK内部图像缓存节点个数,范围[1, 30],在抓图前调用
  110. // en:Set the number of the internal image cache nodes in SDK, range [1, 30], called before capture
  111. virtual int SetImageNodeNum(unsigned int nNum);
  112. // ch:设置gvcp超时时间
  113. // en:Set Gvcp Timeout
  114. virtual int SetGvcpTimeout(unsigned int nTimeout);
  115. // ch:注册图像数据回调
  116. // en:Register Image Data Callback
  117. virtual int RegisterImageCallBack(void(__stdcall* cbOutput)(unsigned char * pData, MV_FRAME_OUT_INFO* pFrameInfo, void* pUser),
  118. void* pUser);
  119. // ch:注册EVENT消息回调,已废弃
  120. // en:Register Event Message Callback
  121. virtual int RegisterEventCallBack(void(__stdcall* cbEvent)(unsigned int nUserDefinedId, void* pUser),
  122. void* pUser);
  123. // ch:注册全部EVENT消息回调
  124. // en:Register all event Callback, chunk
  125. virtual int RegisterAllEventCallBack(void(__stdcall* cbEvent)(MV_EVENT_OUT_INFO * pEventInfo, void* pUser),void* pUser);
  126. // ch:注册单个EVENT消息回调
  127. // en:Register event Callback, chunk
  128. virtual int RegisterEventCallBack(const char* pEventName,void(__stdcall* cbEvent)(MV_EVENT_OUT_INFO * pEventInfo, void* pUser),
  129. void* pUser);
  130. // ch:注册图像数据回调,chunk
  131. // en:Register Image Data Callback, chunk
  132. virtual int RegisterImageCallBackEx(void(__stdcall* cbOutput)(unsigned char * pData, MV_FRAME_OUT_INFO_EX* pFrameInfo, void* pUser),void* pUser);
  133. virtual int RegisterImageCallBackForRGB(void(__stdcall* cbOutput)(unsigned char * pData, MV_FRAME_OUT_INFO_EX* pFrameInfo, void* pUser),void* pUser);
  134. virtual int RegisterImageCallBackForBGR(void(__stdcall* cbOutput)(unsigned char * pData, MV_FRAME_OUT_INFO_EX* pFrameInfo, void* pUser),void* pUser);
  135. virtual int GetOneFrameEx(unsigned char * pData , unsigned int nDataSize, MV_FRAME_OUT_INFO_EX* pFrameInfo);
  136. virtual int GetImageForRGB(unsigned char * pData , unsigned int nDataSize, MV_FRAME_OUT_INFO_EX* pFrameInfo, int nMsec);
  137. virtual int GetImageForBGR(unsigned char * pData , unsigned int nDataSize, MV_FRAME_OUT_INFO_EX* pFrameInfo, int nMsec);
  138. virtual int GetOneFrameTimeout(unsigned char * pData , IN unsigned int nDataSize, IN OUT MV_FRAME_OUT_INFO_EX* pFrameInfo, int nMsec);
  139. private:
  140. CDevRefs* m_pRefs;
  141. };
  142. }
  143. #endif /* __MV_GIGE_DEVICE_H__ */