opencascade AIS_InteractiveContext源码学习2

2024-06-21 12:12

本文主要是介绍opencascade AIS_InteractiveContext源码学习2,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

AIS_InteractiveContext

在这里插入图片描述

前言

交互上下文(Interactive Context)允许您在一个或多个视图器中管理交互对象的图形行为和选择。类方法使这一操作非常透明。需要记住的是,对于已经被交互上下文识别的交互对象,必须使用上下文方法进行修改。如果交互对象尚未加载到交互上下文中,您才能直接调用交互对象的方法。

每个可选择的对象必须指定负责整体选择对象的选择模式(全局选择模式)。交互上下文本身支持使用选择过滤器进行分解对象的选择。默认情况下,全局选择模式等于0,但如果需要,可以重新定义。

Selection management 选择管理

1:AddSelect

构造1:将对象添加到选择中
构造2:将对象添加到选择中

2:SelectRectangle

选择在包围矩形内的对象。选择后应显式重绘视图。
参数:

  • thePntMin [输入] 矩形的较小点(以像素表示)
  • thePntMax [输入] 矩形的较大点(以像素表示)
  • theView [输入] 定义矩形的活动视图
  • theSelScheme [输入] 选择方案
    返回值:选择状态
    另请参阅:StdSelect_ViewerSelector3d::AllowOverlapDetection()
3:SelectPolygon

选择多边形边界内找到的所有内容。选择后应显式重绘视图。
参数:

  • thePolyline [输入] 定义多边形边界的折线(以像素表示)
  • theView [输入] 定义折线的活动视图
  • theSelScheme [输入] 选择方案
    返回值:选择状态
4:SelectPoint

选择视图中由点拾取的最顶层对象。选择后应显式重绘视图。
参数:

  • thePnt [输入] 视图内的点的像素坐标
  • theView [输入] 定义点所在的活动视图
  • theSelScheme [输入] 选择方案
    返回值:拾取状态
5:SelectDetected

选择并突出显示之前通过 AIS_InteractiveContext::MoveTo() 方法检测到的对象;取消之前选中的对象的高亮显示。选择后应显式重绘视图。
参数:

  • theSelScheme [输入] 选择方案
    返回值:拾取状态
    另请参阅:HighlightStyle(),定义所选所有者的默认高亮样式(Prs3d_TypeOfHighlight_Selected 和 Prs3d_TypeOfHighlight_LocalSelected);PrsMgr_PresentableObject::HilightAttributes(),定义所选所有者的每个对象高亮样式(覆盖默认设置)。
6:BoundingBoxOfSelection

返回所选对象的边界框。

7:Select
重载方法1:

设置使用指定选择方案选择/取消选择的所有者列表。
参数:

  • theOwners 要改变选择状态的所有者列表
  • theSelScheme 选择方案
    返回值:拾取状态
重载方法2:

存储并突出显示之前检测到的对象;取消之前选择的对象的高亮显示。参见 MoveTo()。已弃用:(“此方法已弃用 - 应调用带有 AIS_SelectionScheme_Replace 参数的 SelectDetected() 方法代替”)

重载方法3:

选择在视图中由像素最小值和最大值(XPMin、YPMin、XPMax 和 YPMax)定义的边界矩形内找到的所有内容。检测到的对象将传递给主视图,然后进行更新。
已弃用:(“此方法已弃用 - 应调用带有 AIS_SelectionScheme_Replace 参数的 SelectRectangle() 方法代替”)

重载方法4:

折线选择;清除先前的选取列表。
已弃用:(“此方法已弃用 - 应调用带有 AIS_SelectionScheme_Replace 参数的 SelectPolygon() 方法代替”)

8:FitSelected
重载方法1、2:

将视图适应所选对象的边界。如果将 AIS_InteractiveObject 的无限状态设置为 true,则无限对象将被忽略。

9:ToHilightSelected

返回值指定当鼠标光标移到选定对象上方时是否应突出显示该对象。
另请参阅 MoveTo()。

10:SetToHilightSelected

指定当鼠标光标移到选定对象上方时,是否应突出显示该对象(在 MoveTo 方法中)。默认情况下,此值为 false,在这种情况下选定的对象不会被突出显示。
另请参阅 MoveTo()。

11:AutomaticHilight

如果自动高亮模式处于活动状态,则返回 true;默认情况下为 TRUE。
另请参阅 MoveTo()、Select()、HilightWithColor()、Unhilight()。

12:SetAutomaticHilight

设置检测到和选定实体的突出显示状态。此函数允许您断开自动模式。

MoveTo() 将填充检测到实体的列表,而 Select() 将设置检测到对象的选定状态,而不考虑此标志,但如果禁用了 AutomaticHiligh(),它们的突出显示状态将不受影响,因此应用程序可以根据需要以不同方式执行自定义突出显示。

此 API 应与 SelectMgr_SelectableObject::SetAutoHilight() 区分开来,后者用于实现特定交互对象类的自定义突出显示逻辑。
另请参阅 MoveTo()、Select()、HilightWithColor()、Unhilight()。

13:SetSelected
重载方法1

将交互式对象 aniObj 放入选定对象的列表中。执行选择过滤器检查。

重载方法2

取消先前选定的所有者的高亮显示,并将它们标记为未选定状态。将给定的所有者标记为已选定并突出显示它。执行选择过滤器检查。

14:AddOrRemoveSelected
重载方法1

允许根据其选择状态来突出显示或取消突出显示给定的所有者。

重载方法2

允许根据其选择状态对给定的所有者进行突出显示或取消突出显示操作。

15:IsSelected
重载方法1

返回 true 表示给定的对象已被选中。

重载方法2

返回 true 表示给定的所有者已被选中。

16:FirstSelectedObject

返回当前选定列表中的第一个选定对象。

17:NbSelected

使用 InitSelected() + MoreSelected() + NextSelected() 迭代器计算当前选定实体的数量。
另请参见 SelectedOwner()、InitSelected()、MoreSelected()、NextSelected()。

18:InitSelected

初始化对选定对象的扫描。
另请参见 SelectedOwner()、MoreSelected()、NextSelected()。

19:MoreSelected

如果在扫描选定对象列表时找到另一个对象,则返回 true。
另请参见 SelectedOwner()、InitSelected()、NextSelected()。

20:NextSelected

继续扫描到选定对象列表中的下一个对象。
另请参见 SelectedOwner()、InitSelected()、MoreSelected()。

21:SelectedOwner

返回选定实体的所有者。
另请参见 InitSelected()、MoreSelected()、NextSelected()。

22:SelectedInteractive

返回 Handle(AIS_InteractiveObject)::DownCast(SelectedOwner()->Selectable())

另请参见 SelectedOwner()。
重点 转换方法

23:HasSelectedShape

如果交互上下文中选择了形状,则返回 TRUE。

另请参见 SelectedShape()。

24:SelectedShape

返回选定的形状。基本上,它只是由 StdSelect_BRepOwner 存储的形状,并应用了图形变换:

const Handle(StdSelect_BRepOwner) aBRepOwner = Handle(StdSelect_BRepOwner)::DownCast(SelectedOwner());
TopoDS_Shape aSelShape = aBRepOwner->Shape();
TopoDS_Shape aLocatedShape = aSelShape.Located(aBRepOwner->Location() * aSelShape.Location());

另请参见 SelectedOwner()、HasSelectedShape()。
重点 转换方法

25:HasApplicative

如果上下文中存在通过鼠标检测到的实体,则返回 true。

另请参见 DetectedOwner()、HasNextDetected()、HilightPreviousDetected()、HilightNextDetected()。

26:Applicative

返回 SelectedInteractive()->GetOwner()

另请参见 SelectedOwner()。

用法用例

当使用OpenCASCADE的AIS_InteractiveContext进行选择管理时,可以基于不同的交互需求和场景来执行多种操作。以下是用例示例:

1. 利用选择状态进行对象操作
  • 获取当前选择的对象:

    Handle(AIS_InteractiveObject) selectedObject = myContext->SelectedInteractive();
    if (!selectedObject.IsNull()) {// 对选定对象执行操作,如获取属性、修改颜色等selectedObject->SetColor(Quantity_NOC_RED);
    }
    

    通过 SelectedInteractive() 方法获取当前选定的交互式对象,并可以在此基础上执行相应的操作,如修改颜色、获取属性等。

  • 根据选择执行特定操作:

    if (myContext->HasSelectedShape()) {TopoDS_Shape selectedShape = myContext->SelectedShape();// 执行基于选定形状的操作,如分析、处理等
    }
    

    使用 HasSelectedShape()SelectedShape() 方法检查和获取当前选定的形状,并在此基础上执行特定的操作。

2. 多选和集合操作
  • 获取所有选定的对象:

    for (myContext->InitSelected(); myContext->MoreSelected(); myContext->NextSelected()) {Handle(AIS_InteractiveObject) selectedObject = myContext->SelectedInteractive();// 处理每个选定的对象,如打印信息、处理属性等
    }
    

    使用 InitSelected()MoreSelected()NextSelected() 方法遍历所有选定的对象,并执行适当的操作。

  • 添加和移除选择对象:

    myContext->ShiftSelect(...);  // 添加新对象到当前选择
    myContext->ShiftSelect(...);  // 再次选择以移除对象
    

    使用 ShiftSelect(...) 方法可以根据需要添加或移除对象到当前选择集合中。

3. 自定义高亮显示和选择模式
  • 自定义高亮显示:

    myContext->HilightWithColor(anObject, Quantity_NOC_YELLOW);
    

    使用 HilightWithColor() 方法为指定的对象设置自定义的高亮显示颜色。

  • 设置选择模式:

    myContext->SetSelectionMode(AIS_SelectionMode::AIS_SelectionMode_EntityOwner);
    

    使用 SetSelectionMode() 方法设置选择模式,以控制如何处理选择操作,如选择对象或选择对象所有者等。

4. 事件处理和用户交互
  • 处理选择事件:

    void MyEventHandler::OnSelectEvent(const AIS_InteractiveObject& object, const Standard_Boolean isSelected) {// 处理选择事件,根据选择状态执行相应操作if (isSelected) {// 对象被选中时执行的操作} else {// 对象取消选中时执行的操作}
    }
    

    使用事件处理器(如自定义的 MyEventHandler 类)来处理选择事件,根据选择状态执行相应的操作。

相关类和方法:
  • AIS_InteractiveContext: 主要类,用于管理交互式对象、选择和操作。
  • AIS_SelectionMode: 枚举,定义不同的选择模式,如选择对象或选择对象所有者。
  • 事件处理器类:用于处理选择事件和与选择相关的操作。

这些用例展示了如何利用OpenCASCADE中的 AIS_InteractiveContext 类进行灵活的选择管理和交互操作,以实现各种复杂的3D场景应用需求。通过这些方法和技术,可以有效地增强应用程序的用户体验和交互性。

immediate mode rendering 即时模式渲染

续看篇章5

这篇关于opencascade AIS_InteractiveContext源码学习2的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1081189

相关文章

Go学习记录之runtime包深入解析

《Go学习记录之runtime包深入解析》Go语言runtime包管理运行时环境,涵盖goroutine调度、内存分配、垃圾回收、类型信息等核心功能,:本文主要介绍Go学习记录之runtime包的... 目录前言:一、runtime包内容学习1、作用:① Goroutine和并发控制:② 垃圾回收:③ 栈和

Android学习总结之Java和kotlin区别超详细分析

《Android学习总结之Java和kotlin区别超详细分析》Java和Kotlin都是用于Android开发的编程语言,它们各自具有独特的特点和优势,:本文主要介绍Android学习总结之Ja... 目录一、空安全机制真题 1:Kotlin 如何解决 Java 的 NullPointerExceptio

8种快速易用的Python Matplotlib数据可视化方法汇总(附源码)

《8种快速易用的PythonMatplotlib数据可视化方法汇总(附源码)》你是否曾经面对一堆复杂的数据,却不知道如何让它们变得直观易懂?别慌,Python的Matplotlib库是你数据可视化的... 目录引言1. 折线图(Line Plot)——趋势分析2. 柱状图(Bar Chart)——对比分析3

重新对Java的类加载器的学习方式

《重新对Java的类加载器的学习方式》:本文主要介绍重新对Java的类加载器的学习方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、介绍1.1、简介1.2、符号引用和直接引用1、符号引用2、直接引用3、符号转直接的过程2、加载流程3、类加载的分类3.1、显示

Android实现一键录屏功能(附源码)

《Android实现一键录屏功能(附源码)》在Android5.0及以上版本,系统提供了MediaProjectionAPI,允许应用在用户授权下录制屏幕内容并输出到视频文件,所以本文将基于此实现一个... 目录一、项目介绍二、相关技术与原理三、系统权限与用户授权四、项目架构与流程五、环境配置与依赖六、完整

Android实现定时任务的几种方式汇总(附源码)

《Android实现定时任务的几种方式汇总(附源码)》在Android应用中,定时任务(ScheduledTask)的需求几乎无处不在:从定时刷新数据、定时备份、定时推送通知,到夜间静默下载、循环执行... 目录一、项目介绍1. 背景与意义二、相关基础知识与系统约束三、方案一:Handler.postDel

Java学习手册之Filter和Listener使用方法

《Java学习手册之Filter和Listener使用方法》:本文主要介绍Java学习手册之Filter和Listener使用方法的相关资料,Filter是一种拦截器,可以在请求到达Servl... 目录一、Filter(过滤器)1. Filter 的工作原理2. Filter 的配置与使用二、Listen

Java 正则表达式URL 匹配与源码全解析

《Java正则表达式URL匹配与源码全解析》在Web应用开发中,我们经常需要对URL进行格式验证,今天我们结合Java的Pattern和Matcher类,深入理解正则表达式在实际应用中... 目录1.正则表达式分解:2. 添加域名匹配 (2)3. 添加路径和查询参数匹配 (3) 4. 最终优化版本5.设计思

Java调用C++动态库超详细步骤讲解(附源码)

《Java调用C++动态库超详细步骤讲解(附源码)》C语言因其高效和接近硬件的特性,时常会被用在性能要求较高或者需要直接操作硬件的场合,:本文主要介绍Java调用C++动态库的相关资料,文中通过代... 目录一、直接调用C++库第一步:动态库生成(vs2017+qt5.12.10)第二步:Java调用C++

Python实现无痛修改第三方库源码的方法详解

《Python实现无痛修改第三方库源码的方法详解》很多时候,我们下载的第三方库是不会有需求不满足的情况,但也有极少的情况,第三方库没有兼顾到需求,本文将介绍几个修改源码的操作,大家可以根据需求进行选择... 目录需求不符合模拟示例 1. 修改源文件2. 继承修改3. 猴子补丁4. 追踪局部变量需求不符合很