C 深度HDR示例代码-Hdr Merge






    PG电子







      PG电子

      C 深度HDR示例代码-Hdr Merge

      # HDR示例-HdrMerge

       

      支持设备: Gemini 330系列相机,例如:Gemini G335

       

      功能描述:演示使用HDR操作,显示HDR处理后的图像,并通过ESC_KEY键退出程序

       

      >本示例基于C High Level API进行演示

       

      创建pipeline,配置depth和ir流

      // Create a pipeline to open the depth stream after connecting the device
      pipeline = ob_create_pipeline(&error);
      check_error(error);

      // Create config to configure the resolution, frame rate, and format of the depth stream
      ob_config *config = ob_create_config(&error);
      check_error(error);

      // Configure the depth stream
      ob_stream_profile      *depth_profile = NULL;
      ob_stream_profile_list *profiles      = ob_pipeline_get_stream_profile_list(pipeline, OB_SENSOR_DEPTH, &error);
      check_error(error);

      // Find the corresponding profile according to the specified format, first look for the y16 format
      depth_profile = ob_stream_profile_list_get_video_stream_profile(profiles, 640, OB_HEIGHT_ANY, OB_FORMAT_Y16, 30, &error);
      // If the specified format is not found, search for the default profile to open the stream
      if(error) {
          depth_profile = ob_stream_profile_list_get_profile(profiles, OB_PROFILE_DEFAULT, &error);
          ob_delete_error(error);
          error = nullptr;
      }

      // enable stream
      ob_config_enable_stream(config, depth_profile, &error);
      check_error(error);

      // Configure the infrared stream
      // Please adjust the sensor according to the actual product, some device types only have OB_SENSOR_IR_LEFT and OB_SENSOR_IR_RIGHT.
      ob_stream_profile *     ir_profile = NULL;
      ob_stream_profile_list *ir_profiles   = ob_pipeline_get_stream_profile_list(pipeline, OB_SENSOR_IR_LEFT, &error);
      check_error(error);

      if(profiles == nullptr) {
          printf(
              "The obtained IR resolution list is NULL. For binocular structured light devices, try using the doubleIr example to turn on the ir data stream. ");
          return 0;
      }

      // Find the corresponding profile according to the specified format, first look for the y16 format
      ir_profile = ob_stream_profile_list_get_video_stream_profile(ir_profiles, 640, OB_HEIGHT_ANY, OB_FORMAT_Y8, 30, &error);
      // If the specified format is not found, search for the default profile to open the stream
      if(error) {
          ir_profile = ob_stream_profile_list_get_profile(profiles, OB_PROFILE_DEFAULT, &error);
          ob_delete_error(error);
          error = nullptr;
      }

      // enable stream
      ob_config_enable_stream(config, ir_profile, &error);
      check_error(error);

       

      获取device

      // Get the device through the pipeline
      ob_device *dev = ob_pipeline_get_device(pipeline, &error);
      check_error(error);

       

      打开HDR处理

      // Create HdrMerage post processor
      ob_filter *hdr_merge_filter = ob_create_hdr_merge(&error);
      check_error(error);

      bool is_supported = ob_device_is_property_supported(dev, OB_STRUCT_DEPTH_HDR_CONFIG, OB_PERMISSION_READ_WRITE, &error);
      check_error(error);
      // open hdr merage
      if(is_supported) {
          // Get depth exposure value range,the exposure_1 and exposure_2 in OBHdrConfig can be adjusted.
          ob_int_property_range depth_exp_range = ob_device_get_int_property_range(dev, OB_PROP_DEPTH_EXPOSURE_INT, &error);
          check_error(error);

          // Get depth gain value range,,the gain_1 and gain_1 in OBHdrConfig can be adjusted.
          ob_int_property_range depth_gain_range = ob_device_get_int_property_range(dev, OB_PROP_DEPTH_GAIN_INT, &error);
          check_error(error);

          ob_hdr_config hdr_config;
          uint32_t      dataSize = sizeof(ob_hdr_config);
          ob_device_get_structured_data(dev, OB_STRUCT_DEPTH_HDR_CONFIG, &hdr_config, &dataSize, &error);
          check_error(error);
          // open hdr
          hdr_config.enable = true;

          ob_device_set_structured_data(dev, OB_STRUCT_DEPTH_HDR_CONFIG, &hdr_config, dataSize, & error);
          check_error(error);
      }

       

      开启pipeline

      ob_pipeline_start_with_config(pipeline, config, &error);

       

      获取HDR处理后的图像

      auto new_frame_set = ob_filter_process(hdr_merge_filter, frameset, &error);
      check_error(error);

      auto new_depth_frame = ob_frameset_depth_frame(new_frame_set, &error);
      check_error(error);
      if(new_depth_frame != nullptr) {
          frames.push_back(new_depth_frame);
      }

       

      停止pipeline

      ob_pipeline_stop(pipeline, &error);

      预期输出:

      image.png 


      友情链接: