C#開發BIMFACE系列30 服務端API之模型對比1:發起模型對比

  在實際項目中,因爲需求變動常常須要對模型文件進行修改。爲了便於用戶瞭解模型在修改先後發生的變化,BIMFACE提供了模型在線對比功能,能夠利用在線的模型對比接口,經過簡單的四個步驟實現模型在線對比。模型對比能夠對兩個文件/模型進行差別性分析,肯定兩個文件/模型之間構件的幾何和屬性差別,包括增長的構件、刪除的構件和修改的構件。 模型對應能夠用於進行文件/模型的版本對比。html

特別說明:模型對比是在BIMFACE雲端進行的,一般須要5~10分鐘。當模型對比完成後,BIMFACE能通知對比結果。 api

前置條件
  • 您須要將修改前和修改後的模型上傳到雲端並轉換成功之後才能發起模型對比;
  • 目前僅支持.rvt單文件的模型對比。
基本步驟
  1. 經過服務端API發起模型對比(對比先後模型文件的fileId);
  2. 等待雲端對比任務執行;
  3. 對比完成後,在網頁端經過調用JavaScript API實現差別模型的顯示;
  4. 除了顯示差別模型,還須要調用服務端API獲取對比結果(包括新增、刪除、修改的構件列表)。
對比流程

  模型文件通過雲端轉換後,生成了BIMFACE定義的數據包。所以,要對比兩個模型文件,實際上須要對比兩個文件的數據包。以下圖所示,文件B是文件A修改後的版本,對比完成以後,其結果包括兩個部分:app

  • 幾何差別;
  • 變動構件及屬性。

 

發起模型對比

對比操做的第一步是調用服務端API發起模型對比。ide

請求地址:POST https://api.bimface.com/v2/compare函數

說明:不一樣版本的模型文件上傳並轉換成功後,便可發起模型對比。因爲對比不能當即完成,BIMFace支持在模型對比完成之後,經過Callback機制通知應用;另外,應用也能夠經過接口查詢對比狀態。測試

參數:
this

請求 path(示例):https://api.bimface.com/v2/compareurl

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

請求 body(示例):3d

{ "callback" : "https://api.glodon.com/viewing/callback?authCode=BJ90Jk0affae&signature=2ef131395fb6442eb99abd83d45c2412", "comparedEntityType" : "file", "config" : "object", "followingId" : 22145522, "name" : "compare0001", "previousId" : 12311221, "priority" : 2, "sourceId" : "123223223212" }

HTTP響應示例(200):

{ "code" : "success", "data" : { "compareId" : 1248756572307264, "createTime" : "2017-12-25 16:17:27", "name" : "compare0001", "priority" : 2, "reason" : "reason", "sourceId" : "123223223212", "status" : "succcess", "thumbnail" : [ "https://m.bimface.com/9b711803a43b92d871cde346b63e5019/thumbnail/96.png" ] }, "message" : "" }

C#實現方法:

 1 /// <summary>
 2 /// 不一樣版本的模型文件上傳並轉換成功後,便可發起模型對比。因爲對比不能當即完成,BIMFace支持在模型對比完成之後,經過Callback機制通知應用;另外,應用也能夠經過接口查詢對比狀態  3 /// </summary>
 4 /// <param name="accessToken">【必填】令牌</param>
 5 /// <param name="followingId">修改後圖紙(當前本班,本輪)模型文件ID</param>
 6 /// <param name="previousId">修改前圖紙(歷史版本,上一輪次)模型文件ID</param>
 7 /// <returns></returns>
 8 public virtual ModelCompareResponse Compare(string accessToken, long followingId, long previousId)  9 { 10     CompareRequest request = new CompareRequest(followingId, previousId); 11 
12     return Compare(accessToken, request); 13 }

其中12行的Compare方法調用了重載方法,實現以下:

 1 /// <summary>
 2 /// 不一樣版本的模型文件上傳並轉換成功後,便可發起模型對比。因爲對比不能當即完成,BIMFace支持在模型對比完成之後,經過Callback機制通知應用;另外,應用也能夠經過接口查詢對比狀態  3 /// </summary>
 4 /// <param name="accessToken">【必填】令牌</param>
 5 /// <param name="request">對比時的請求參數</param>
 6 /// <returns></returns>
 7 public virtual ModelCompareResponse Compare(string accessToken, CompareRequest request)  8 {  9     //POST https://api.bimface.com/v2/compare
10     string url = BimfaceConstants.API_HOST + "/v2/compare"; 11     string data = request.SerializeToJson(); 12 
13     BimFaceHttpHeaders headers = new BimFaceHttpHeaders(); 14  headers.AddOAuth2Header(accessToken); 15 
16     try
17  { 18  ModelCompareResponse response; 19 
20         HttpManager httpManager = new HttpManager(headers); 21         HttpResult httpResult = httpManager.Post(url, data); 22         if (httpResult.Status == HttpResult.STATUS_SUCCESS) 23  { 24             response = httpResult.Text.DeserializeJsonToObject<ModelCompareResponse>(); 25  } 26         else
27  { 28             response = new ModelCompareResponse 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 類請參考個人博客文章《C# HTTP系列 HttpWebRequest 與 HttpWebResponse》。

CompareRequest 請求類以下:

 1 /// <summary>
 2 /// 模型對比請求參數類  3 /// </summary>
 4 [Serializable]  5 public class CompareRequest  6 {  7     /// <summary>
 8     /// 
 9     /// </summary>
10     /// <param name="followingId">變動後文件ID,若是爲刪除文件,則爲null</param>
11     /// <param name="previousId">變動前文件ID,若是爲新增文件,則爲null</param>
12     /// <param name="name">自定義對比的名稱</param>
13     public CompareRequest(long? followingId, long? previousId, string name = "") 14  { 15         ComparedEntityType = "file"; //要麼賦值,必須是正確的值。若是賦值null,則報錯
16         Config = null; 17         SourceId = null; 18         Priority = 2; 19         CallBack = "http://www.app.com/receive"; 20 
21         FollowingId = followingId; 22         PreviousId = previousId; 23         if (name.IsNullOrWhiteSpace()) 24  { 25             Name = DateTime.Now.ToString("yyyyMMddHHmmss") + "對比:" + followingId.ToString2() + "-" + previousId.ToString2(); 26  } 27  } 28 
29     /// <summary>
30     /// 對比的模型類型:file 31     /// </summary>
32     [JsonProperty("comparedEntityType", NullValueHandling = NullValueHandling.Ignore)] 33     public string ComparedEntityType { get; set; } 34 
35     [JsonProperty("config", NullValueHandling = NullValueHandling.Ignore)] 36     public object Config { get; set; } 37 
38     /// <summary>
39     /// 變動後文件ID,若是爲刪除文件,則爲null 40     /// </summary>
41     [JsonProperty("followingId")] 42     public long? FollowingId { get; set; } 43 
44     /// <summary>
45     /// 變動前文件ID,若是爲新增文件,則爲null 46     /// </summary>
47     [JsonProperty("previousId")] 48     public long? PreviousId { get; set; } 49 
50     /// <summary>
51     /// 用戶指定對比後的模型的名字 52     /// </summary>
53     [JsonProperty("name")] 54     public string Name { get; set; } 55 
56     /// <summary>
57     /// 第三方應用本身的ID 58     /// </summary>
59     [JsonProperty("sourceId", NullValueHandling = NullValueHandling.Ignore)] 60     public string SourceId { get; set; } 61 
62     /// <summary>
63     /// 對比優先級。取值 一、二、3。數字越大,優先級越低。默認爲2 64     /// </summary>
65     [JsonProperty("priority")] 66     public int Priority { get; set; } 67 
68     /// <summary>
69     /// Callback地址,待轉換完畢之後,BIMFace會回調該地址 70     /// </summary>
71     [JsonProperty("callback")] 72     public string CallBack { get; set; } 73 }
View Code

其中 Name 屬性,在構造函數中默認設置爲當前時間 + "對比" + 修改後文件ID + 修改前文件ID。這裏是爲了方便使用不須要每次調用該類都給Name賦值,也能夠自定義任何有意義的名稱。

ModelCompareResponse 響應類以下:

 1 /// <summary>
 2     /// 模型對比返回的結果類  3     /// </summary>
 4     public class ModelCompareResponse : GeneralResponse<ModelCompareBean>
 5  {  6 
 7  }  8 
 9     public class ModelCompareBean 10  { 11         /// <summary>
12         /// 對比後返回的ID,用於獲取對比狀態或者結果等信息 13         /// </summary>
14         [JsonProperty("compareId", NullValueHandling = NullValueHandling.Ignore)] 15         public long? CompareId { get; set; } 16 
17         /// <summary>
18         /// 對比完成的消耗時間,單位是秒 19         /// </summary>
20         [JsonProperty("cost", NullValueHandling = NullValueHandling.Ignore)] 21         public int? Cost { get; set; } 22 
23         /// <summary>
24         /// 對比開始時間,格式:yyyy-MM-dd hh:mm:ss 25         /// </summary>
26         [JsonProperty("createTime", NullValueHandling = NullValueHandling.Ignore)] 27         public string CreateTime { get; set; } 28 
29         /// <summary>
30         /// 用戶指定對比後的模型的名字 31         /// </summary>
32         [JsonProperty("name", NullValueHandling = NullValueHandling.Ignore)] 33         public string Name { get; set; } 34 
35         /// <summary>
36         /// 離線數據包生成狀態。prepare(未生成); processing(生成中); success(生成成功); failed(生成失敗) 37         /// </summary>
38         [JsonProperty("offlineDatabagStatus", NullValueHandling = NullValueHandling.Ignore)] 39         public string OfflineDatabagStatus { get; set; } 40 
41         /// <summary>
42         /// 對比優先級。取值 一、二、3。數字越大,優先級越低。默認爲2 43         /// </summary>
44         [JsonProperty("priority", NullValueHandling = NullValueHandling.Ignore)] 45         public int? Priority { get; set; } 46 
47         /// <summary>
48         /// 若對比失敗,返回失敗緣由 49         /// </summary>
50         [JsonProperty("reason", NullValueHandling = NullValueHandling.Ignore)] 51         public string Reason { get; set; } 52 
53         /// <summary>
54         /// 第三方應用本身的ID 55         /// </summary>
56         [JsonProperty("sourceId", NullValueHandling = NullValueHandling.Ignore)] 57         public string SourceId { get; set; } 58 
59         /// <summary>
60         /// 對比狀態:prepare(待對比)、processing(對比中)、success(對比成功)、failed(對比失敗) 61         /// </summary>
62         [JsonProperty("status", NullValueHandling = NullValueHandling.Ignore)] 63         public string Status { get; set; } 64 
65         /// <summary>
66         /// 對比幾個縮略圖 67         /// </summary>
68         [JsonProperty("thumbnail", NullValueHandling = NullValueHandling.Ignore)] 69         public string[] Thumbnails { get; set; } 70 
71         /// <summary>
72         /// 模型對比的類型 rvt(或者igms…​) 73         /// </summary>
74         [JsonProperty("type", NullValueHandling = NullValueHandling.Ignore)] 75         public string Type { get; set; } 76 
77         /// <summary>
78         /// 處理對比任務的worker類型。model-compare(或者drawing-compare…​) 79         /// </summary>
80         [JsonProperty("workerType", NullValueHandling = NullValueHandling.Ignore)] 81         public string WorkerType { get; set; } 82 
83         /// <summary>返回表示當前對象的字符串。</summary>
84         /// <returns>表示當前對象的字符串。</returns>
85         public override string ToString() 86  { 87             return this.SerializeToJson(); 88         }
View Code
測試

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

這裏選擇 bimface_2018_mdv_room.rvt 與 Revit案例項目改.0001.rvt 爲例來進行對比。

 1 /// <summary>
 2 /// 開始比對  3 /// </summary>
 4 protected void btnStartCompare_Click(object sender, EventArgs e)  5 {  6     txtResult.Text = string.Empty;  7 
 8     long followingId = lbl1RVT.Text.ToLong();  9     long previousId = lbl2RVT.Text.ToLong(); 10 
11     CompareRequest request = new CompareRequest(followingId, previousId); 12 
13     ModelCompareApi api = new ModelCompareApi(); 14     ModelCompareResponse response = api.Compare(txtAccessToken.Text, request); 15 
16     txtResult.Text = response.SerializeToJson(); 17     txtCompareID.Text = response.Data.CompareId.ToString(); 18 }

調用對比接口發起對比

 返回結果中,code:success表示發起對比成功。到控制檯中查看以下,新增了一筆對比記錄。

特別說明:模型對比是在BIMFACE雲端進行的,一般須要5~10分鐘。當模型對比完成後,BIMFACE能通知對比結果。

在下一篇《C#開發BIMFACE系列31 服務端API之模型對比2:獲取模型對比狀態》中詳細介紹如何獲取模型對比狀態。

原文出處:https://www.cnblogs.com/SavionZhang/p/12395986.html

相關文章
相關標籤/搜索