应用程序:DeckProperties
Revit平台:所有
Revit版本:2011.0
首次发布于:8.1
编程语言:C#
技能水平:初级
类别:参数
类型:外部命令
主题:显示甲板层属性。
摘要:此示例显示了如何通过RevitAPI获取甲板层的属性。
相关类:
Autodesk.Revit.UI.IExternalCommand
Autodesk.Revit.DB.CompoundStructureLayer
Autodesk.Revit.DB.FloorType
Autodesk.Revit.DB.CompoundStructureLayerFunction
项目文件:
Command.cs
该文件包含了如何获取甲板层属性的函数。
功能:
- 在列表中显示甲板层的属性信息。其包括甲板型号、甲板材料、混凝土保护层厚度和混凝土材料等信息。
- 对于混凝土板,它包含混凝土层厚度和混凝土材料等信息。
- CompoundStructureLayer图层可以从Autodesk.Revit.DB.FloorType的CompoundStructureLayer属性中获取。
实施:
1. 在Revit UI中绘制包含若干层的地板。在SlabProperties示例的文件夹中提供了一个样例工程文件SlabProperties.rvt。
2. 选择所绘制的地板,运行该命令,它将会在一个列表中显示所选地板的所有甲板层属性。
完整的源代码请加入QQ群649037449,在群文件中下载RevitSDK.exe,解压后在文件夹中搜索本文中应用程序名称即可获得完整源码
Command.cs
//
// (C) Copyright 2003-2019 by Autodesk, Inc.
//
// Permission to use, copy, modify, and distribute this software in
// object code form for any purpose and without fee is hereby granted,
// provided that the above copyright notice appears in all copies and
// that both that copyright notice and the limited warranty and
// restricted rights notice below appear in all supporting
// documentation.
//
// AUTODESK PROVIDES THIS PROGRAM "AS IS" AND WITH ALL FAULTS.
// AUTODESK SPECIFICALLY DISCLAIMS ANY IMPLIED WARRANTY OF
// MERCHANTABILITY OR FITNESS FOR A PARTICULAR USE. AUTODESK, INC.
// DOES NOT WARRANT THAT THE OPERATION OF THE PROGRAM WILL BE
// UNINTERRUPTED OR ERROR FREE.
//
// Use, duplication, or disclosure by the U.S. Government is subject to
// restrictions set forth in FAR 52.227-19 (Commercial Computer
// Software - Restricted Rights) and DFAR 252.227-7013(c)(1)(ii)
// (Rights in Technical Data and Computer Software), as applicable.
//
using System;
using System.Collections.Generic;
using System.Text;
using Autodesk.Revit;
using Autodesk.Revit.DB;
using Autodesk.Revit.UI;
using Autodesk.Revit.DB.Structure;
namespace Revit.SDK.Samples.DeckProperties.CS
{
/// <summary>
/// Implements the Revit add-in interface IExternalCommand
/// </summary>
[Autodesk.Revit.Attributes.Transaction(Autodesk.Revit.Attributes.TransactionMode.Manual)]
[Autodesk.Revit.Attributes.Regeneration(Autodesk.Revit.Attributes.RegenerationOption.Manual)]
[Autodesk.Revit.Attributes.Journaling(Autodesk.Revit.Attributes.JournalingMode.NoCommandData)]
public class Command : IExternalCommand
{
private DeckPropertyForm m_displayForm;
private Document m_document;
/// <summary>
/// Implement this method as an external command for Revit.
/// </summary>
/// <param name="commandData">An object that is passed to the external application
/// which contains data related to the command,
/// such as the application object and active view.</param>
/// <param name="message">A message that can be set by the external application
/// which will be displayed if a failure or cancellation is returned by
/// the external command.</param>
/// <param name="elements">A set of elements to which the external application
/// can add elements that are to be highlighted in case of failure or cancellation.</param>
/// <returns>Return the status of the external command.
/// A result of Succeeded means that the API external method functioned as expected.
/// Cancelled can be used to signify that the user cancelled the external operation
/// at some point. Failure should be returned if the application is unable to proceed with
/// the operation.</returns>
public Autodesk.Revit.UI.Result Execute(Autodesk.Revit.UI.ExternalCommandData commandData,
ref string message,
ElementSet elements)
{
// Get the application of revit
Autodesk.Revit.UI.UIApplication revit = commandData.Application;
m_document = revit.ActiveUIDocument.Document;
try
{
ElementSet elementSet = new ElementSet();
foreach (ElementId elementId in revit.ActiveUIDocument.Selection.GetElementIds())
{
elementSet.Insert(revit.ActiveUIDocument.Document.GetElement(elementId));
}
if (elementSet.IsEmpty)
{
TaskDialog.Show("Select", "Please select one floor or slab at least.");
return Autodesk.Revit.UI.Result.Cancelled;
}
using (m_displayForm = new DeckPropertyForm())
{
List<Floor> floorList = new List<Floor>();
foreach (ElementId elementId in revit.ActiveUIDocument.Selection.GetElementIds())
{
Element element = revit.ActiveUIDocument.Document.GetElement(elementId);
Floor floor = element as Floor;
if (floor != null)
{
floorList.Add(floor);
}
}
if (floorList.Count <= 0)
{
TaskDialog.Show("Select", "Please select one floor or slab at least.");
return Autodesk.Revit.UI.Result.Cancelled;
}
foreach (Floor floor in floorList)
{
DumpSlab(floor);
}
m_displayForm.ShowDialog();
}
}
catch (Exception ex)
{
// If any error, store error information in message and return failed
message = ex.Message;
return Autodesk.Revit.UI.Result.Failed;
}
// If everything goes well, return succeeded.
return Autodesk.Revit.UI.Result.Succeeded;
}
/// <summary>
/// Dump the properties of interest for the slab passed as a parameter
/// </summary>
/// <param name="slab"></param>
private void DumpSlab(Floor slab)
{
m_displayForm.WriteLine("Dumping Slab" + slab.Id.IntegerValue.ToString());
Autodesk.Revit.DB.FloorType slabType = slab.FloorType;
if (slabType != null)
{
foreach (CompoundStructureLayer layer in slabType.GetCompoundStructure().GetLayers())
{
if (layer.Function == MaterialFunctionAssignment.StructuralDeck)
{
DumbDeck(layer);
}
else
{
DumpLayer(layer);
}
}
}
m_displayForm.WriteLine(" ");
}
/// <summary>
/// Dump properties specific to a decking layer
/// </summary>
/// <param name="deck"></param>
private void DumbDeck(CompoundStructureLayer deck)
{
m_displayForm.WriteLine("Dumping Deck");
if (deck.MaterialId != ElementId.InvalidElementId)
{
// get the deck material object. In this sample all we need to display is the
// name, but other properties are readily available from the material object.
Autodesk.Revit.DB.Material deckMaterial = m_document.GetElement(deck.MaterialId) as Material;
m_displayForm.WriteLine("Deck Material = " + deckMaterial.Name);
}
if (deck.DeckProfileId != ElementId.InvalidElementId)
{
// the deck profile is actually a family symbol from a family of profiles
Autodesk.Revit.DB.FamilySymbol deckProfile = m_document.GetElement(deck.DeckProfileId) as FamilySymbol;
// firstly display the full name as the user would see it in the user interface
// this is done in the format Family.Name and then Symbol.Name
m_displayForm.WriteLine("Deck Profile = "
+ deckProfile.Family.Name + " : " + deckProfile.Name);
// the symbol object also contains parameters that describe how the deck is
// specified. From these parameters an external application can generate
// identical decking for analysis purposes
DumpParameters(deckProfile);
}
}
/// <summary>
/// A generic parameter display method that displays all the parameters of an element
/// </summary>
/// <param name="element"></param>
private void DumpParameters(Element element)
{
foreach (Parameter parameter in element.Parameters)
{
string value = "";
switch (parameter.StorageType)
{
case Autodesk.Revit.DB.StorageType.Double:
value = parameter.AsDouble().ToString();
break;
case Autodesk.Revit.DB.StorageType.ElementId:
value = parameter.AsElementId().IntegerValue.ToString();
break;
case Autodesk.Revit.DB.StorageType.String:
value = parameter.AsString();
break;
case Autodesk.Revit.DB.StorageType.Integer:
value = parameter.AsInteger().ToString();
break;
}
m_displayForm.WriteLine(parameter.Definition.Name + " = " + value);
}
}
/// <summary>
/// for non deck layers this method is called and it displays minimal information
/// about the layer
/// </summary>
/// <param name="layer"></param>
private void DumpLayer(CompoundStructureLayer layer)
{
// Display the name of the material. More detailed material properties can
// be found form the material object
m_displayForm.WriteLine("Dumping Layer");
Autodesk.Revit.DB.Material material = m_document.GetElement(layer.MaterialId) as Material;
if (material != null)
{
m_displayForm.WriteLine("Layer material = " + material.Name);
}
// display the thickness of the layer in inches.
m_displayForm.WriteLine("Layer Thickness = " + layer.Width.ToString());
}
}
}
版权所有 :无锡模信建筑科技有限公司 苏ICP备2021028830号-1 BIM建模|BIM技术应用|BIM软件开发
联系地址:江苏省无锡市新吴区龙山路4号B座705 手机:18761516598