C#开发BIMFACE系列16 服务端API之获取模型数据1:查询满足条件的构件ID列表

源文件/模型转换完成之后,可以获取模型的具体数据。本篇介绍根据文件ID查询满足条件的构件ID列表。
请求地址:GET https://api.bimface.com/data/v2/files/{fileId}/elementIds
说明:根据六个维度(专业,系统类型,楼层,构件类型,族,族类型)获取对应的构件ID列表,任何维度都是可选的。
构件ID分页查询相关请参考这里
同时,也支持根据空间关系从房间计算出房间内的构件ID列表
构件与房间空间关系计算相关请参考这里
参数:
请求 path(示例):https://api.bimface.com/data/v2/files/1211223382064960/elementIds
请求 header(示例):"Authorization: Bearer dc671840-bacc-4dc5-a134-97c1918d664b"
HTTP响应示例(200):
{ "code": "success", "message": null, "data": [ "1107237", "1109326", "1107234", "1109327", "1107235", "1107239", "1109329", "1107236", "1109325", "1107238", "1109328" ] }
C#实现方法:
1 /// <summary> 2 /// 查询满足条件的构件ID列表 3 /// </summary> 4 /// <param name="accessToken">令牌</param> 5 /// <param name="fileId">文件ID</param> 6 /// <param name="request">请求参数对象</param> 7 /// <returns></returns> 8 public virtual FileElementsGetResponse GetFileElements(string accessToken, string fileId, FileElementsGetRequest request = null) 9 { 10 // GET https://api.bimface.com/data/v2/files/{fileId}/elementIds 11 string url = string.Format(BimfaceConstants.API_HOST + "/data/v2/files/{0}/elementIds", fileId); 12 13 BimFaceHttpHeaders headers = new BimFaceHttpHeaders(); 14 headers.AddOAuth2Header(accessToken); 15 16 string data = string.Empty; 17 if (request != null) 18 { 19 data = request.SerializeToJson(); 20 } 21 22 try 23 { 24 FileElementsGetResponse response; 25 26 HttpManager httpManager = new HttpManager(headers); 27 HttpResult httpResult = httpManager.Get(url, data); 28 if (httpResult.Status == HttpResult.STATUS_SUCCESS) 29 { 30 response = httpResult.Text.DeserializeJsonToObject<FileElementsGetResponse>(); 31 } 32 else 33 { 34 response = new FileElementsGetResponse 35 { 36 Message = httpResult.RefText 37 }; 38 } 39 40 return response; 41 } 42 catch (Exception ex) 43 { 44 throw new Exception("[查询满足条件的构件ID列表]发生异常!", ex); 45 } 46 }
其中调用到的 httpManager.Get() 方法,请参考《C# HTTP系列》
封装的其他请求参数类 FileElementsGetRequest
1 /// <summary> 2 /// 查询满足条件的构件ID列表请求参数类 3 /// </summary> 4 [Serializable] 5 public class FileElementsGetRequest 6 { 7 public FileElementsGetRequest() 8 { 9 CategoryId = null; 10 Family = null; 11 FamilyType = null; 12 Floor = null; 13 PaginationContextId = null; 14 PaginationNo = null; 15 PaginationSize = null; 16 RoomId = null; 17 RoomToleranceXY = null; 18 RoomToleranceZ = null; 19 Specialty = null; 20 SystemType = null; 21 } 22 23 ///// <summary> 24 ///// 【必填】代表该单模型的文件ID 25 ///// </summary> 26 //[JsonProperty("fileId")] 27 //public long FileId { get; set; } 28 29 /// <summary> 30 /// 【非必填】筛选条件构件类型id 31 /// </summary> 32 [JsonProperty("categoryId",NullValueHandling = NullValueHandling.Ignore)] 33 public string CategoryId { get; set; } 34 35 /// <summary> 36 /// 【非必填】筛选条件族 37 /// </summary> 38 [JsonProperty("family", NullValueHandling = NullValueHandling.Ignore)] 39 public string Family { get; set; } 40 41 /// <summary> 42 /// 【非必填】筛选条件族类型 43 /// </summary> 44 [JsonProperty("familyType", NullValueHandling = NullValueHandling.Ignore)] 45 public string FamilyType { get; set; } 46 47 /// <summary> 48 /// 【非必填】筛选条件楼层 49 /// </summary> 50 [JsonProperty("floor", NullValueHandling = NullValueHandling.Ignore)] 51 public string Floor { get; set; } 52 53 /// <summary> 54 /// 【非必填】根据paginationContextId返回构件ID列表 55 /// </summary> 56 [JsonProperty("paginationContextId", NullValueHandling = NullValueHandling.Ignore)] 57 public string PaginationContextId { get; set; } 58 59 /// <summary> 60 /// 【非必填】返回结果中paginationNo对应的页码构件ID项 61 /// </summary> 62 [JsonProperty("paginationNo", NullValueHandling = NullValueHandling.Ignore)] 63 public int? PaginationNo { get; set; } 64 65 /// <summary> 66 /// 【非必填】返回结果按照paginationSize分页 67 /// </summary> 68 [JsonProperty("paginationSize", NullValueHandling = NullValueHandling.Ignore)] 69 public int? PaginationSize { get; set; } 70 71 /// <summary> 72 /// 【非必填】筛选条件房间id 73 /// </summary> 74 [JsonProperty("roomId", NullValueHandling = NullValueHandling.Ignore)] 75 public string RoomId { get; set; } 76 77 /// <summary> 78 /// 【非必填】XY坐标轴方向对构件的筛选容忍度 79 /// </summary> 80 [JsonProperty("roomToleranceXY", NullValueHandling = NullValueHandling.Ignore)] 81 public RoomTolerance? RoomToleranceXY { get; set; } 82 83 /// <summary> 84 /// 【非必填】Z坐标轴方向对构件的筛选容忍度 85 /// </summary> 86 [JsonProperty("roomToleranceZ", NullValueHandling = NullValueHandling.Ignore)] 87 public RoomTolerance? RoomToleranceZ { get; set; } 88 89 /// <summary> 90 /// 【非必填】筛选条件专业 91 /// </summary> 92 [JsonProperty("specialty", NullValueHandling = NullValueHandling.Ignore)] 93 public string Specialty { get; set; } 94 95 /// <summary> 96 /// 【非必填】筛选条件系统类型 97 /// </summary> 98 [JsonProperty("systemType", NullValueHandling = NullValueHandling.Ignore)] 99 public string SystemType { get; set; } 100 }
1 /// <summary> 2 /// 坐标轴方向对构件的筛选容忍度 3 /// </summary> 4 public enum RoomTolerance 5 { 6 STRICT, 7 8 ORDINARY, 9 10 LENIENT 11 }
参数都是可选的,如果不设置,则默认不添加到请求中。
在BIMFACE的控制台中可以看到我们上传的文件列表,共计2个文件。模型状态均为转换成功。
以“01_BIMFACE示例文件-Revit模型.rvt”为例查询其构建ID列表

查看结果中返回了构建ID列表。
如果使用 .dwg 二维文件进行测试则返回一下信息:unsupported operation:[please upgrade this databag to support specialty tree]
查询满足条件的构件ID列表 ,只对三维模型适用。二维图纸没有目录树。
测试代码如下:
// 查询满足条件的构件ID列表 protected void btnGetFileElements_Click(object sender, EventArgs e) { FileConvertApi api = new FileConvertApi(); FileElementsGetResponse response = api.GetFileElements(txtAccessToken.Text, txtFileID.Text); txtResult.Text = response.Code.ToString2() + Environment.NewLine + response.Message.ToString2() + Environment.NewLine + response.Data.ToStringWith(","); }
查询构建ID列表返回类 FileElementsGetResponse
/// <summary> /// 查询满足条件的构件ID列表返回的结果类 /// </summary> public class FileElementsGetResponse : GeneralResponse<List<string>> { }

成在管理,败在经验;嬴在选择,输在不学! 贵在坚持!
个人作品
BIMFace.SDK.NET
开源地址:https://gitee.com/NAlps/BIMFace.SDK
系列博客:https://www.cnblogs.com/SavionZhang/p/11424431.html
系列视频:https://www.cnblogs.com/SavionZhang/p/14258393.html
技术栈
1、AI、DeepSeek、MiniMax、通义千问
2、Visual Studio、.NET Core/.NET、MVC、Web API、RESTful API、gRPC、SignalR、Java、Python
3、jQuery、Vue.js、Bootstrap、ElementUI
4、数据库:分库分表、读写分离、SQLServer、MySQL、PostgreSQL、Redis、MongoDB、ElasticSearch、达梦DM、GaussDB、OpenGauss
5、架构:DDD、ABP、SpringBoot、jFinal
6、环境:跨平台、Windows、Linux
7、移动App:Android、IOS、HarmonyOS、微信小程序、钉钉、uni-app、MAUI
8、分布式、高并发、云原生、微服务、Docker、CI/CD、DevOps、K8S;Dapr、RabbitMQ、Kafka、RPC、Elasticsearch
欢迎关注作者头条号 张传宁IT讲堂,获取更多IT文章、视频等优质内容。
出处:www.cnblogs.com/SavionZhang
作者:张传宁 技术顾问、培训讲师、微软MCP、系统架构设计师、系统集成项目管理工程师、科技部创新工程师。
专注于企业级通用开发平台、工作流引擎、自动化项目(代码)生成器、SOA 、DDD、 云原生(Docker、微服务、DevOps、CI/CD);PDF、CAD、BIM 审图等研究与应用。
多次参与电子政务、图书教育、生产制造等企业级大型项目研发与管理工作。
熟悉中小企业软件开发过程:可行调研、需求分析、架构设计、编码测试、实施部署、项目管理。通过技术与管理帮助中小企业实现互联网转型升级全流程解决方案。
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
如有问题,可以通过邮件905442693@qq.com联系。共同交流、互相学习。
如果您觉得文章对您有帮助,请点击文章右下角【推荐】。您的鼓励是作者持续创作的最大动力!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?