EaBIM一直以来积极响应国家“十二五”推进建筑业信息化的号召,对建筑领域的信息技术开展深入技术交流和探讨!致力于打造“BIM-建筑师-生态技术”三位一体综合资源交流共享平台,希望为BIM与可持续设计理念及技术的普及做出微小的贡献!!!

EaBIM

 找回密码
 注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

搜索
查看: 698|回复: 1
打印 上一主题 下一主题

判断一个柱子是圆柱还是矩形柱的代码

[复制链接]

1514

主题

7465

帖子

1万

积分

admin

Rank: 10Rank: 10Rank: 10Rank: 10Rank: 10Rank: 10Rank: 10Rank: 10Rank: 10Rank: 10

积分
12404

社区QQ达人

跳转到指定楼层
楼主
发表于 2014-1-15 13:25:58 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
下面这段代码用来判断柱子的形状。提取柱子的几何形状,看看所有的面,如果有一个面是CylindricalFace,那么其就是圆形柱子。(本命令只适用与判断是矩形柱还是圆形柱)。可以看看如何访问对象的几何信息

[c-sharp] view plaincopyusing System;  using System.Collections.Generic;  using System.Text;  using System.Windows.Forms;    using  Autodesk.Revit .DB;  using Autodesk.Revit.UI;  using Autodesk.Revit .ApplicationServices;  using Autodesk.Revit.Attributes ;  using Autodesk.Revit.UI.Selection;        [TransactionAttribute(Autodesk.Revit.Attributes.TransactionMode.Manual)]  public class RevitCommand : IExternalCommand  {      public Result Execute(ExternalCommandData commandData, ref string messages, ElementSet elements)      {          UIApplication app = commandData.Application;        Document doc = app.ActiveUIDocument.Document;        Transaction trans = new Transaction(doc, "ExComm");        trans.Start();            Selection sel = app.ActiveUIDocument.Selection;        Reference ref1 = sel.PickObject(ObjectType.Element, "Please pick a column to get its shape");        Element elem = doc.GetElement(ref1);        FamilyInstance column = elem as FamilyInstance;          //read its geometry          Options options = app.Application.Create.NewGeometryOptions();        GeometryElement geoElement = column.get_Geometry(options);        bool bRound = false;        Solid solid;        foreach (GeometryObject geoObj in geoElement.Objects)        {          if (geoObj is Solid)          {            solid = geoObj as Solid;            if (solid.Faces.Size > 1)            {               bRound = IsAnyCylinderFace(ref solid);                        }            if (true == bRound)              break;          }          else if (geoObj is GeometryInstance)          {            GeometryInstance geoInstance = geoObj as GeometryInstance;            GeometryElement geoElem1 = geoInstance.GetSymbolGeometry();            if (geoElem1.Objects.Size > 1)            {              foreach (GeometryObject geoObj1 in geoElem1.Objects)              {                if (geoObj1 is Solid && geoObj1 != null)                {                  solid = geoObj1 as Solid;                  if (solid.Faces.Size > 1)                  {                    bRound = IsAnyCylinderFace(ref solid);                                      }                  if (true == bRound)                    break;                }              }            }          }        }                        TaskDialog.Show("column section shape", bRound.ToString());                 trans.Commit();                return Result.Succeeded ;      }        bool IsAnyCylinderFace(ref Solid solid)      {        bool bRound = false;        foreach (Face face in solid.Faces)        {          if (face is CylindricalFace)          {            bRound = true;            break;          }                 }        return bRound;      }  }  作者:叶雄进文章来源:http://blog.csdn.net/joexiongjin/article/category/782739


分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友 微信微信
收藏收藏 转播转播 分享分享 分享淘帖 支持支持 反对反对

相关帖子

工作时间:工作日的9:00-12:00/13:30-18:00,节假日不在线,请勿留言

18

主题

702

帖子

1270

积分

BIM经理

Rank: 6Rank: 6Rank: 6Rank: 6Rank: 6Rank: 6

积分
1270
2F
发表于 2014-2-20 14:10:39 | 只看该作者
路过!!! 不发表意见……
*滑块验证:
您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|EaBIM网 ( 苏ICP备2020058923号-1  苏公网安备32011502011255号

GMT+8, 2024-11-16 16:36

Powered by Discuz! X3.2 Licensed

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表