C#开发BIMFACE系列23 服务端API之获取模型数据8:获取模型链接信息

系列目录     【已更新最新开发文章,点击查看详细】

在Revit等BIM设计工具中可以给模型的某个部位添加链接信息。即类似于在Office Word、Excel 中给一段文字添加本地文件链接或者网址链接等类似功能。例如下面的一个RVT模型种包含了2个链接。

C#开发BIMFACE系列23 服务端API之获取模型数据8:获取模型链接信息_第1张图片 C#开发BIMFACE系列23 服务端API之获取模型数据8:获取模型链接信息_第2张图片

下面详细介绍如何获取单个模型包含的所有链接信息。

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

说明:获取一个模型种包含的所有链接信息

参数:

C#开发BIMFACE系列23 服务端API之获取模型数据8:获取模型链接信息_第3张图片

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

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

HTTP响应示例(200):

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

返回的结果封装成 SingleModelLink 类

/// 
///  获取单个模型的链接信息返回的结果类
/// 
[Serializable]
public class SingleModelLink : GeneralResponse>
{

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

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

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

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

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

C#实现方法:

 1 /// 
 2 ///  获取单个模型的楼层信息
 3 /// 
 4 /// 【必填】令牌
 5 /// 【必填】代表该单模型的文件ID
 6 /// 
 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();
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的控制台中可以看到我们上传的文件列表,模型状态均为转换成功。

  C#开发BIMFACE系列23 服务端API之获取模型数据8:获取模型链接信息_第4张图片

 以模型 “A4.rvt” 为例测试上述的方法

 C#开发BIMFACE系列23 服务端API之获取模型数据8:获取模型链接信息_第5张图片

查询到了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 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 }
 
系列目录     【已更新最新开发文章,点击查看详细】
 

你可能感兴趣的:(C#开发BIMFACE系列23 服务端API之获取模型数据8:获取模型链接信息)