09 Halcon 3D点云定向切割

1.基于halcon算法平台;

2.提供深度图源文件以及解压密码;

3.代码预览:

/*******************************************************************************

  • @文档名称: 3D点云定向切割。
  • @作者: hugo
  • @版本: 1.1
  • @日期: 2021-6-26
  • @描述: 该方法支持3DROI创建以及点云定向切割。
  • @来源:欢迎关注微信公众号 robotvision+ 获取更多机器人视觉知识。

********************************************************************************/

 read_image (imageReal, './replay_38893_2021-6-7.tif')
    *read_image (imageReal, './circle0.tiff')
    xResolution:=0.06
    yResolution:=0.06
    zResolution:=0.001 
    ScaleFactor:=[xResolution,yResolution,zResolution]

    .......

    * ROI区域
    create_drawing_object_rectangle2 (270, 270, rad(90), 30, 20, DrawID)
    set_drawing_object_params (DrawID, 'color', 'yellow')
    set_drawing_object_params (DrawID, 'line_width', 1)
    attach_drawing_object_to_window (WindowHandle, DrawID)
   
    stop ()
      
    dev_set_color ('yellow')
    get_drawing_object_params (DrawID, ['row','column','phi','length1','length2'], GenParamValue)
    gen_rectangle2 (Rectangle,GenParamValue[0], GenParamValue[1], GenParamValue[2], GenParamValue[3], GenParamValue[4])
    detach_drawing_object_from_window (WindowHandle, DrawID)    
   
    *生成3DROI
    gen_3d_line (Rectangle, TriangulatedObjectModel3D, CameraParam, Pose, scale, WindowHandle, ObjectModel3D, GenParamValue, m_vloumn)

09 Halcon 点云空间定向切割

源码链接

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Hi~ 可私信我了解后再进行下载~ 本资源上传时,遗漏了两个文件,分别是:data_filter_keep_order_output_index.hdvp 以及 IntensityImageToPiontsCloudImage.hdvp,购买了该资源的同学,给我留言,我会私信发给你们。 1.基于halcon算法平台; 2.提供深度图源文件以及解压密码; 3.代码预览: */****************************** * @文档名称: 基于点云的平面度测量。 * @作者: hugo * @版本: 1.1 * @日期: 2021-6-20 * @描述: 该方法支持点云的平面的平面度测量。 ********************************/ dev_update_window ('on') dev_get_window (WindowHandle) read_image (imageReal, './replay_38893_2021-6-7.tif') xResolution:=0.06 yResolution:=0.06 zResolution:=0.001 ScaleFactor:=[xResolution,yResolution,zResolution] *采样区域1 create_drawing_object_rectangle2 (300, 120, rad(90), 30, 20, DrawID) set_drawing_object_params (DrawID, 'color', 'forest green') set_drawing_object_params (DrawID, 'line_width', 1) attach_drawing_object_to_window (WindowHandle, DrawID) .......... *平面度 height:=theta/zScale*0.001 *可视化高度差效果 visParamName := ['lut','alpha_0','intensity','color_1'] visParamValue := ['hsi',0.7,'coord_z','yellow'] Labels := ['','平面度:'+height+'mm',''] objs:=[ObjectModel3Ds[2],final_ObjectModel3Ds] visualize_object_model_3d (WindowHandle, objs, [], [], visParamName, visParamValue, 'Edited by AmazingRobot+', [Labels], '', PoseOut) *stop () clear_object_model_3d (plane_balls) for Index := 0 to |final_ObjectModel3Ds|-1 by 1 clear_object_model_3d (final_ObjectModel3Ds[Index]) endfor return () 谢谢您的信任~
在GStreamer的C语言绑定中,`g_value_get_object`是一个用于从`GValue`获取对象的函数。它的原型如下: ```c GObject* g_value_get_object(const GValue *value); ``` - `value` 是一个指向要获取对象的`GValue`结构体的指针。 `GValue`是一个通用值容器,可以存储不同类型的值。`g_value_get_object`函数用于从`GValue`中提取对象,并将其转换为`GObject`类型。 请注意,`g_value_get_object`函数在使用之前需要确保值类型为对象类型,否则会导致类型不匹配错误。你可以使用`G_VALUE_HOLDS_OBJECT`宏来检查`GValue`是否包含对象类型的值。 以下是一个示例,演示如何使用`g_value_get_object`函数: ```c #include <glib-object.h> void print_object(GValue *value) { if (G_VALUE_HOLDS_OBJECT(value)) { GObject *object = g_value_get_object(value); g_print("Object name: %s\n", G_OBJECT_TYPE_NAME(object)); } else { g_print("Value does not hold an object.\n"); } } int main() { GValue value = G_VALUE_INIT; g_value_init(&value, G_TYPE_OBJECT); GObject *object = g_object_new(G_TYPE_OBJECT, NULL); g_value_set_object(&value, object); print_object(&value); g_value_unset(&value); g_object_unref(object); return 0; } ``` 在这个示例中,我们创建了一个`GValue`对象并初始化为对象类型。然后,我们创建一个`GObject`对象并将其设置到`GValue`中。最后,我们调用`print_object`函数来提取并打印`GValue`中的对象。 请注意,在实际应用中,你需要根据你的具体情况和类型来使用和管理`GValue`和对象。上述示例仅用于演示如何使用`g_value_get_object`函数。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

robotvision+

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值