16. Revit API: Family、FamilySymbol、FamilyInstance

前言

前面写着一直絮絮叨叨,感觉不好。想找些表情包来,写得好玩点,但找不到合适的,或者说耗时费力又不满意,而自个儿又做不来表情包,就算了。

其次呢,之前会把部分类成员给抄表列出来,写全了又长又啰嗦,自己都不愿看,挑着写又可能会落下点有用的,所以就不列了。

那么,就闲话少说,直接讲。


一、这三个是什么

Family(族),直接派生自Element,在Revit中,绝大部分图元都是族。墙、梁、柱等模型是族,长度、角度、直径等图纸标注也是族。当然也有不是族的,比如DirectShape,就单纯的只是模型。
按照编辑形式,族可分为系统族、内建族、可载入族3种。由于我对内建组不够了解,就不展开了,可自行去查阅。

FamilySymbol(族类型),是族的一部分。比如一扇门,可以通过调整参数改变其宽、高、门把手的位置。但只有几种规格的门是实际用到的,这样就可以预设一些参数。这种预设好的,就是族类型。一个族可以有很多种类型。
在这里插入图片描述

FamilyInstance(族实例),简单理解,就是族的实例。
但是呢,族实例这个类,特指可载入族(用户自己创建的族,体现为.rfa格式的文件)的实例。系统族的实例,就是WallCloumn这类由Revit内部定义与实现好的族。


二、它们如何获取

泛指的族实例的获取,可按照之前讲过的《Filter(过滤器)》进行。

族名称的获取,可以参照另一篇Revit获取元素的族名,或者直接采用以下代码。

// 扩展方法
public static string GetFamilyName(this Element element)
{Parameter parameter = element.GetParameter(BuiltInParameter.ELEM_FAMILY_PARAM); // GetParameter也是扩展方法,自带的返回是一个Liststring familyName = parameter.AsValueString(); return familyName;
}

族/族类型的获取,就要分情况了。族类型是绑定在族上的,所以获取到族,自然就可以拿到族类型了。

2.1. 可载入族-族与类型的获取

上面介绍到,FamilyInstance类特指可载入族的实例,同样的,Family类特指可载入族。FamilySymbol例外,系统组和可载入族都有。
因此,

第一种方式,便是直接使用类过滤器,过滤Family类
这种方式通常用于族的创建,比如我们要批量生成灯具,就可以通过这种方式检索到项目种已载入的灯族。

第二种方式,从FamilyInstance上拿到族。
族实例上,自然是包含了族信息的,这很合理,很自然就能想到。
但也有不自然的时候,等讲到Parameter的时候再细说。

从属性上获取

// ① 从属性种获取
var familySymbol = familyInstance.Symbol;
var family = familySymbol.Family;

需要注意的是,族实例上的名称,是类型名,而不是族名。这也是上面写获取元素族名方法的原因。

用方法获取。
这是通用的方法,无论是可载入族,或者是系统族,都可以使用,在下面 2.2 讲。

2.2. 系统族-族与类型的获取

我们注意到,Element上有俩方法:

  • GetTypeId():获取当前元素类型的ID,无类型则返回不可用ID。
  • GetValidTypes():获取当前元素的所有类型的ID,无则返回空集合。

看,在Element那篇,就没有讲这俩方法。

// ② 用方法获取var typeID = element.GetTypeId();var familySymbol = document.GetElement(typeID) as FamilySymbol;

至于系统族的获取,那就直接过滤呗。要墙就过滤Wall,要楼梯就过滤Stairs


三、作用、使用

从使用Revit的角度,族的作用就是让用户能够简单轻松的操作图元。而开发上呢,这几个类的作用就是让开发者能够对族、族实例进行调整,进行使用。

3.1. 族的载入与交互放置

使用交互的方式载入族,可以直接讲文件拖到Revit中。

而开发呢,则需要使用载入方法。

族的载入方法,在Document

// 载入族
bool loaded = document.LoadFamily(path);
// 其它重载
// public bool LoadFamily(string path,IFamilyLoadOptions familyLoadOptions,...);

这种直接载入的方式是不妥的,当项目中已经存在了同名族时,系统会进行提示。

Revit中,族不可同名。可载入族的名称,就是该族的文件名。

我们能不能默认对同名族进行替换呢?当然是可以的,这时需要实现IFamilyLoadOptions接口,并使用对应的LoadFamily方法。

// 加载行为
class FamilpathyLoadOptions_Overwrite : IFamilyLoadOptions
{bool IFamilyLoadOptions.OnFamilyFound(bool familyInUse, out bool overwriteParameterValues){overwriteParameterValues = true;  // 覆盖return true;}bool IFamilyLoadOptions.OnSharedFamilyFound(Family sharedFamily, bool familyInUse, out FamilySource source, out bool overwriteParameterValues){source = FamilySource.Project;overwriteParameterValues = true;return true;}
};

现在族已经载入了,那么放置呢?

UIDocument上,有以下方法,这样就可以交互式放置,点哪儿方哪儿。

uiDoc.PromptForFamilyInstancePlacement(familySymbol);

3.2. 族实例的创建

族的交互放置方式,一般是在开发族库类插件时用到。

而在要求批量生成的功能中,则需要使用代码来创建,也就是前面的随笔中多次提到的Creation

var creation = document.Create;  // 获取Creation实例
var instance = creation.NewFamilyInstance(setPoint, symbol, Autodesk.Revit.DB.Structure.StructuralType.NonStructural);

需要注意的是,族实例的创建方法,足足有12个重载。上面只是按照位置放置的方法,具体是需要自己去看看。

在这里插入图片描述

3.3. 族参数的设置

Revit族是可以由参数控制的,比如有一个门的族,可以通过设置其宽、高参数来改变规格。

流程:① 拿到族实例,② 拿到指定参数,③ 设置参数值。

这里涉及到Parameter了,简单讲一下使用。

[Autodesk.Revit.Attributes.Transaction(Autodesk.Revit.Attributes.TransactionMode.Manual)]
internal class FamilyInstanceCommand : IExternalCommand
{public Result Execute(ExternalCommandData commandData, ref string message, ElementSet elements){UIDocument uiDoc = commandData.Application.ActiveUIDocument;Document document = uiDoc.Document;Reference reference = uiDoc.Selection.PickObject(Autodesk.Revit.UI.Selection.ObjectType.Element);Element element = document.GetElement(reference);//ElementId typeID = element.GetTypeId();//FamilySymbol familySymbol = document.GetElement(typeID) as FamilySymbol;//TaskDialog.Show("Family", $"Family: {familySymbol.Name}");// 获取指定参数Parameter width = element.FindParameter("宽度");  // Nice3Points.Revit.ExtensionsParameter height = element.FindParameter("高度");if (width == null || height == null){TaskDialog.Show("Family Instance", "No width or height parameter found.");return Result.Failed;}// 修改参数值using (Transaction transaction = new Transaction(document)){transaction.Start("Change Family Instance Parameters");width.Set(1500d.FromMillimeters());  // Nice3Points.Revit.Extensionsheight.Set(2100d.FromMillimeters());transaction.Commit();}return Result.Succeeded;}
}

代码中有两处Nice3Points.Revit.Extensions的注释,这是一个三方库,提供了一些扩展方法。

第一处是找到参数,Revit本身也有查找参数查找参数方法,但返回的是列表。

第二处是单位转换,讲毫米转为Revit内部单位(英尺)。Revit也有单位转换相关的工具类UnitUtils

提示,可以使用插件RevitLookUp,方便查看元素的参数。

在这里插入图片描述

四、一些可能用到的东西

Family、FamilySymbol上的大部分属性方法继承自Element,而FamilyInsyance上,就有比较多属于自己的东西了。

这里还是看一下类成员。

  1. 变换(Transform)相关

    带有翻转、镜像、等含义的。
    如属性上的 CanFlipFacing、FacingFlipped、FacingOrientation、Mirrored…
    方法上的 flipFacing、flipHand,继承来的GetTransform。
    对于上述类成员的作用,请查看Revit Transform和镜像(翻转)问题。

  2. 几何(Geometry)相关

    带有Geometry、Profile之类字样的,多少与图元的几何有关。
    几何方面的,放到后面讲。

  3. 剪切相关

    注意到有数个带有Coping资源的方法,但其含义我不够了解。
    至于剪切,也放到后面讲。

  4. 结构相关


总结

这篇,讲了的与族相关的3个类,讲了族的获取,载入,创建和参数修改。

又提到了一些没有展开的东西,有 CreationParameterUnitTransformGeoemtryCut等。

既然Creation已经提了好多次了,那么就下一篇写吧。

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

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

相关文章

短视频矩阵系统多账号搭建技术源码(saas开发者技术独立搭建)

在构建云服务环境以部署虚拟机方面,以Amazon Web Services(AWS)为示例,需采购并配置适当数量的EC2实例以及相关网络设施。 接下来,根据业务需求,应创建多个社交媒体平台如抖音和快手的官方账户,…

基于springboot+mybatis学生管理系统

基于springbootmybatis学生管理系统 简介: 题目虽然是学生管理系统,但功能包含(学生,教师,管理员),项目基于springboot2.1.x实现的管理系统。 编译环境 : jdk 1.8 mysql 5.5 tomcat 7 框架 : springboot…

Postman使用教程【项目实战】

目录 引言软件下载及安装项目开发流程1. 创建项目2. 创建集合(理解为:功能模块)3. 设置环境变量,4. 创建请求5. 测试脚本6. 响应分析7. 共享与协作 结语 引言 Postman 是一款功能强大的 API 开发工具,它可以帮助开发者测试、开发和调试 API。…

org.springframework.boot.autoconfigure.EnableAutoConfiguration=XXXXX的作用是什么?

org.springframework.boot.autoconfigure.EnableAutoConfigurationXXXXXXX 这一配置项在 Spring Boot 项目中的作用如下: 自动配置类的指定: 这一配置将 EnableAutoConfiguration 设置为 cn.geek.javadatamanage.config.DataManageAutoConfiguration&…

解决Invalid or unsupported by client SCRAM mechanisms(dbeaver)

在用工具(dbeaver)链接Opengauss数据库的时候,报出标题的错误。原因为驱动不正确。 驱动下载地址:https://opengauss.org/zh/download/ 下载完的包 ,解压后,里面应该有两个jar 包,使用postgresql.jar dbe…

什么是CAP理论及应用场景,为什么只能进行3选2

在理论计算机科学中,CAP定理(CAP theorem),又被称作布鲁尔定理(Brewers theorem),它指出对于一个分布式计算系统来说,不可能同时满足以下三点: 1、 一致性(C…

计算机网络之广域网

广域网特点: 主要提供面向通信的服务,支持用户使用计算机进行远距离的信息交换。 覆盖范围广,通信的距离远,需要考虑的因素增多, 线路的冗余、媒体带宽的利用和差错处理问题。 由电信部门或公司负责组建、管理和维护,并向全社会…

拟合衰减振动模型,估算阻尼比和阻尼系数

拟合衰减振动模型,估算阻尼比和阻尼系数 flyfish 衰减振动模型 在自由振动系统中,阻尼振动可以用以下公式描述: x ( t ) x 0 e − ζ ω n t cos ⁡ ( ω d t ϕ ) x(t) x_0 e^{-\zeta \omega_n t} \cos(\omega_d t \phi) x(t)x0​e−…

一天搞定软件测试基础!——包含Web测试、App测试

以下👇是2024新版黑马程序员软件测试零基础入门到精通全套视频教程的所有笔记! 有一些缺点,就是我是在7月份的时候进行该课程学习的,所以网课老师准备的一些网盘资源都已经失去连接了,所以我无法在我的电脑里进行测试&…

【代码随想录】【算法训练营】【第64天】 [卡码117]软件构建 [卡码47]参加科学大会

前言 思路及算法思维,指路 代码随想录。 题目来自 卡码网。 day 64,周三,继续ding~ 题目详情 [卡码117] 软件构建 题目描述 卡码117 软件构建 解题思路 前提: 思路: 重点: 代码实现 C语言 [卡码…

错位情缘悬疑升级

✨🔥【错位情缘,悬疑升级!关芝芝与黄牡丹的惊世婚约】🔥✨在这个迷雾重重的剧场,一场前所未有的错位大戏正悄然上演!👀 你没看错,昔日兄弟的前女友关芝芝,竟摇身一变成了…

用Python玩转Excel的五大功能!

在日常的数据处理工作中,Excel无疑是一个强大的工具。然而,当数据量较大或需要自动化处理时,Python凭借其强大的库支持,如pandas和openpyxl,能够更高效地处理Excel文件。 本文将介绍Python中常用的五种Excel操作**&am…

单链表--续(C语言详细版)

2.6 在指定位置之前插入数据 // 在指定位置之前插入数据 void SLTInsert(SLTNode** pphead, SLTNode* pos, SLTDataType x); 分为两种情况:1. 插入的数据在链表中间;2. 插入的数据在链表的前面。 // 在指定位置之前插入数据 void SLTInsert(SLTNode** …

快团团团长如何获得物流查询码以及如何查询呢?

快团团团长如何获得物流查询码以及如何查询呢? 一、功能说明 团长可自行生成物流查询码,直接将码发给顾客,顾客扫码可查询自己订单的物流状态! 用户扫码后,会出现用户在该团长处下单的所有快递订单。团员可查看该订…

基于Booth乘法和Wallace树的乘法器优化思想

基于Booth乘法和Wallace树的快速乘法器 为了理解Booth乘法和Wallace数如何让乘法器变得更快: 先考虑不优化的8位乘法器实现,即8个16位数字累积共进行7次加法运算,可以认为一次16位加法用到16个全加器,则共需要112个全加器件&…

【Vscode】显示多个文件 打开多个文件时实现标签栏多行显示

Vscode显示多个文件&VSCode打开多个文件时实现标签栏多行显示 写在最前面一、解决打开文件的时候只显示一个tab的办法解决办法如下: 二、文件标签栏多行显示设置步骤: 🌈你好呀!我是 是Yu欸 🌌 2024每日百字篆刻时…

SpringBoot新手快速入门系列教程七:基于一个低配centoos服务器,如何通过宝塔面板部署一个SpringBoot项目

1,如何打包一个项目 通过IDEA自带的命令行,执行 ./gradlew clean build 2,检查生成的JAR文件 进入 build/libs 目录,你应该会看到一个类似 helloredis-0.0.1-SNAPSHOT.jar 的文件。 3:运行生成的JAR文件 你可以在…

C++的介绍与认识

目录 前言 1.什么是C 2.C的发展历史 3.C参考文档 4.C重要性 4.1C特点 4.2编程语言排行榜 4.3 C的应用领域 5.C学习指南 1. 基础知识 2. 面向对象编程(OOP) 3. 泛型编程 4. 标准库(STL) 结束语 前言 学习了C语言的知识…

Day06-角色管理-员工管理

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 1.编辑角色-进入行内编辑2.角色管理-行内编辑-数据缓存3.角色管理-编辑角色-确定取消4.角色管理-删除角色员工管理-页面结构6.员工管理-左侧树7.员工管理-选中首个节…

算法的复杂度

文章目录 一、算法的效率1、复杂度的概念2、复杂度的重要性 二、时间复杂度三、空间复杂度四、大O的渐进表示发五、计算复杂度案例1、计算Func1函数的复杂度2、计算Fun2的时间复杂度3、计算Func3的时间复杂度4、计算Func4的时间复杂度5、计算strchr的时间复杂度6、计算Func5的时…