C#开发BIMFACE系列17 服务端API之获取模型数据2:获取构件材质列表
在上一篇《C#开发BIMFACE系列16 服务端API之获取模型数据1:查询满足条件的构件ID列表》中介绍了获取单文件(模型)的所有构建ID列表。每个构建由多种材质组成,本文介绍获取单个构建ID的材质列表。
请求地址:GET https://api.bimface.com/data/v2/files/{fileId}/elements/{elementId}/materials
说明:根据单个构建ID获取其所有材质
参数:

请求 path(示例):https://api.bimface.com/data/v2/files/1211223382064960/elements/618987/materials
请求 header(示例):"Authorization: Bearer dc671840-bacc-4dc5-a134-97c1918d664b"
HTTP响应示例(200):
{
"code" : "success",
"data" : [ {
"id" : "",
"name" : "METAL_(229,80,30)Steel",
"parameters" : [ {
"group" : "dimension",
"items" : [ {
"code" : "perimeter",
"extension" : "object",
"key" : "perimeter",
"orderNumber" : ,
"unit" : "mm",
"value" : ,
"valueType" :
} ]
} ]
} ],
"message" : ""
}
该响应结果的结构比较复杂,封装成C#实体类 SingleModelSingleElementMaterials 如下:
/// <summary>
/// 获取单个模型单个构件的材质列表返回的结果类
/// </summary>
public class SingleModelSingleElementMaterials : GeneralResponse<List<MaterialInfo>>
{ }
public class MaterialInfo
{
[JsonProperty("id")]
public string Id { get; set; } [JsonProperty("name")]
public string Name { get; set; } [JsonProperty("parameters")]
public PropertyGroup[] Parameters { get; set; } /// <summary>返回表示当前对象的字符串。</summary>
/// <returns>表示当前对象的字符串。</returns>
public override string ToString()
{
StringBuilder sb = new StringBuilder();
if (Parameters != null && Parameters.Length > )
{
foreach (var param in Parameters)
{
sb.AppendLine(param.ToString());
}
} return string.Format("[id={0}, name={1}, parameters={2}]",
Id, Name, sb);
}
}
public class PropertyGroup
{
[JsonProperty("group")]
public string Group { get; set; } [JsonProperty("items")]
public PropertyItem[] Items { get; set; } /// <summary>返回表示当前对象的字符串。</summary>
/// <returns>表示当前对象的字符串。</returns>
public override string ToString()
{
StringBuilder sb = new StringBuilder();
if (Items != null && Items.Length > )
{
foreach (var item in Items)
{
sb.AppendLine(item.ToString());
}
} return string.Format("[group={0}, items={1}]",
Group, sb);
}
}
public class PropertyItem
{
[JsonProperty("code")]
public string Code { get; set; } [JsonProperty("extension")]
public object Extension { get; set; } [JsonProperty("key")]
public string Key { get; set; } [JsonProperty("orderNumber")]
public int? OrderNumber { get; set; } [JsonProperty("unit")]
public string Unit { get; set; } [JsonProperty("value")]
public object Value { get; set; } [JsonProperty("valueType")]
public int? ValueType { get; set; } /// <summary>返回表示当前对象的字符串。</summary>
/// <returns>表示当前对象的字符串。</returns>
public override string ToString()
{
return string.Format("[code={0}, extension={1}, key={2}, orderNumber={3},unit={4},value={5},valueType={6}]",
Code, Extension, Key, OrderNumber, Unit, Value, ValueType);
}
}
C#实现方法:
/// <summary>
/// 获取构件材质列表
/// </summary>
/// <param name="accessToken">令牌</param>
/// <param name="fileId">【必填】代表该单模型的文件ID</param>
/// <param name="elementId">【必填】代表该单模型的构件ID</param>
/// <returns></returns>
public virtual SingleModelSingleElementMaterials GetSingleModelSingleElementMaterials(string accessToken, long fileId,string elementId)
{
// GET https://api.bimface.com/data/v2/files/{fileId}/elements/{elementId}/materials
string url = string.Format(BimfaceConstants.API_HOST + "/data/v2/files/{0}/elements/{1}/materials", fileId, elementId); BimFaceHttpHeaders headers = new BimFaceHttpHeaders();
headers.AddOAuth2Header(accessToken); try
{
SingleModelSingleElementMaterials response; HttpManager httpManager = new HttpManager(headers);
HttpResult httpResult = httpManager.Get(url);
if (httpResult.Status == HttpResult.STATUS_SUCCESS)
{
response = httpResult.Text.DeserializeJsonToObject<SingleModelSingleElementMaterials>();
}
else
{
response = new SingleModelSingleElementMaterials
{
Message = httpResult.RefText
};
} return response;
}
catch (Exception ex)
{
throw new Exception("[获取构件材质列表]发生异常!", ex);
}
}
其中调用到的 httpManager.Get() 方法,请参考《C# HTTP系列》
在BIMFACE的控制台中可以看到我们上传的文件列表,共计2个文件。模型状态均为转换成功。

以“01_BIMFACE示例文件-Revit模型.rvt”为例来测试。

完整的材质列表为:
[id=, name=金属 - 铝, parameters=[group=标识数据, items=[code=, extension=, key=型号, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=成本, orderNumber=,unit=,value=0.00,valueType=]
[code=, extension=, key=URL, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=图像, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=注释, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=注释记号, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=标记, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=制造商, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=说明, orderNumber=,unit=,value=,valueType=]
]
[group=材质和装饰, items=[code=, extension=, key=名称, orderNumber=,unit=,value=金属 - 铝,valueType=]
[code=, extension=, key=高光, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=辉光, orderNumber=,unit=,value=False,valueType=]
[code=, extension=, key=平滑度, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=透明度, orderNumber=,unit=,value=,valueType=]
]
]
更换其他的构建ID,再次查询

完整的材质列表为:
[id=, name=混凝土砌块, parameters=[group=标识数据, items=[code=, extension=, key=型号, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=成本, orderNumber=,unit=,value=0.00,valueType=]
[code=, extension=, key=URL, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=图像, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=注释, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=注释记号, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=标记, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=制造商, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=说明, orderNumber=,unit=,value=混凝土砌块,valueType=]
]
[group=材质和装饰, items=[code=, extension=, key=剪变模量 X, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=子类, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=名称, orderNumber=,unit=,value=混凝土砌块,valueType=]
[code=, extension=, key=抗压强度, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=弹性模量 Y, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=类别, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=剪变模量 Z, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=弹性模量 Z, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=轻质, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=剪变模量 Y, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=抗剪强度折减系数, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=热膨胀系数 X, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=热膨胀系数 Y, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=热膨胀系数 Z, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=高光, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=辉光, orderNumber=,unit=,value=False,valueType=]
[code=, extension=, key=弹性模量 X, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=平滑度, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=表现, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=材质类型, orderNumber=,unit=,value=混凝土,valueType=]
[code=, extension=, key=透明度, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=泊松比 Z, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=泊松比 Y, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=泊松比 X, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=容重, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=阻尼比, orderNumber=,unit=,value=,valueType=]
]
],[id=, name=松散-石膏板, parameters=[group=标识数据, items=[code=, extension=, key=型号, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=成本, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=URL, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=图像, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=注释, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=注释记号, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=标记, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=制造商, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=说明, orderNumber=,unit=,value=内部面层,valueType=]
]
[group=材质和装饰, items=[code=, extension=, key=名称, orderNumber=,unit=,value=松散-石膏板,valueType=]
[code=, extension=, key=高光, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=辉光, orderNumber=,unit=,value=False,valueType=]
[code=, extension=, key=平滑度, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=透明度, orderNumber=,unit=,value=,valueType=]
]
],[id=, name=水泥砂浆, parameters=[group=标识数据, items=[code=, extension=, key=型号, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=成本, orderNumber=,unit=,value=0.00,valueType=]
[code=, extension=, key=URL, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=图像, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=注释, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=注释记号, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=标记, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=制造商, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=说明, orderNumber=,unit=,value=,valueType=]
]
[group=材质和装饰, items=[code=, extension=, key=名称, orderNumber=,unit=,value=水泥砂浆,valueType=]
[code=, extension=, key=高光, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=辉光, orderNumber=,unit=,value=False,valueType=]
[code=, extension=, key=平滑度, orderNumber=,unit=,value=,valueType=]
[code=, extension=, key=透明度, orderNumber=,unit=,value=,valueType=]
]
]
可以看到不同的构建ID,其组成材质不同。
// 获取构件材质列表
protected void btnGetSingleModelSingleElementMaterials_Click(object sender, EventArgs e)
{
FileConvertApi api = new FileConvertApi(); string elementId = ddlSingleModelElements.SelectedValue; SingleModelSingleElementMaterials response = api.GetSingleModelSingleElementMaterials(txtAccessToken.Text, txtFileID.Text.ToLong(), elementId); txtResult.Text = response.Code.ToString2()
+ Environment.NewLine
+ "elementId:" + elementId
+ Environment.NewLine
+ response.Message.ToString2()
+ Environment.NewLine
+ response.Data.ToStringWith(",");
}
C#开发BIMFACE系列17 服务端API之获取模型数据2:获取构件材质列表的更多相关文章
- C#开发BIMFACE系列45 服务端API之创建离线数据包
BIMFACE二次开发系列目录 [已更新最新开发文章,点击查看详细] BIMFACE的常规应用方式有公有云与私有化部署两种方式,并且浏览模型或者图纸需要使用ViewToken,ViewToke ...
- C#开发BIMFACE系列18 服务端API之获取模型数据3:获取构件属性
系列目录 [已更新最新开发文章,点击查看详细] 本篇主要介绍如何获取单文件/模型下单个构建的属性信息. 请求地址:GET https://api.bimface.com/data/v2/fil ...
- C#开发BIMFACE系列24 服务端API之获取模型数据9:获取单个房间信息
系列目录 [已更新最新开发文章,点击查看详细] 大厦建筑模型中,基本上包含多个楼层,每个楼层包含多个房间等信息.在<C#开发BIMFACE系列21 服务端API之获取模型数据6:获取单模 ...
- C#开发BIMFACE系列25 服务端API之获取模型数据10:获取楼层对应面积分区列表
系列目录 [已更新最新开发文章,点击查看详细] 在<C#开发BIMFACE系列22 服务端API之获取模型数据7:获取多个模型的楼层信息>中,返回的楼层信息结果中包含了楼层的具体信 ...
- C#开发BIMFACE系列46 服务端API之离线数据包下载及结构详解
BIMFACE二次开发系列目录 [已更新最新开发文章,点击查看详细] 在前一篇博客<C#开发BIMFACE系列45 服务端API之创建离线数据包>中通过调用接口成功的创建一个离线数 ...
- C#开发BIMFACE系列9 服务端API之获取应用支持的文件类型
系列目录 [已更新最新开发文章,点击查看详细] BIMFACE最核心能力之一是工程文件格式转换.无需安装插件,支持数十种工程文件格式在云端转换,完整保留原始文件信息.开发者将告别原始文件解析烦 ...
- C#开发BIMFACE系列14 服务端API之批量获取转换状态详情
系列目录 [已更新最新开发文章,点击查看详细] 上一篇<C#开发BIMFACE系列13 服务端API之获取转换状态>中介绍了根据文件ID查询单个文件的转换状态. 本文介绍批量获取转 ...
- C#开发BIMFACE系列13 服务端API之获取转换状态
系列目录 [已更新最新开发文章,点击查看详细] 在<C#开发BIMFACE系列12 服务端API之文件转换>中详细介绍了7种文件转换的方法.发起源文件/模型转换后,转换过程可能成功 ...
- C#开发BIMFACE系列30 服务端API之模型对比1:发起模型对比
系列目录 [已更新最新开发文章,点击查看详细] 在实际项目中,由于需求变更经常需要对模型文件进行修改.为了便于用户了解模型在修改前后发生的变化,BIMFACE提供了模型在线对比功能,可以利用在 ...
随机推荐
- java实用类总结
1.什么是枚举类? 访问修饰符 Enum 枚举名称{}其应用上可以看做一个类去定义,如果枚举里有方法,定义的枚举常量要以':'结尾 2.应用枚举的好处? 枚举限制了范围,更加安全,如果要大量定义常量用 ...
- 二进制文件安装安装flannel
二进制文件安装安装flannel overlay网络简介 覆盖网络就是应用层网络,它是面向应用层的,不考虑或很少考虑网络层,物理层的问题. 详细说来,覆盖网络是指建立在另一个网络上的网络.该网络中的结 ...
- Mybatis整合Spring 使用
1.继承通用的Mapper<T>,必须指定泛型<T> 例如下面的例子: public interface UserInfoMapper extends Mapper<Us ...
- dubbo负载均衡是如何实现的?
dubbo的负载均衡全部由AbstractLoadBalance的子类来实现 RandomLoadBalance 随机 在一个截面上碰撞的概率高,但调用量越大分布越均匀,而且按概率使用权重后也比较均匀 ...
- log4net服务启动后没有记录日志
有时候在用log4net的时候,调试或执行是ok的,但是安装服务后没有记录日志. 这是因为服务启动是在C盘启动,而程序放的位置在别的目录. 这时候需要指定读取配置文件的位置为程序所在的目录 strin ...
- .Net异步编程详解入门
前言 今天周五,早上起床晚了.赶着挤公交上班.但是目前眼前有这么几件事情.刷牙洗脸.泡牛奶.煎蛋.在同步编程眼中.先刷牙洗脸,然后烧水泡牛奶.再煎蛋,最后喝牛奶吃蛋.毫无疑问,在时间紧促的当下.它完了 ...
- JVM总结(二)
JVM总结(2)java内存区域.字节码执行引擎 1.内存区域 程序计数器:知道线程执行位置,保证线程切换后能恢复到正确的执行位置. 虚拟机栈:存栈帧.栈帧里存局部变量表.操作栈.动态连接.方法返回地 ...
- 【0808 | Day 11】文件的高级应用/修改以及函数的定义/使用/参数
文件的高级应用 一.三种模式 'r+'模式 with open('test.py','r',encoding = 'utf8') as fr: print(fr.writable()) fr.writ ...
- Vue 中使用 typescript
Vue 中使用 typescript 什么是typescript typescript 为 javaScript的超集,这意味着它支持所有都JavaScript都语法.它很像JavaScript都强类 ...
- intellIJ IDEA学习笔记
如果你初次用idea,毫无目的的度娘如何使用IDEA 浪费的将会是大量的时间.为以表诚意, 上一套IDEA教学视频,以表我诚意.(下载地址:https://pan.baidu.com/s/1g ...