5. Revit API: Application

5. Revit API: Application

前言

上一篇中,讲到了UI篇的Ribbon(界面),并提到要创建 RibbonPanel,需要使用UIControlledApplication.CreateRibbonPanel(..)方法,还在结尾说到要写“UI”开头的那些个类,本来呢是这么想的,但写的时候,发现单独写UI类不好,与它们关联的类有不少呢,所以想想,还是把相关的内容都放一块儿,一起写了得了。


Application 相关类

Application 的翻译是“应用/应用程序”,也就是APP的简写。在程序中,一般与配置、操作、框架之类的相关。在Revit中,就是①本身表示某类应用,②提供某类操作的入口,并且都定义了不少事件。

这一篇标题是Application,与之直接关联的类或接口有哪些呢?我整了个图,一起看看。

IExternalApplication(外部应用)接口 -> 其方法提供了UIControlledApplication参数 -> 该参数有属性ControlledApplication -> 又能从该属性中拿到Creation命名空间下的另一个Application类。

IEcternalCommand(外部命令)部分的图也这样看下去。

根据它们之间的关联,这一篇,我们就讲一讲这4个:

  • UIApplicationUIControlledApplication
  • UIxxxXXX
  • ApplicationControlledApplication
  • Autodesk.Revit.Creation.Application:这个先简单提一下,后面专门写Creation相关的东西。

在这里插入图片描述

一、UIApplication 与 UIControlledApplication

UIApplicationUIControlledApplication 都是 Autodesk.Revit.UI 命名空间下的类,也都是直接派生自 System.Object ,尽管它们之间**共享**大部分属性、方法和事件,但它们之间并不存在继承关系,我们带着问题来了解它们。

1.1. 是做什么的

UIApplication 和 UIControlledApplication 都是用来操作界面的,它们之间共享了大部分属性、方法和事件,可以当作是同一个来使用。

我们来看看方法:

MethodsDescriptionUIAppUIC..App
CanPostCommand
PostCommand
主动触发一些命令
CreateAddInCommandBinding
RemoveAddInCommandBinding
LoadAddIn
重绑定按钮和外部命令
加载外部命令
CreateRibbonPanel x3
CreateRibbonTab
GetRibbonPanels x3
创建/查询工具栏处的界面。
x3表示有3个重载
DoDragDrop x2文件拖入Revit时会执行的操作。Revit有默认行为
GetDockablePane
RegisterDockablePane
获取/注册 可停靠界面DockablePane
OpenAndActivateDocument x2更改活动文档

可以看到,UIApplication只多了文件拖入和更改活动文档这两类方法。

属性上,提供一些指向具体操作的实例, 如下图。

在这里插入图片描述

而事件呢,则是完全一样。

从事件上看,UIApplicationUIControlledApplication的管理范围,基本就限定在展示上(文档操作之外)。

结合方法,基本就是一些“准备/前置”工作。

EventsDescription
ApplicationClosing应用关闭时触发
DialogBoxShowing
DisplayingOptionsDialog
对话框、对话选项
DockableFrameFocusChanged
DockableFrameVisibilityChanged
可停靠界面 聚焦/显影变化
Idling空闲事件
ViewActivated
ViewActivating
视图切换
FabricationPartBrowserChanged
TransferredProjectStandards
TransferringProjectStandards
不看

1.2. 差异与产生原因

最直接的导致差异的原因,应该是这两者的来源不同吧。

UIControlledApplication是实现外部应用接口时,由方法OnStartup/OnShutdown提供,此时Revit刚刚启动,未打开任何Revit项目。

UIApplication 主要是实现外部命令接口时,由方法Execute(ExternalCommandData..)提供,此时【已打开】了Revit项目。

从这儿,我们也就理解了,为什么方法和属性略有差异,而事件则完全相同了。

比如 UIApplication 多出的那几个方法,总得Revit打开了,能交互了,才能拖拽文件进去,才有视图能切换嘞。

注:【已打开】
启动Revit后停在欢迎界面,没有打开具体的项目呢,此时插件的不可用的。我就是要点点试试怎么办?上一篇提到的按钮的AvailabilityClassName属性,可以改变按钮可用状态。效果嘛,没试过,猜测拿文档会报错。


二、UIApplication 与 Application

在上面,我们已经知道,UIApplication 持有 Application 属性,因此我们可以从前者对象获取到后者的实例。而作为贡献了大部分方法、属性、事件的UIControlledApplication 与 ControlledApplication 显然也是类似的,只不过多提供了几个实例(上面的属性图)。

它们之间的关系,似乎仅此而已。真的仅此而已。

那么,意义呢?

UIControlledApplication 提供 ControlledApplication的入口,UIApplication 提供 Application 的入口,两个UI类本身对同一事物进行操作。

(UI)ControlledApplication 到 (UI)Application 基本就提供一个实例.

类似的还有UIDocument与Document。

虽然名称类似,功能类似,但又如上面 1.1 里说的俩UI类范围被限定到展示相关,而不带UI的显然就是对文档,对Revit项目的操作了。

逻辑清晰,结构分明,就是意义了。

2.1. 创建一个UIApplication?

UIApplication 存在一个接收 Application 的构造函数,那么,我们能够创建出一个UIApplication吗?

public Result Execute(ExternalCommandData commandData, ref string message, ElementSet elements)
{UIApplication uiApp = new UIApplication(commandData.Application.Application);TaskDialog.Show("UIAPP", $"{uiApp.LoadedApplications.Size}");return Result.Succeeded;
}

显然是可以的,但这又做的目的是啥呢。

P.S. 在Revit2016以及更早,还有一种错误的创建方式。

// 该构造函数于2017版本移除,此时会报错
Autodesk.Revit.ApplicationServices.Application app = new Autodesk.Revit.ApplicationServices.Application();
Autodesk.Revit.UI.UIApplication uiApp = new Autodesk.Revit.UI.UIApplication(app);
TaskDialog.Show("UIAPP", $"{uiApp.LoadedApplications.Size}");

三、Application 与 ControlledApplication

ApplicationControlledApplication 都是 Autodesk.Revit.ApplicationServices 命名空间下的类,该命名空间下就这2个类,还有2枚举,都是没啥用的,一个显示当前Revit的语言(LanguageType ),一个表示当前Revit产品分类(ProductType )。

同带UI的,这俩之间有相当一部分属性、方法、事件相同。

与UI不同的是,这里就涉及到项目、文档的修改了,大部分事件与此有关。

P.S. 类成员有点多,建议直接复制,丢给GPT,让它解释。

3.1. ControlledApplication

ControlledApplication 成员较少,除了事件较为全面要看看,方法/属性上值得注意的就2点:

  • 共享属性
  • 失败处理程序

讲到共享属性,就得讲可扩展存储了;讲失败处理程序,就得提那些个警告/错误 的触发与处理了。后面再说、

以我这摸鱼写的样子,什么时候是个头哇(⓿_⓿)

话说今天法环DLC发售了,传火传火,赐福赐福!!

事件

事件也简单,扫一眼就那么几类:Revit程序初始化时,文档的增删改、开关存,打印前后,文件/族/链接资源的导入导出,失败通知,还有其它几个杂鱼,无了,就这么简单。

还有上面需要注意的吗,我看看…没了,就这些。

3.2. Application

比起ControlledApp多了不少,定睛一看:

  • 方法上:多了创建族文档,创建文档,打开IFC文档,和其它看起来没啥用的
  • 属性上:Documents,Create,其它的太长不看
  • 事件上:视图导出(ed/ing),共享状态变更,有啥用?不知道,没啥用。

啪啪啪,鼓掌,学会了,下一个。

四、Autodesk.Revit.Creation.Application

看Application看得我脑壳疼了都,这又是个啥玩意儿?

哦,一个用于创建 其它对象实例 的这么个类,没有构造函数,从UIApplication.Application.Creat中拿到。里头全是Newxxx方法。

那么,都New了些上面东西呢,好像看不懂唉,不知道干啥用的。

这就对了,开发时,某些方法需要奇奇怪怪的参数,这些个参数又没有构造函数时,说不准就可以在这里New出来。

好了,我们发现Creation下也没几个类呐、

在这里插入图片描述


结尾

UI都还没写完,下篇写啥,Events总结要不要来一个,Creation就一点点也想先写了,UI上还有预览界面和可停靠界面,AdWindows.dll往后稍稍。

还是写UI吧,就一丢丢了

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/31854.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

碳钢酸洗线送酸槽蒸汽冷凝水PH计测量装置改进方法

碳钢酸洗线送酸槽蒸汽冷凝水PH计测量装置改进方法 一、项目提出前状况 1)立项背景 轧钢退火酸洗生产线的酸洗过程需要使用大量的硫酸、盐酸、硝酸、氢氟酸等酸液对钢带的表面进行清洗,酸洗过后产生较多的酸洗废水,酸洗废水需要经过处理达到污水排放标准后才能排放。其中酸…

【linux】内核源码TCP->IP->L2层函数调用继续摸索中

日志打印的时候,把行数也打印了: 登录 - Gitee.comhttps://gitee.com/r77683962/linux-6.9.0/commit/b847489a9910f68b9581fd8788807c697c82cdbd 上回基于应用层wget操作找到TCP调用的一些接口,并且已经到IP层的一些接口,当前基…

昇思25天学习打卡营第3天|数据集Dataset

一、简介: 数据是深度学习的基础,高质量的数据输入将在整个深度神经网络中起到积极作用。有一种说法是模型最终训练的结果,10%受到算法影响,剩下的90%都是由训练的数据质量决定。(doge) MindSpore提供基于…

Docker常用操作和命令

文章目录 1、卸载旧版本 2、yum安装Docker CE(社区版) 3、添加镜像加速器 4、docker --version 查看docker版本 5、docker info 或 docker system info 显示 Docker 系统的详细信息,包括容器、镜像、网络等 6、docker search 搜索镜像 …

仙讯畅通无阻:探索MQ阵法的强大功能

MQ起源 IBM MQ:IBM MQ是IBM推出的一系列消息导向中间件产品,最初在1993年12月发布。它最初被称为MQSeries,2002年更名为WebSphere MQ,以加入WebSphere产品系列。2014年4月,它被重新命名为IBM MQ。Apache ActiveMQ&…

永辉超市:胖东来爆改,成色几何?

单日业绩暴涨14倍。来,看看,这是被胖东来爆改后重新开业后的门店, 不出意外的流量爆炸。胖东来爆改,真是解决实体商超困境的灵丹妙药吗? 今天我们聊聊——永辉超市 最近两年实体商超日子都不好过,去年13家…

cron.timezone

系统 date 数据库 show timezone插件 show cron.timezonealter system set cron.timezonePRC;show cron.timezone

【odoo】常用的基本视图类型

概要 在Odoo中,有几种基本视图类型,每种视图类型用于不同的目的和场景。这些视图类型包括表单视图(form view)、树视图(tree view)、看板视图(kanban view)、图表视图(gr…

研究人员描述了如何判断ChatGPT是否在虚构

研究人员描述了如何判断ChatGPT是否在虚构 这是世界上最不为人知的秘密之一,大型语言模型对查询给出了明显错误的答案,并自信地这样做,与它们正确的时候没有区别。这有很多原因。人工智能可能已经接受了错误信息的训练;答案可能需要从LLM无法…

Flutter【组件】富文本组件

简介 flutter 富文本组件。 github地址: https://github.com/ThinkerJack/jac_uikit pub地址:https://pub.dev/packages/jac_uikit 使用方式 运行 flutter pub add jac_uikit组件文档 使用方式: HighlightedTextWidget.builder(text: &…

SpringMVC的使用

SpringMVC详情 RequestMapping("/hello") 负责用户的请求路径与后台服务器之间的映射关系 如果请求路径不匹配,则用户报错404 ResponseBody 作用: 将服务器的返回值转化为JSON. 如果服务器返回的是String类型,则按照自身返回. 新增: post请求类型 PostMapping("…

Java 从零开始写一个简单的图书管理系统

了解一下 先来了解要实现一个怎样的图书管理系统 从中可以看到有操作的 使用者 和 不同 的 功能 而不同的使用者有不同的 菜单 那要如何实现呢? 请继续看下去 如何实现 首先了解我们 需要什么 图书系统需要 书,放书的 书架 ,用户 中有 管…

大数据与java哪个好找工作?这篇文章帮你做选择!

大数据与java哪个好找工作?这篇文章帮你做选择! 还在为选择Java开发还是Java大数据而头疼吗?别担心,本文将从就业前景、学习方向、学习内容以及薪资待遇四个方面,为你揭开Java和Java大数据的神秘面纱,帮你做…

【STM32】时钟树系统

1.时钟树简介 1.1五个时钟源 LSI是低速内部时钟,RC振荡器,频率为32kHz左右。供独立看门狗和自动唤醒单元使用。 LSE是低速外部时钟,接频率为32.768kHz的石英晶体。这个主要是RTC的时钟源。 HSE是高速外部时钟,可接石英*/陶瓷谐振…

Webstorm vue项目@路径不能跳转到对应资源,提示Cannot find declaration to go to

Webstorm vue项目路径不能跳转到对应资源,提示Cannot find declaration to go to 我们 ctrl加鼠标左键点击方法会失效,看了网上很多教程在说需要在此处配置一下webpack.config.js的文件路径,而且指向了node_modules\vue\cli-service\webpack.config.js 我…

外贸SEO工具有哪些推荐?

"我们作为一个专业的Google SEO团队,比较推荐一下几个适合外贸SEO的工具。Ahrefs 是一个非常强大的工具,可以帮助你深入分析竞争对手的表现,找到有潜力的关键词,还可以监控你的网站链接状况。另外,SEMrush 也很不…

Android基础到进阶UI祖父级 ViewGroup介绍+实用

1.创建CustomLayout继承ViewGroup /** 编写自定义ViewGroup的示例。 */ public class CustomLayout extends ViewGroup { // private int childHorizontalSpace 20; // private int childVerticalSpace 20; private int childHorizontalSpace; private int childVert…

Android企业级实战-界面篇-5

3.colors.xml文件内容(此案例可用) #ffb2b2b2 #ff14c4bc color/jimeng_text_tertiary_light color/jimeng_green_light color/jimeng_background_secondary_light color/jimeng_background_secondary_light #7f4eb7ba 4.strings.xml文件内容&…

内容安全复习 5 - 深在线社交网络分析与舆情监测

文章目录 在线社交网络分析什么是在线社交网络什么是在线社交网络分析社交网络信息传播基本模型影响力模型传染模型影响力计算公式 网络舆情监测网络舆情概述网络舆情监测系统 在线社交网络分析 什么是在线社交网络 在线社交网络是一种在信息网络上由社会个体集合及个体之间的…