C#開發BIMFACE系列23 服務端API之獲取模型數據8:獲取模型連接信息

在Revit等BIM設計工具中能夠給模型的某個部位添加連接信息。即相似於在Office Word、Excel 中給一段文字添加本地文件連接或者網址連接等相似功能。例以下面的一個RVT模型種包含了2個連接。html

下面詳細介紹如何獲取單個模型包含的全部連接信息。api

請求地址:GET https://api.bimface.com/data/v2/files/{fileId}/linkside

說明:獲取一個模型種包含的全部連接信息工具

參數:測試

請求 path(示例):https://api.bimface.com/data/v2/files/1211223382064960/linksui

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

HTTP響應示例(200):spa

{
  "code" : "success",
  "data" : [ {
    "guid" : "ffb665b7-067f-4cd6-b080-214e96db0f73-00058185",
    "id" : 0,
    "name" : "file_link.rvt : 12 : loc <not shared>",
    "transform" : ""
  } ],
  "message" : ""
}

返回的結果封裝成 SingleModelLink 類設計

/// <summary>
///  獲取單個模型的連接信息返回的結果類
/// </summary>
[Serializable]
public class SingleModelLink : GeneralResponse<List<Link>>
{

}
[Serializable]
public class Link
{
    [JsonProperty("guid")]
    public string Guid { get; set; }

    [JsonProperty("id")]
    public long? Id { get; set; }

    /// <summary>
    ///  樣例 : "file_link.rvt : 12 
    /// </summary>
    [JsonProperty("name")]
    public string Name { get; set; }

    [JsonProperty("transform")]
    public string Transform { get; set; }

    /// <summary>返回表示當前對象的字符串。</summary>
    /// <returns>表示當前對象的字符串。</returns>
    public override string ToString()
    {
        return String.Format("[Link guid={0}, id={1}, name={2},transform={3}]",
                             Guid, Id, Name, Transform);
    }
}

C#實現方法:code

 1 /// <summary>
 2 ///  獲取單個模型的樓層信息
 3 /// </summary>
 4 /// <param name="accessToken">【必填】令牌</param>
 5 /// <param name="fileId">【必填】表明該單模型的文件ID</param>
 6 /// <returns></returns>
 7 public virtual SingleModelLink GetSingleModelLink(string accessToken, long fileId)
 8 {
 9     // GET https://api.bimface.com/data/v2/files/{fileId}/links
10     string url = string.Format(BimfaceConstants.API_HOST + "/data/v2/files/{0}/links", fileId);
11 
12     BimFaceHttpHeaders headers = new BimFaceHttpHeaders();
13     headers.AddOAuth2Header(accessToken);
14 
15     try
16     {
17         SingleModelLink response;
18 
19         HttpManager httpManager = new HttpManager(headers);
20         HttpResult httpResult = httpManager.Get(url);
21         if (httpResult.Status == HttpResult.STATUS_SUCCESS)
22         {
23             response = httpResult.Text.DeserializeJsonToObject<SingleModelLink>();
24         }
25         else
26         {
27             response = new SingleModelLink
28             {
29                 Message = httpResult.RefText
30             };
31         }
32 
33         return response;
34     }
35     catch (Exception ex)
36     {
37         throw new Exception("[獲取模型連接信息]發生異常!", ex);
38     }
39 }

其中調用到的 httpManager.Get() 方法,請參考《C# HTTP系列》

測試

在BIMFACE的控制檯中能夠看到咱們上傳的文件列表,模型狀態均爲轉換成功。

 

 以模型 「A4.rvt」 爲例測試上述的方法

 

查詢到了2條連接信息,與文章開始處的源文件中的連接信息對應。

並非全部的模型中都包含連接信息,若是不包含,則返回 null

測試代碼以下:
 1 // 獲取單模型連接信息
 2 protected void btnGetSingleModelLink_Click(object sender, EventArgs e)
 3 {
 4     long fileId = txtFileID.Text.Trim().ToLong();
 5     FileConvertApi api = new FileConvertApi();
 6     SingleModelLink response = api.GetSingleModelLink(txtAccessToken.Text, fileId);
 7 
 8     StringBuilder sb = new StringBuilder();
 9     if (response.Data != null)
10     {
11         List<Link> lstLink = response.Data;
12         foreach (var link in lstLink)
13         {
14             sb.AppendLine(link.ToString());
15         }
16     }
17 
18     txtResult.Text = response.Code.ToString2()
19                    + Environment.NewLine
20                    + response.Message.ToString2()
21                    + Environment.NewLine
22                    + sb;
23 }
 
相關文章
相關標籤/搜索