#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 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; }