C#开发BIMFACE系列24 服务端API之获取模型数据9:获取单个房间信息

Posted savionzhang

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C#开发BIMFACE系列24 服务端API之获取模型数据9:获取单个房间信息相关的知识,希望对你有一定的参考价值。

大厦建筑模型中,基本上包含多个楼层,每个楼层包含多个房间等信息。在《C#开发BIMFACE系列21 服务端API之获取模型数据6:获取单模型的楼层信息》中介绍了如何获取一个模型中包含的楼层信息、面积分区、房间等信息。本篇主要介绍如何获取单个模型中单个房间信息。

请求地址:GET https://api.bimface.com/data/v2/files/fileId/rooms/roomId

说明:获取单个模型种单个房间信息

参数:

技术图片

请求 path(示例):https://api.bimface.com/data/v2/files/1211223382064960/rooms/857279

请求 header(示例):"Authorization: Bearer dc671840-bacc-4dc5-a134-97c1918d664b"

HTTP响应示例(200):


  "code" : "success",
  "data" : 
    "area" : 7.256476003661832E7,
    "bboxMax" : 
      "x" : -4938.068482562385,
      "y" : -3201.59397858169,
      "z" : 0.0
    ,
    "bboxMin" : 
      "x" : -4938.068482562385,
      "y" : -3201.59397858169,
      "z" : 0.0
    ,
    "boundary" : "",
    "id" : "313137",
    "levelId" : "11",
    "maxPt" : 
      "x" : -4938.068482562385,
      "y" : -3201.59397858169,
      "z" : 0.0
    ,
    "minPt" : 
      "x" : -4938.068482562385,
      "y" : -3201.59397858169,
      "z" : 0.0
    ,
    "name" : "dining room 4",
    "perimeter" : 40087.80000000279,
    "properties" : [ 
      "group" : "dimension",
      "items" : [ 
        "code" : "perimeter",
        "extension" : "object",
        "key" : "perimeter",
        "orderNumber" : 0,
        "unit" : "mm",
        "value" : 17200,
        "valueType" : 2
       ]
     ]
  ,
  "message" : ""

该返回结果的结构比较复杂。在文章最后会给出对应封装成的C#类。

C#实现方法:

 1 /// <summary>
 2 ///  获取单个模型中单个楼层信息
 3 /// </summary>
 4 /// <param name="accessToken">【必填】令牌</param>
 5 /// <param name="fileId">【必填】代表该单模型的文件ID</param>
 6 /// <param name="roomId">【必填】房间ID</param>
 7 /// <returns></returns>
 8 public virtual SingleModelSingleRoom GetSingleModelSingleRoom(string accessToken, long fileId, string roomId)
 9 
10     // GET https://api.bimface.com/data/v2/files/fileId/rooms/roomId
11     string url = string.Format(BimfaceConstants.API_HOST + "/data/v2/files/0/rooms/1", fileId, roomId);
12 
13     BimFaceHttpHeaders headers = new BimFaceHttpHeaders();
14     headers.AddOAuth2Header(accessToken);
15 
16     try
17     
18         SingleModelSingleRoom response;
19 
20         HttpManager httpManager = new HttpManager(headers);
21         HttpResult httpResult = httpManager.Get(url);
22         if (httpResult.Status == HttpResult.STATUS_SUCCESS)
23         
24             response = httpResult.Text.DeserializeJsonToObject<SingleModelSingleRoom>();
25         
26         else
27         
28             response = new SingleModelSingleRoom
29             
30                 Message = httpResult.RefText
31             ;
32         
33 
34         return response;
35     
36     catch (Exception ex)
37     
38         throw new Exception("[获取单个房间信息]发生异常!", ex);
39     
40 

其中调用到的 httpManager.Get() 方法,请参考《C# HTTP系列》

测试

在BIMFACE的控制台中可以看到以下文件列表。模型状态均为转换成功。

技术图片

 以“Revit案例项目改.0001.rvt”为例测试上述的方法。

在《C#开发BIMFACE系列21 服务端API之获取模型数据6:获取单模型的楼层信息》中查询返回的结果中包含 RoomId

技术图片

以 RoomID 为 857552 为例来查询该房间的详细信息

技术图片

完整的房间信息如下:

success

[area=70319994.3674652, 
 bboxMax=[x=13061.9309943162, y=-3481.59383914623, z=2199.99991189159], 
 bboxMin=[x=7061.93123461209, y=-15201.5933697684, z=0], 
 boundary="version":"2.0","loops":[[["z":0.0,"y":-15201.593978581839,"x":13061.931517437606,
                                      "z":0.0,"y":-3481.5939785817081,"x":13061.931517437624
                                     ],
                                     ["z":0.0,"y":-3481.5939785817077,"x":13061.931517437624,
                                      "z":0.0,"y":-3481.5939785816972,"x":10001.931517437628
                                     ],
                                     ["z":0.0,"y":-3481.5939785816972,"x":10001.931517437628,
                                      "z":0.0,"y":-3481.5939785816904,"x":7726.6267896735426
                                     ],
                                     ["z":0.0,"y":-3481.5939785816904,"x":7726.6267896735426,
                                      "z":0.0,"y":-3481.59397858169,"x":7558.3362452017109
                                     ],
                                     ["z":0.0,"y":-3481.59397858169,"x":7558.3362452017109,
                                      "z":0.0,"y":-3481.5939785816881,"x":7061.9315174376252
                                     ],
                                     ["z":0.0,"y":-3481.5939785816881,"x":7061.9315174376252,
                                      "z":0.0,"y":-15201.593978581817,"x":7061.9315174376061
                                     ],
                                     ["z":0.0,"y":-15201.593978581821,"x":7061.9315174376061,
                                      "z":0.0,"y":-15201.593978581839,"x":13061.931517437606
                                     ]
                                    ] 
                                   ]
          ,
  id=857552, 
  levelId=, 
  maxPt=[x=13061.9309943162, y=-3481.59383914623, z=0], 
  minPt=[x=7061.93123461209, y=-15201.5933697684, z=0], 
  name=Living 106, 
  perimeter=35579.9985750456,
  properties=[group=尺寸标注, 
              items=[code=, extension=, key=体积, orderNumber=,unit=m³,value=154.70,valueType=2]
                    [code=, extension=, key=周长, orderNumber=,unit=mm,value=35580,valueType=2]
                    [code=, extension=, key=房间标示高度, orderNumber=,unit=mm,value=4000,valueType=2]
                    [code=, extension=, key=计算高度, orderNumber=,unit=mm,value=0,valueType=2]
                    [code=, extension=, key=面积, orderNumber=,unit=m²,value=70,valueType=2]
             ]
             [group=标识数据, 
              items=[code=, extension=, key=Occupant, orderNumber=,unit=,value=,valueType=3]
                    [code=, extension=, key=占用, orderNumber=,unit=,value=,valueType=3]
                    [code=, extension=, key=名称, orderNumber=,unit=,value=Living,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]
                    [code=, extension=, key=编号, orderNumber=,unit=,value=106,valueType=3]
                    [code=, extension=, key=部门, orderNumber=,unit=,value=,valueType=3]
            ]
            [group=阶段化, 
             items=[code=, extension=, key=相位, orderNumber=,unit=,value=Working Drawings,valueType=4]
            ] 
            [group=限制条件, 
             items=[code=, extension=, key=上限, orderNumber=,unit=,value=Level 1,valueType=4]
                   [code=, extension=, key=底部偏移, orderNumber=,unit=mm,value=0,valueType=2]
                   [code=, extension=, key=标高, orderNumber=,unit=,value=Level 1,valueType=4]
                   [code=, extension=, key=高度偏移, orderNumber=,unit=mm,value=4000,valueType=2]
            ]
]

该接口返回的响应信息,封装成对应的C# SingleModelSingleRoom 类:

/// <summary>
/// 获取单个模型单个房间信息返回的结果类
/// </summary>
public class SingleModelSingleRoom : GeneralResponse<Room>


Room 类如下:

 1 /// <summary>
 2 ///  模型的房间信息
 3 /// </summary>
 4 [Serializable]
 5 public class Room
 6 
 7     /// <summary>
 8     ///  样例 : 7.256476003661832E7
 9     /// </summary>
10     [JsonProperty("area")]
11     public double? Area  get; set; 
12 
13     [JsonProperty("bboxMax")]
14     public Coordinate BboxMax  get; set; 
15 
16     [JsonProperty("bboxMin")]
17     public Coordinate BboxMin  get; set; 
18 
19     /// <summary>
20     ///  边界
21     /// </summary>
22     [JsonProperty("boundary")]
23     public string Boundary  get; set; 
24 
25     /// <summary>
26     ///  编号
27     /// </summary>
28     [JsonProperty("id")]
29     public string Id  get; set; 
30 
31     /// <summary>
32     ///  水平线编号
33     /// </summary>
34     [JsonProperty("levelId")]
35     public string LevelId  get; set; 
36 
37     [JsonProperty("maxPt")]
38     public Coordinate MaxPt  get; set; 
39 
40     [JsonProperty("minPt")]
41     public Coordinate MinPt  get; set; 
42 
43     /// <summary>
44     ///  对象名称。例如:"dining room 4"
45     /// </summary>
46     [JsonProperty("name")]
47     public string Name  get; set; 
48 
49     /// <summary>
50     ///  样例 : 40087.80000000279
51     /// </summary>
52     [JsonProperty("perimeter")]
53     public double? Perimeter  get; set; 
54 
55     [JsonProperty("properties")]
56     public PropertyGroup[] Properties  get; set; 
57 
58     /// <summary>返回表示当前对象的字符串。</summary>
59     /// <returns>表示当前对象的字符串。</returns>
60     public override string ToString()
61     
62         StringBuilder sb = new StringBuilder();
63         if (Properties != null && Properties.Length > 0)
64         
65             foreach (var property in Properties)
66             
67                 sb.AppendLine(property.ToString());
68             
69         
70 
71         return string.Format("[area=0, bboxMax=1, bboxMin=2, boundary=3, id=4, levelId=5, maxPt=6, minPt=7, name=8, perimeter=9, properties=10]",
72                              Area, BboxMax, BboxMin, Boundary, Id, LevelId, MaxPt, MinPt, Name, Perimeter, sb);
73     
74 

其中 Coordinate 、PropertyGroup 类请参考《C#开发BIMFACE系列17 服务端API之获取模型数据2:获取构件材质列表》

 

 
 

以上是关于C#开发BIMFACE系列24 服务端API之获取模型数据9:获取单个房间信息的主要内容,如果未能解决你的问题,请参考以下文章

C#开发BIMFACE系列1 BIMFACE 简介

C#开发BIMFACE系列2 二次开发流程

C#开发BIMFACE系列53 WinForm程序中使用CefSharp加载模型图纸1 简单应用

#导入MD文档图片# 全网首发最全BIMFACE二次开发系列教程

C# web 获取服务端cookie

HBase编程 API入门系列之modify(管理端而言)(10)