using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Autodesk.Revit.UI;
using Autodesk.Revit.DB;
using Autodesk.Revit.UI.Selection;
namespace WorkingDymo
{
/// <summary>
/// 计算楼梯体积,本案例包含了element=》solid过程的数据提取
/// </summary>
[Autodesk.Revit.Attributes.Transaction(Autodesk.Revit.Attributes.TransactionMode.Manual)]
class 获取楼梯体积 : IExternalCommand
{
public Result Execute(ExternalCommandData commandData, ref string message, ElementSet elements)
{
UIDocument uidoc = commandData.Application.ActiveUIDocument;
Document doc = uidoc.Document;
//获取楼梯元素
Reference refer = null;
try
{
refer = uidoc.Selection.PickObject(ObjectType.Element, "选择一个楼梯");
}
catch
{
return Result.Succeeded;
}
//获取元素
Element ele = doc.GetElement(refer);
List<Solid> solids = GetSolidsOfElement(ele);
double volume = 0;
foreach (Solid solid in solids)
{
volume += solid.Volume*0.3048*0.3048*0.3048;//获得体积并进行单位转换
}
TaskDialog.Show("楼梯体积", "获取体积是:" + volume);
return Result.Succeeded;
}
#region GetSolidsOfElement:从element里面获取实体的方法
public List<Solid>GetSolidsOfElement(Element ele)
{
//生成事件,指定返回数据的特征
Options options = new Options();
options.DetailLevel = ViewDetailLevel.Fine;
options.ComputeReferences = true;
options.IncludeNonVisibleObjects = true;
//取得构件元素
GeometryElement geoElement = ele.get_Geometry(options);
List<GeometryObject> geoObj = new List<GeometryObject>();
//递归获取集合元素的所有geometryobject
GetAllObj(geoElement, ref geoObj);
//转为solid的集合
List<Solid> solids = geoObj.ConvertAll(m => m as Solid);
return solids;
}
#endregion
#region GetAllObj获得geometry的方法
//获得geometryobject的递归算法
public void GetAllObj(GeometryElement gele,ref List<GeometryObject>gobjs)
{
if (gele==null)
{
return;
}
//遍历geometryelement里面的geometryobject
IEnumerator<GeometryObject> enumerator = gele.GetEnumerator();
while(enumerator.MoveNext())
{
GeometryObject geoObject = enumerator.Current;
Type type = geoObject.GetType();
//如果是嵌套的GeometryElement
if (type.Equals(typeof(GeometryElement)))
{
//则递归
GetAllObj(geoObject as GeometryElement, ref gobjs);
}
//如果嵌套的geometryinstance
else if (type.Equals(typeof(GeometryInstance)))
{
//则用getinstancegeometry取得其中的geometryelement再递归
GetAllObj((geoObject as GeometryInstance).GetInstanceGeometry(), ref gobjs);
}
//如果是solid,则存入集合,递归结束
else
{
if(type.Equals(typeof(Solid)))
{
Solid solid = geoObject as Solid;
//去掉可能存在的空Solid
if (solid.Faces.Size>0||solid.Edges.Size>0)
{
gobjs.Add(geoObject);
}
}
}
}
}
#endregion
}
}
计算楼梯体积
最新推荐文章于 2023-12-07 22:42:32 发布