5. Revit API: Application

news2025/1/11 9:54:05

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.coloradmin.cn/o/1859006.html

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

相关文章

Spring循环依赖问题——从源码画流程图

文章目录 关键代码相关知识为什么要使用二级缓存为什么要使用三级缓存只使用两个缓存的问题不能解决构造器循环依赖为什么多例bean不能解决循环依赖问题初始化后代理对象赋值给原始对象解决循环依赖SpringBoot开启循环依赖 循环依赖 在线流程图 关键代码 从缓存中查询getSingl…

鸿蒙开发系统基础能力:【@ohos.hiTraceChain (分布式跟踪)】

分布式跟踪 本模块提供了端侧业务流程调用链跟踪的打点能力,包括业务流程跟踪的启动、结束、信息埋点等能力。 说明: 本模块首批接口从API version 8开始支持。后续版本的新增接口,采用上角标单独标记接口的起始版本。 导入模块 import hi…

固特超声波清洗机怎么样?三大超声波清洗机美的、固特、希亦谁更好?

眼镜是我们日常生活中不可或缺的用具,但随着使用时间的增长,眼镜上的灰尘和污垢也会逐渐积累,传统的清洗方法往往难以彻底清洁。为了解决这一难题,超声波清洗机出现了!它利用超声波振动原理,可以轻松、快速…

群辉NAS中文件下载的三种方案

目录 一、迅雷套件 1、添加套件来源 2、安装套件 3、手机安装迅雷 二、qBittorrent套件 1、添加套件来源 2、改手工安装 3、更新后的问题 4、最后放弃DSM6 (1)上传文件手工安装 (2)添加套件来源 5、解决登陆报错 6、添加tracker 7、修改下载默认位置 8、手机…

【十一】【QT开发应用】模拟腾讯会议登录界面设计UI

ui 加入会议的样式表 QPushButton { /* 前景色 */ color:#0054E6; /* 背景色 */ background-color:rgb(255,255,255); /* 边框风格 */ border-style:outset; /* 边框宽度 */ border-width:0.5px; /* 边框颜色 */ border-color:gray; /* 边框倒角 */ border-radius…

python自动化测试之DDT数据驱动的实现代码

时隔已久,再次冒烟,自动化测试工作仍在继续,自动化测试中的数据驱动技术尤为重要,不然咋去实现数据分离呢,对吧,这里就简单介绍下与传统unittest自动化测试框架匹配的DDT数据驱动技术。 话不多说&#xff…

神经网络的编程基础

神经网络的编程基础 二分类 二分类是机器学习中的一种基本分类问题,其中每个样本被划分为两个类别中的一个,即正类或负类。这种分类问题在现实生活中有广泛的应用,例如判定邮件是否为垃圾邮件、判别某个人是否患病等。二分类模型根据样本的特…

Python高压电容导电体和水文椭圆微分

🎯要点 🎯二维热传导二阶偏微分方程 | 🎯调和函数和几何图曲率 | 🎯解潮汐波动方程 | 🎯解静止基态旋转球体流体运动函数 | 🎯水文空间插值 | 🎯流体流动模拟求解器 | 🎯随机算法解…

光伏半导体的种类

光照射半导体材料时,其电导率发生变化的实质是光生载流子的产生。在半导体中,价带中的电子受到一定能量的光子激发后,可以跃迁到导带,形成自由电子和空穴对,即光生载流子。这些光生载流子会增加半导体的导电能力&#…

NepnepxCATCTF Pwn-Chao

文章目录 参考类型混淆异常处理的栈回退机制虚表和类的恢复假想的程序结构逆向工程场景步骤解析 idabug检查找虚表strupsc_str()alloca异常逆向maindisplayupdatecreate 新东西exp和思路 参考 https://www.cnblogs.com/winmt/articles/17018284.html 类型混淆 关于C中由虚函…

【乐吾乐2D可视化组态编辑器】图表动态显示

1. 添加数据 乐吾乐2D可视化组态编辑器地址:https://2d.le5le.com/ 图表动态展示是指一个图表图元的数据属性(一般是dataY)绑定多个变量,建立通信后数据动态变化展示。 官网默认Echarts图表拖拽到画布中是已经添加了图元的da…

【SpringCloud-Seata源码分析3】

文章目录 事务的提交客户端提交流程服务端提交流程客户端删除undo_log 事务回滚客户端事务回滚服务端回滚事务 事务的提交 前面两篇我们分析了seata的TC初始化和TM,RM初始化,并且事务准备阶段源码及业务Sql执行,下面我们分析事务的提交源码。 客户端提…

【面试题】等保(等级保护)的工作流程

等保(等级保护)的工作流程主要包括以下几个步骤,以下将详细分点介绍: 系统定级: 确定定级对象:根据《信息系统等级保护管理办法》和《信息系统等级保护定级指南》的要求,确定需要进行等级保护的…

Charles抓包工具系列文章(二)-- Repeat 回放http请求

一、什么是http请求回放 当我们对客户端进行抓包,经常会想要重试http请求,或者改写原有部分进行重新请求,都需要用到回放http请求。 还有一种场景是压力测试,对一个请求进行重复请求多少次,并加上适当的并发度。 这里…

2024年6月22日,雨中骑行谷仓坝游后记。 (校长骑行撰稿)

在这个快节奏的时代,生活中总是充满了无尽的压力和喧嚣。然而,骑行就像一股清流,给人们带来片刻的宁静和思考,是一种独特的释放方式。它不仅是一种锻炼,更是一种探索世界、理解生活的方式。这次,我们校长骑…

[职场] 线上面试的准备工作 #知识分享#经验分享#媒体

线上面试的准备工作 面对求职中的面试,应届毕业生该做些什么准备呢?在这里,向各位分享面试前做好预案不慌张几点准备。现在许多面试是通过线上形式进行的。对于求职者来说,要做好两手准备。在这里,重点与大家分享线上面…

pyhon模块以及常用的第三方模块

import my_info as info print(info.name) info.show()from my_info import * print(name) show() pyhon中包的导入 import admin.my_admin as ad # 包名.模块名 admin是包名,my_admin是模块名print(ad.name) print(ad.info())from admin import my_admin as ad # …

【可控图像生成系列论文(三)】北大 Context-Aware Unsupervised Text Stylization论文解读1

【可控图像生成系列论文(一)】 简要介绍了论文的整体流程和方法;【可控图像生成系列论文(二)】则将就整体方法、模型结构、训练数据和纹理迁移进行了更详细的介绍。 本篇将介绍来自 ACM MM 2018 的一篇字体风格化的可控…

【43 Pandas+Pyecharts | 京东某商品销量数据分析可视化】

文章目录 🏳️‍🌈 1. 导入模块🏳️‍🌈 2. Pandas数据处理2.1 读取数据2.2 查看数据信息2.3 查看数据描述信息 🏳️‍🌈 3. Pyecharts数据可视化3.1 销量(瓶)地图分布3.2 每月销量(瓶)3.3 男性女性购买数量…

《看不影子的少年》一部探讨偏见与接纳的电视剧❗

《看不见影子的少年》这部电视剧以其独特的视角和深刻的主题 给我留下了深刻的印象。该剧讲述了一位与众不同的少年 他无法在阳光下留下影子,象征着他在社会中的孤独与不被理解 观看过程中,可以感受到少年内心的挣扎与渴望 他渴望被接纳,渴…