【Revit API】梁的凈高分析

来源:https://www.cnblogs.com/lovecsharp094/archive/2018/05/29/9104448.html
-Advertisement-
Play Games

原理就是,先從梁的LocationCurve上取點,然後向板的上錶面投影。如果有投影點,再從投影點(板上)向梁的底面投影,這時候如果有投影點的話就能得到距離了。 運用該分析的第一條件是梁是在板的上方,勿忘哈! LocationCurve的延伸: 在Curve上按PointRange選取點位: 獲取距 ...


原理就是,先從梁的LocationCurve上取點,然後向板的上錶面投影。如果有投影點,再從投影點(板上)向梁的底面投影,這時候如果有投影點的話就能得到距離了。

運用該分析的第一條件是梁是在板的上方,勿忘哈!

var beamBottomFaces = FaceUtils.GetBottomFaces(beam); //這個方法是自己封裝的
if (null != beamBottomFaces && beamBottomFaces.Any())
{
    var beamLocationCurve = beam.Location as LocationCurve;
    var beamCurve = beamLocationCurve.Curve;
    if (beamCurve != null)
    {
         if (beamCurve is Line)
         {
              beamCurve = GetExtLocationCurve(beamCurve); //如果LocationCurve是Line,最好做個延伸演算法來延長,不然有些梁因為扣減的話,locationCurve容易缺少一部分
         }
         var beamPoints = GetPoints(beamCurve, pointRange); //pointRange是取點間隔
         if (beamPoints != null && beamPoints.Any())
         {
              var floorDataList = GetBeamFloorsPairCore(beamBottomFaces, beamPoints, floors); //floors為建築板                               
         }
    }
}

 

LocationCurve的延伸:

private Curve GetExtLocationCurve(Curve curve)
{
     XYZ dir0 = XYZ.Zero;
     XYZ dir1 = XYZ.Zero;
     if (curve is Line)
     {
          dir0 = (curve as Line).Direction.Negate();
          dir1 = (curve as Line).Direction;
     }
      Curve extCurve = Line.CreateBound(curve.GetEndPoint(0) + 1E3 * dir0, curve.GetEndPoint(1) + 1E3 * dir1);
      return extCurve;
}

 

在Curve上按PointRange選取點位:

private List<XYZ> GetPoints(Curve curve, double pointRange)
{
       var points = new List<XYZ>();
       var beamLength = curve.Length;
       var pointsNumber = beamLength % pointRange == 0 ? ((beamLength / pointRange) - 1) : Math.Floor((beamLength / pointRange));

       for(var i = 1; i <= pointsNumber; i++)
       {
          var point = curve.Evaluate(pointRange * i, false);
          points.Add(point);
       }
       return points;
}

 

 獲取距離:

private List<KeyValuePair<Element, List<KeyValuePair<XYZ, double>>>> GetBeamFloorsPairCore(List<PlanarFace> beamBottomFaces, IEnumerable<XYZ> beamPoints, List<Element> floors)
{
      var floorDataList = new List<KeyValuePair<Element, List<KeyValuePair<XYZ, double>>>>();
      //尋找每一塊結構梁下的板
      foreach (var floor in constructionFloors)
      {
         //獲取該板的最上點坐標
         var floorTopFaces = FaceUtils.GetTopFaces(floor);
         if (null != floorTopFaces && floorTopFaces.Any())
         {
              var defaultFloorOriginZ = floorTopFaces.FirstOrDefault().Origin.Z;
              foreach (var tf in floorTopFaces)
              {
                   var originZ = tf.Origin.Z;
                   if (defaultFloorOriginZ <= originZ)
                   {
                       defaultFloorOriginZ = originZ;
                   }
              }

                   
              var defaultBeamOriginZ = beamBottomFaces.FirstOrDefault().Origin.Z;
              foreach (var bf in beamBottomFaces)
              {
                   var originZ = bf.Origin.Z;
                   if (defaultBeamOriginZ >= originZ)
                   {
                       defaultBeamOriginZ = originZ;
                   }
              }
              //板在梁下麵
              var isLower = defaultFloorOriginZ < defaultBeamOriginZ;

              if (isLower)
              {
                   var datalist = new List<KeyValuePair<XYZ, double>>();
                   //梁上一點能投影到板上
                   foreach (var point in beamPoints)
                   {
                       foreach (var tf in floorTopFaces)
                       {
                           var isProject = tf.Project(point);
                           if (null != isProject)
                           {
                               //投影到板上點的坐標
                               var projectPoint = isProject.XYZPoint;

                               //投影點到梁上點的距離
                               foreach (var bf in beamBottomFaces)
                               {
                                   var bp = bf.Project(projectPoint);
                                   if (null != bp)
                                   {
                                       var distance = bp.Distance;
                                       distance = UnitUtils.ConvertFromInternalUnits(distance, DisplayUnitType.DUT_MILLIMETERS);
                                       distance = Math.Floor(distance);

                                       var pointAndDistance = new KeyValuePair<XYZ, double>(projectPoint, distance);
                                       datalist.Add(pointAndDistance);
                                       break;
                                    }
                                }
                            }
                        }                            
                    }

                    if (datalist != null && datalist.Any())
                    {
                       var floorAndData = new KeyValuePair<Element, List<KeyValuePair<XYZ, double>>>(floor, datalist);
                       floorDataList.Add(floorAndData);
                    }
                }
           }
     }
     return floorDataList;
}

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 說起非同步,Thread,Task,async/await,IAsyncResult 必須掌握 1.線程(Thread) 多線程的意義在於一個應用程式中,有多個執行部分可以同時執行;對於比較耗時的操作(例如io,資料庫操作),或者等待響應(如WCF通信)的操作,可以單獨開啟後臺線程來執行,這樣主線程就 ...
  • 前言 1、本文的前提條件:EF上下文是線程唯一,EF版本6.1.3。 2、網上已有相關API的詳細介紹,本文更多的是作為我自己的個人學習研究記錄。 疑問 用反編譯工具翻開DbContext類可以看到EF本身就是一個實現了工作單元的倉儲層,每運行一次DbContext.SaveChanges()便提交 ...
  • 剛剛學習了 Siki老師 的C#教程Linq部分,以下是筆記 需要引用命名空間 然後我們需要準備數據 武林高手類 武林絕學類 Main方法里的武林高手列表和武林絕學列表 表達式基本寫法 事實上,條件語句是可以用一個委托代替的,如下麵的代碼 也可以使用擴展方法的方式進行查詢 接著我用下麵的代碼輸出 聯 ...
  • 索引 NET Core應用框架之BitAdminCore框架應用篇系列 框架演示:http://bit.bitdao.cn 框架源碼:https://github.com/chenyinxin/cookiecutter-bitadmin-core 20180529更新內容 本次更新兩個內容,一是qu ...
  • 在對python有了一定的瞭解之後就對python的第三方庫產生了十分濃厚的興趣,因為python的很多功能都是要依靠第三方庫函數來實現的,而且在電腦二級剛剛加入的python考試中也有對第三方庫的安裝和運用有一定的要求,比如Turtle庫、jieba庫、pyinstaller庫、wordclou ...
  • 索引 NET Core應用框架之BitAdminCore框架應用篇系列 框架演示:http://bit.bitdao.cn 框架源碼:https://github.com/chenyinxin/cookiecutter-bitadmin-core 一、列定義 本節講解如何定義querySuite要顯 ...
  • 在Revit中有一個相機功能可以以相機視角產生一個視圖。一開始我在2016中找關鍵詞Camera,但是沒什麼收穫。 其實這個相機功能的真正核心是創建透視視圖:View3D.CreatePerspective(Document, ElementId) 簡單的代碼示例如下: 關於上方向: Autodes ...
  • 話不多說,直接代碼 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...