// Copyright 2018 Slightech Co., Ltd. All rights reserved. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. #ifndef MYNTEYE_API_H_ // NOLINT #define MYNTEYE_API_H_ #pragma once #include #include #include #include #include #include "mynteye/mynteye.h" #include "mynteye/types.h" MYNTEYE_BEGIN_NAMESPACE class Device; class Synthetic; namespace device { class Frame; } // namespace device namespace api { /** * @ingroup datatypes * API stream data. */ struct MYNTEYE_API StreamData { /** ImgData. */ std::shared_ptr img; /** Frame. */ cv::Mat frame; /** Raw frame. */ std::shared_ptr frame_raw; bool operator==(const StreamData &other) const { if (img && other.img) { return img->frame_id == other.img->frame_id && img->timestamp == other.img->timestamp; } return false; } }; /** * @ingroup datatypes * API motion data. */ struct MYNTEYE_API MotionData { /** ImuData. */ std::shared_ptr imu; bool operator==(const MotionData &other) const { if (imu && other.imu) { return imu->timestamp == other.imu->timestamp; } return false; } }; } // namespace api /** * The API class to communicate with MYNT® EYE device. */ class MYNTEYE_API API { public: /** The api::StreamData callback. */ using stream_callback_t = std::function; /** The api::MotionData callback. */ using motion_callback_t = std::function; explicit API(std::shared_ptr device); virtual ~API(); /** * Create the API instance. * @return the API instance. * @note This will call device::select() to select a device. */ static std::shared_ptr Create(); /** * Create the API instance. * @param device the selected device. * @return the API instance. */ static std::shared_ptr Create(std::shared_ptr device); /** * Create the API instance. * @param argc the arg count. * @param argv the arg values. * @return the API instance. * @note This will init glog with args and call device::select() to select a * device. */ static std::shared_ptr Create(int argc, char *argv[]); /** * Create the API instance. * @param argc the arg count. * @param argv the arg values. * @param device the selected device. * @return the API instance. * @note This will init glog with args. */ static std::shared_ptr Create( int argc, char *argv[], std::shared_ptr device); /** * Get the model. */ Model GetModel() const; /** * Supports the stream or not. */ bool Supports(const Stream &stream) const; /** * Supports the capability or not. */ bool Supports(const Capabilities &capability) const; /** * Supports the option or not. */ bool Supports(const Option &option) const; /** * Supports the addon or not. */ bool Supports(const AddOns &addon) const; /** * set the stream request. */ void SetStreamRequest( const Resolution &res, const Format &format, const FrameRate &rate); /** * Get all stream requests of the capability. */ const std::vector &GetStreamRequests( const Capabilities &capability) const; /** * Config the stream request to the capability. */ void ConfigStreamRequest( const Capabilities &capability, const StreamRequest &request); /** * Get the device info. */ std::string GetInfo(const Info &info) const; /** * Get the intrinsics of stream. */ Intrinsics GetIntrinsics(const Stream &stream) const; /** * Get the extrinsics from one stream to another. */ Extrinsics GetExtrinsics(const Stream &from, const Stream &to) const; /** * Get the intrinsics of motion. */ MotionIntrinsics GetMotionIntrinsics() const; /** * Get the extrinsics from one stream to motion. */ Extrinsics GetMotionExtrinsics(const Stream &from) const; /** * Log all option infos. */ void LogOptionInfos() const; /** * Get the option info. */ OptionInfo GetOptionInfo(const Option &option) const; /** * Get the option value. */ std::int32_t GetOptionValue(const Option &option) const; /** * Set the option value. */ void SetOptionValue(const Option &option, std::int32_t value); /** * Run the option action. */ bool RunOptionAction(const Option &option) const; /** * Set the callback of stream. */ void SetStreamCallback(const Stream &stream, stream_callback_t callback); /** * Set the callback of motion. */ void SetMotionCallback(motion_callback_t callback); /** * Has the callback of stream. */ bool HasStreamCallback(const Stream &stream) const; /** * Has the callback of motion. */ bool HasMotionCallback() const; /** * Start capturing the source. */ void Start(const Source &source); /** * Stop capturing the source. */ void Stop(const Source &source); /** * Wait the streams are ready. */ void WaitForStreams(); /** * Enable the data of stream. * @note must enable the stream if it's a synthetic one. This means the stream * in not native, the device has the capability to provide this stream, but * still support this stream. */ void EnableStreamData(const Stream &stream); /** * Disable the data of stream. */ void DisableStreamData(const Stream &stream); /** * Get the latest data of stream. */ api::StreamData GetStreamData(const Stream &stream); /** * Get the datas of stream. * @note default cache 4 datas at most. */ std::vector GetStreamDatas(const Stream &stream); /** * Enable cache motion datas. */ void EnableMotionDatas( std::size_t max_size = std::numeric_limits::max()); /** * Get the motion datas. */ std::vector GetMotionDatas(); /** * Enable the plugin. */ void EnablePlugin(const std::string &path); std::shared_ptr device(); private: std::shared_ptr device_; std::unique_ptr synthetic_; void CheckImageParams(); }; MYNTEYE_END_NAMESPACE #endif // MYNTEYE_API_H_ NOLINT