MvUsb3VDevice.h 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148
  1. #ifndef __MV_USB3V_DEVICE_H__
  2. #define __MV_USB3V_DEVICE_H__
  3. #include "MvDeviceBase.h"
  4. namespace MvCamCtrl
  5. {
  6. class CMvUsb3VDevice : 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 Files
  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 ~CMvUsb3VDevice( void );
  67. CMvUsb3VDevice( const MV_CC_DEVICE_INFO* pInfo );
  68. // ch:显示一帧图像
  69. // en:Display One Frame Image
  70. virtual int Display(void* hWnd);
  71. // ch:获取各种类型的信息
  72. // en:Get Various Types of Information
  73. virtual int GetAllMatchInfo(MV_ALL_MATCH_INFO* pstInfo);
  74. // ch:注册消息异常回调
  75. // en:Register Message Exception Callback
  76. virtual int RegisterExceptionCallBack(void(__stdcall* cbException)(unsigned int nMsgType, void* pUser),
  77. void* pUser);
  78. virtual int SetSingleShot(void(__stdcall* cbSingleShot)(unsigned char* pData , unsigned int nDataLen,
  79. MV_FRAME_OUT_INFO* pFrameInfo, void* pUser),
  80. void* pUser);
  81. // ch:设置设备采集模式
  82. // en:Set Device Aquisition Mode
  83. virtual int SetAcquisitionMode(MV_CAM_ACQUISITION_MODE enMode);
  84. // ch:设备本地升级
  85. // en:Device Local Upgrade
  86. virtual int LocalUpgrade(const void *pFilePathName);
  87. // ch:获取当前升级进度
  88. // en:Get Current Upgrade Process
  89. virtual int GetUpgradeProcess(unsigned int* pnProcess);
  90. virtual int ReadMemory(void *pBuffer, int64_t nAddress, int64_t nLength);
  91. virtual int WriteMemory(const void *pBuffer, int64_t nAddress, int64_t nLength);
  92. // ch:设置SDK内部图像缓存节点个数,范围[1, 30],在抓图前调用
  93. // en:Set the number of the internal image cache nodes in SDK, range [1, 30], called before capture
  94. virtual int SetImageNodeNum(unsigned int nNum);
  95. // ch:注册图像数据回调
  96. // en:Register Image Data Callback
  97. virtual int RegisterImageCallBack(void(__stdcall* cbOutput)(unsigned char * pData, MV_FRAME_OUT_INFO* pFrameInfo, void* pUser),
  98. void* pUser);
  99. private:
  100. CDevRefs* m_pRefs;
  101. };
  102. }
  103. #endif /* __MV_GIGE_DEVICE_H__ */