当前位置: 首页 > article >正文

halcon三维点云数据处理(十三)reduce_object_model_3d_by_view

目录

  • 一、reduce_object_model_3d_by_view函数
  • 二、reduce_object_model_3d_by_view函数调用过程

首先说明一下这部分代码在find_box_3d这个例程中,非常好用的一个坐标系生成函数。

一、reduce_object_model_3d_by_view函数

通过将3D对象模型投影到虚拟视图并删除给定区域外的所有点来删除3D对象模型中的点。

reduce_object_model_3d_by_view(Region : : ObjectModel3D, CamParam, Pose : ObjectModel3DReduced)

二、reduce_object_model_3d_by_view函数调用过程

* ********************************************************

read_object_model_3d ('glass_mug', 'cm', [], [], ObjectModel3D, Status)
* 
* Prepare the Visualization
dev_update_off ()
dev_close_window ()
dev_open_window (0, 0, 768, 512, 'black', WindowHandle)
dev_set_draw ('margin')
set_display_font (WindowHandle, 16, 'mono', 'true', 'false')
* 
gen_cam_par_area_scan_division (0.01, 0, 7e-6, 7e-6, 384, 255, 768, 512, CamParam)
create_pose (-0.1e-3, -0.47e-3, 55.8e-3, 104.5, 358.0, 353.0, 'Rp+T', 'gba', 'point', Pose)
GenParamName := ['color_0', 'disp_pose_0', 'alpha_0']
GenParamValue := ['yellow', 'true', 0.3]
GenParamName := [GenParamName,'color_1', 'attribute_1', 'disp_background']
GenParamValue := [GenParamValue,'blue', 'points', 'true']
gen_image_gray_ramp (Ramp, -0.5, 0, 300, 0, 512, 768, 512)
* 
* Show current 3D object model
Title := 'Move and rotate the object to an appropriate pose, before'
Title[1] := 'selecting the region of the points to be trimmed off.'
Instructions[0] := 'Rotate: Left button'
Instructions[1] := 'Zoom:   Shift + left button'
Instructions[2] := 'Move:   Ctrl  + left button'
dev_display (Ramp)
visualize_object_model_3d (WindowHandle, [ObjectModel3D,ObjectModel3D], CamParam, Pose, GenParamName, GenParamValue, Title, [], Instructions, Pose)
* 
* Now, select the points to be trimmed off by entering a
* suitable region
Message := 'Now draw region with the mouse to cut out part of the model'
Message[1] := '(Right click to finish)'
disp_message (WindowHandle, Message, 'window', 12, 12, 'black', 'true')
* Wait for a region
dev_set_line_width (3)
dev_set_color ('red')
draw_region (Region, WindowHandle)
get_cam_par_data (CamParam, 'image_width', ImageWidth)
get_cam_par_data (CamParam, 'image_height', ImageHeight)
gen_rectangle1 (Rectangle, 0, 0, ImageHeight, ImageWidth)
difference (Rectangle, Region, RegionComplement)
* Apply the region drawn before to the 3d object model
reduce_object_model_3d_by_view (RegionComplement, ObjectModel3D, CamParam, Pose, ObjectModel3DReduced)
* 
* Visualize the result
Title := 'Resulting reduced 3d object model'
dev_display (Ramp)
visualize_object_model_3d (WindowHandle, [ObjectModel3DReduced,ObjectModel3DReduced], CamParam, Pose, GenParamName, GenParamValue, Title, [], Instructions, Pose)

下面是这个例程比较特色的三个点
1、gen_image_gray_ramp (Ramp, -0.5, 0, 300, 0, 512, 768, 512),使用这个函数生成一个灰度渐变图像作为3D模型显示得背景。
2、reduce_object_model_3d_by_view (RegionComplement, ObjectModel3D, CamParam, Pose, ObjectModel3DReduced)
通过将3D对象模型投影到虚拟视图,选取RegionComplement内的点,完成模型筛选。
也可以通过下面的方式:

get_object_model_3d_params (ObjectModel3DScene, 'has_xyz_mapping', HasXYZMappings)
if (HasXYZMappings == 'true')
    * In 2D space.
    threshold (ZScene, Regions, MinDist, MaxDist)
    reduce_object_model_3d_by_view (Regions, ObjectModel3DScene, [], [], ObjectModel3DReduced)

3、GenParamName := [‘color_0’, ‘disp_pose_0’, ‘alpha_0’]
GenParamValue := [‘yellow’, ‘true’, 0.3]
GenParamName := [GenParamName,‘color_1’, ‘attribute_1’, ‘disp_background’]
GenParamValue := [GenParamValue,‘blue’, ‘points’, ‘true’]
visualize_object_model_3d (WindowHandle, [ObjectModel3DReduced,ObjectModel3DReduced], CamParam, Pose, GenParamName, GenParamValue, Title, [], Instructions, Pose)
上面一个3D模型显示函数,设置了一些属性,包括’color_0’, ‘disp_pose_0’, ‘alpha_0’,‘color_1’, ‘attribute_1’, ‘disp_background’


http://www.kler.cn/a/543873.html

相关文章:

  • elementuiPlus日期范围选择el-date-picker动态禁用时间选择
  • AI大模型介绍yolo
  • Spring:Spring实现AOP的通俗理解(有源码跟踪)
  • 2025 年前端开发现状分析:卷疯了还是卷麻了?
  • 前后端交互方式
  • 【数据结构入门】一、数组
  • 适配器模式 + 外观模式联合使用:新旧系统的平滑整合之道
  • visual studio 2008的试用版评估期已结束的解决办法
  • vue基础(八)
  • arkTS基础
  • 人工智能:所有144本SCI期刊都在这里(20本Top,4本On Hold)
  • JavaScript设计模式 -- 适配器模式
  • 《手札·行业篇》开源Odoo MES系统与SKF Observer Phoenix API双向对接方案
  • Notepad++ 中删除所有以 “pdf“ 结尾的行
  • CSS 核心技术知识点详解:从基础到进阶
  • 应用层优秀的共享民宿物联网框架该怎么选?
  • Kotlin 2.1.0 入门教程(十四)类、构造函数、对象、抽象类
  • mysql BUG 导致 show processlist 有大量的show slave stauts 处于init状态
  • Java调用C++动态库、入参为对象
  • websocketpp库使用:快速搭建一个websocket服务端
  • 【学习】如何高效通过CCRC信息安全服务资质认证
  • 介绍下SpringBoot在分布式架构中,如何实现读写分离
  • 晶闸管主要参数分析与损耗计算
  • 【Web安全测试】Burp中NEW_xp_CAPTCHA插件(含4.1和4.2)的下载安装和导入
  • 网络安全设备异构要求 网络安全设备硬件
  • 伺服报警的含义