C#开发BIMFACE系列17 服务端API之获取模型数据2:获取构件材质列表
2019-09-04 17:41
2416 查看
系列目录 【已更新最新开发文章,点击查看详细】
在上一篇《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" : "2856106", "name" : "METAL_(229,80,30)Steel", "parameters" : [ { "group" : "dimension", "items" : [ { "code" : "perimeter", "extension" : "object", "key" : "perimeter", "orderNumber" : 0, "unit" : "mm", "value" : 17200, "valueType" : 2 } ] } ] } ], "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> 13 /// <returns>表示当前对象的字符串。</returns> public override string ToString() { StringBuilder sb = new StringBuilder(); if (Parameters != null && Parameters.Length > 0) { 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 > 0) { foreach (var item in Items) { sb.AppendLine(item.ToString()); } 3ff8 } 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, Extension, Key, OrderNumber, Unit, Value, ValueType); } }C#实现方法:
[code] /// <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=268711, name=金属 - 铝, parameters=[group=标识数据, items=[code=, extension=, key=成本, orderNumber=,unit=,value=0.00,valueType=2] [code=, extension=, key=URL, orderNumber=,unit=,value=,valueType=3] [code=, extension=, key=图像, orderNumber=,unit=,value=,valueType=4] [code=, extension=, key=注释, orderNumber=,unit=,value=,valueType=3] [code=, extension=, key=注释记号, orderNumber=,unit=,value=,valueType=3] [code=, extension=, key=标记, orderNumber=,unit=,value=,valueType=3] [code=, extension=, key=制造商, orderNumber=,unit=,value=,valueType=3] [code=, extension=, key=说明, orderNumber=,unit=,value=,valueType=3] ] [group=材质和装饰, items=[code=, extension=, key=名称, orderNumber=,unit=,value=金属 - 铝,valueType=3] [code=, extension=, key=高光, orderNumber=,unit=,value=128,valueType=1] [code=, extension=, key=辉光, orderNumber=,unit=,value=False,valueType=1] [code=, extension=, key=平滑度, orderNumber=,unit=,value=50,valueType=1] [code=, extension=, key=透明度, orderNumber=,unit=,value=0,valueType=1] ] ]更换其他的构建ID,再次查询
完整的材质列表为:
[code][id=415, name=混凝土砌块, parameters=[group=标识数据, items=[code=, extension=, key=成本, orderNumber=,unit=,value=0.00,valueType=2] [code=, extension=, key=URL, orderNumber=,unit=,value=,valueType=3] [code=, extension=, key=图像, orderNumber=,unit=,value=,valueType=4] [code=, extension=, key=注释, orderNumber=,unit=,value=,valueType=3] [code=, extension=, key=注释记号, orderNumber=,unit=,value=,valueType=3] [code=, extension=, key=标记, orderNumber=,unit=,value=,valueType=3] [code=, extension=, key=制造商, orderNumber=,unit=,value=,valueType=3] [code=, extension=, key=说明, orderNumber=,unit=,value=混凝土砌块,valueType=3] ] [group=材质和装饰, items=[code=, extension=, key=剪变模量 X, orderNumber=,unit=,value=,valueType=2] [code=, extension=, key=子类, orderNumber=,unit=,value=,valueType=3] [code=, extension=, key=名称, orderNumber=,unit=,value=混凝土砌块,valueType=3] [code=, extension=, key=抗压强度, orderNumber=,unit=,value=,valueType=2] [code=, extension=, key=弹性模量 Y, orderNumber=,unit=,value=,valueType=2] [code=, extension=, key=类别, orderNumber=,unit=,value=,valueType=1] [code=, extension=, key=剪变模量 Z, orderNumber=,unit=,value=,valueType=2] [code=, extension=, key=弹性模量 Z, orderNumber=,unit=,value=,valueType=2] [code=, extension=, key=轻质, orderNumber=,unit=,value=,valueType=1] [code=, extension=, key=剪变模量 Y, orderNumber=,unit=,value=,valueType=2] [code=, extension=, key=抗剪强度折减系数, orderNumber=,unit=,value=,valueType=2] [code=, extension=, key=热膨胀系数 X, orderNumber=,unit=,value=,valueType=2] [code=, extension=, key=热膨胀系数 Y, orderNumber=,unit=,value=,valueType=2] [code=, extension=, key=热膨胀系数 Z, orderNumber=,unit=,value=,valueType=2] [code=, extension=, key=高光, orderNumber=,unit=,value=128,valueType=1] [code=, extension=, key=辉光, orderNumber=,unit=,value=False,valueType=1] [code=, extension=, key=弹性模量 X, orderNumber=,unit=,value=,valueType=2] [code=, extension=, key=平滑度, orderNumber=,unit=,value=50,valueType=1] [code=, extension=, key=表现, orderNumber=,unit=,value=,valueType=1] [code=, extension=, key=材质类型, orderNumber=,unit=,value=混凝土,valueType=1] [code=, extension=, key=透明度, orderNumber=,unit=,value=0,valueType=1] [code=, extension=, key=泊松比 Z, orderNumber=,unit=,value=,valueType=2] [code=, extension=, key=泊松比 Y, orderNumber=,unit=,value=,valueType=2] [code=, extension=, key=泊松比 X, orderNumber=,unit=,value=,valueType=2] [code=, extension=, key=容重, orderNumber=,unit=,value=,valueType=2] [code=, extension=, key=阻尼比, orderNumber=,unit=,value=,valueType=2] ] ],[id=423, name=松散-石膏板, parameters=[group=标识数据, items=[code=, extension=, key=型号, orderNumber=,unit=,value=,valueType=3] [code=, extension=, key=成本, orderNumber=,unit=,value=,valueType=2] [code=, extension=, key=URL, orderNumber=,unit=,value=,valueType=3] [code=, extension=, key=图像, orderNumber=,unit=,value=,valueType=4] [code=, extension=, key=注释, orderNumber=,unit=,value=,valueType=3] [code=, extension=, key=注释记号, orderNumber=,unit=,value=,valueType=3] [code=, extension=, key=标记, orderNumber=,unit=,value=,valueType=3] [code=, extension=, key=制造商, orderNumber=,unit=,value=,valueType=3] [code=, extension=, key=说明, orderNumber=,unit=,value=内部面层,valueType=3] ] [group=材质和装饰, items=[code=, extension=, key=名称, orderNumber=,unit=,value=松散-石膏板,valueType=3] [code=, extension=, key=高光, orderNumber=,unit=,value=128,valueType=1] [code=, extension=, key=辉光, orderNumber=,unit=,value=False,valueType=1] [code=, extension=, key=平滑度, orderNumber=,unit=,value=50,valueType=1] [code=, extension=, key=透明度, orderNumber=,unit=,value=0,valueType=1] ] ],[id=813, name=水泥砂浆, parameters=[group=标识数据, items=[code=, extension=, key=型号, orderNumber=,unit=,value=,valueType=3] [code=, extension=, key=成本, orderNumber=,unit=,value=0.00,valueType=2] [code=, extension=, key=URL, orderNumber=,unit=,value=,valueType=3] [code=, extension=, key=图像, orderNumber=,unit=,value=,valueType=4] [code=, extension=, key=注释, orderNumber=,unit=,value=,valueType=3] [code=, extension=, key=注释记号, orderNumber=,unit=,value=,valueType=3] [code=, extension=, key=标记, orderNumber=,unit=,value=,valueType=3] [code=, extension=, key=制造商, orderNumber=,unit=,value=,valueType=3] [code=, extension=, key=说明, orderNumber=,unit=,value=,valueType=3] ] [group=材质和装饰, items=[code=, extension=, key=名称, orderNumber=,unit=,value=水泥砂浆,valueType=3] [code=, extension=, key=高光, orderNumber=,unit=,value=0,valueType=1] [code=, extension=, key=辉光, orderNumber=,unit=,value=False,valueType=1] [code=, extension=, key=平滑度, orderNumber=,unit=,value=50,valueType=1] [code=, extension=, key=透明度, orderNumber=,unit=,value=0,valueType=1] ] ]可以看到不同的构建ID,其组成材质不同。
测试代码如下: [code] // 获取构件材质列表 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系列12 服务端API之文件转换
- Knockout开发中文API系列2–创建数据模型和监控属性
- C# 海康DVR客户端开发系列(2)—— 封装API (3)
- Android开发17——获取网络资源之XML数据
- Sharepoint2010应用开发四:使用客户对象模型(Client Object Model)向SharePoint列表写数据
- Caffe学习系列(17):模型各层数据和参数可视化
- Windows 8 开发系列- 自定义Gridview 绑定列表数据时出错
- sharepoint 2016 学习系列篇(17)-自定义列表应用篇-(6)开启列表数据版本控制
- Android开发--与后台通信(一)--API数据获取
- .net C# WebService 开发(获取数据库数据)
- C# WPD PortableDeviceApiLib获取便携设备列表
- 使用C#开发HTTP服务器系列之构建RESTful API
- 腾讯云图片鉴黄集成到C# SQL Server 怎么在分页获取数据的同时获取到总记录数 sqlserver 操作数据表语句模板 .NET MVC后台发送post请求 百度api查询多个地址的经纬度的问题 try{}里有一个 return 语句,那么紧跟在这个 try 后的 finally {}里的 code 会 不会被执行,什么时候被执行,在 return 前还是后? js获取某个日期
- C# 海康DVR客户端开发系列(2)—— 封装API
- Android开发17——获取网络资源之XML数据
- C# 海康DVR客户端开发系列(2)—— 封装API (3)
- C#通过API获取接收数据窗体控件句柄,并向该句柄发送文本信息
- C#开发微信门户及应用(14)-在微信菜单中采用重定向获取用户数据
- 支付宝移动支付开发详细教程服务端采用.net mvc webapi(C#)
- Android开发17——获取网络资源之XML数据