123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153 |
- #include "../common/common.hpp"
- void eventCallback(TY_EVENT_INFO *event_info, void *userdata)
- {
- if (event_info->eventId == TY_EVENT_DEVICE_OFFLINE) {
- LOGD("=== Event Callback: Device Offline!");
- // Note:
- // Please set TY_BOOL_KEEP_ALIVE_ONOFF feature to false if you need to debug with breakpoint!
- }
- else if (event_info->eventId == TY_EVENT_LICENSE_ERROR) {
- LOGD("=== Event Callback: License Error!");
- }
- }
- int main(int argc, char* argv[])
- {
- std::string ID, IP;
- TY_INTERFACE_HANDLE hIface = NULL;
- TY_DEV_HANDLE hDevice;
- for(int i = 1; i < argc; i++) {
- if(strcmp(argv[i], "-id") == 0){
- ID = argv[++i];
- } else if(strcmp(argv[i], "-ip") == 0) {
- IP = argv[++i];
- } else if(strcmp(argv[i], "-h") == 0) {
- LOGI("Usage: %s [-h]", argv[0]);
- return 0;
- }
- }
- LOGD("=== Init lib");
- ASSERT_OK( TYInitLib() );
- TY_VERSION_INFO ver;
- ASSERT_OK( TYLibVersion(&ver) );
- LOGD(" - lib version: %d.%d.%d", ver.major, ver.minor, ver.patch);
- std::vector<TY_DEVICE_BASE_INFO> selected;
- ASSERT_OK( selectDevice(TY_INTERFACE_ALL, ID, IP, 1, selected) );
- ASSERT(selected.size() > 0);
- TY_DEVICE_BASE_INFO& selectedDev = selected[0];
- ASSERT_OK( TYOpenInterface(selectedDev.iface.id, &hIface) );
- ASSERT_OK( TYOpenDevice(hIface, selectedDev.id, &hDevice) );
- TY_COMPONENT_ID allComps, componentIDs = 0;
- ASSERT_OK( TYGetComponentIDs(hDevice, &allComps) );
- if(allComps & TY_COMPONENT_BRIGHT_HISTO) {
- LOGD("=== Has bright histo component");
- componentIDs |= TY_COMPONENT_BRIGHT_HISTO;
- }
- LOGD("=== Configure components, open depth cam");
- componentIDs |= TY_COMPONENT_IR_CAM_RIGHT| TY_COMPONENT_IR_CAM_LEFT;
- ASSERT_OK( TYEnableComponents(hDevice, componentIDs) );
- //try to enable depth map
- LOGD("Configure components, open depth cam");
- if (allComps & TY_COMPONENT_DEPTH_CAM) {
- TY_IMAGE_MODE image_mode;
- ASSERT_OK(get_default_image_mode(hDevice, TY_COMPONENT_DEPTH_CAM, image_mode));
- LOGD("Select Depth Image Mode: %dx%d", TYImageWidth(image_mode), TYImageHeight(image_mode));
- ASSERT_OK(TYSetEnum(hDevice, TY_COMPONENT_DEPTH_CAM, TY_ENUM_IMAGE_MODE, image_mode));
- ASSERT_OK(TYEnableComponents(hDevice, TY_COMPONENT_DEPTH_CAM));
- }
- LOGD("=== Prepare image buffer");
- uint32_t frameSize;
- ASSERT_OK( TYGetFrameBufferSize(hDevice, &frameSize) );
- LOGD(" - Get size of framebuffer, %d", frameSize);
- LOGD(" - Allocate & enqueue buffers");
- char* frameBuffer[2];
- frameBuffer[0] = new char[frameSize];
- frameBuffer[1] = new char[frameSize];
- LOGD(" - Enqueue buffer (%p, %d)", frameBuffer[0], frameSize);
- ASSERT_OK( TYEnqueueBuffer(hDevice, frameBuffer[0], frameSize) );
- LOGD(" - Enqueue buffer (%p, %d)", frameBuffer[1], frameSize);
- ASSERT_OK( TYEnqueueBuffer(hDevice, frameBuffer[1], frameSize) );
- LOGD("=== Register event callback");
- ASSERT_OK(TYRegisterEventCallback(hDevice, eventCallback, NULL));
- LOGD("=== Disable trigger mode");
- TY_TRIGGER_PARAM trigger;
- trigger.mode = TY_TRIGGER_MODE_OFF;
- ASSERT_OK(TYSetStruct(hDevice, TY_COMPONENT_DEVICE, TY_STRUCT_TRIGGER_PARAM, &trigger, sizeof(trigger)));
- LOGD("=== Start capture");
- ASSERT_OK( TYStartCapture(hDevice) );
- LOGD("=== While loop to fetch frame");
- bool exit_main = false;
- TY_FRAME_DATA frame;
- int index = 0;
- while(!exit_main) {
- int err = TYFetchFrame(hDevice, &frame, -1);
- if( err == TY_STATUS_OK ) {
- LOGD("=== Get frame %d", ++index);
- int fps = get_fps();
- if (fps > 0){
- LOGI("fps: %d", fps);
- }
- for( int i = 0; i < frame.validCount; i++ ){
- if(frame.image[i].componentID == TY_COMPONENT_BRIGHT_HISTO) {
- int32_t *ir_left_his, *ir_right_his;
- ir_left_his = (int32_t *)frame.image[i].buffer;
- ir_right_his = (int32_t *)frame.image[i].buffer + 256;
-
- for(int i=0; i<256; i++) {
- LOGI("ir_left_his[%d] = %u, ir_right_his[%d] = %u"
- , i, ir_left_his[i], i, ir_right_his[i]);
- }
- }
- if(frame.image[i].componentID == TY_COMPONENT_IR_CAM_LEFT) {
- cv::Mat irl(frame.image[i].height, frame.image[i].width, CV_8U, frame.image[i].buffer);
- imshow("irl", irl);
- }
- if(frame.image[i].componentID == TY_COMPONENT_IR_CAM_RIGHT) {
- cv::Mat irr(frame.image[i].height, frame.image[i].width, CV_8U, frame.image[i].buffer);
- imshow("irr", irr);
- }
- }
- int key = cv::waitKey(1);
- switch(key & 0xff) {
- case 0xff:
- break;
- case 'q':
- exit_main = true;
- break;
- default:
- LOGD("Unmapped key %d", key);
- }
- LOGD("=== Re-enqueue buffer(%p, %d)"
- , frame.userBuffer, frame.bufferSize);
- ASSERT_OK( TYEnqueueBuffer(hDevice, frame.userBuffer, frame.bufferSize) );
- }
- }
- ASSERT_OK( TYStopCapture(hDevice) );
- ASSERT_OK( TYCloseDevice(hDevice) );
- ASSERT_OK( TYCloseInterface(hIface) );
- ASSERT_OK( TYDeinitLib() );
- delete frameBuffer[0];
- delete frameBuffer[1];
- LOGD("=== Main done!");
- return 0;
- }
|