应用程序:AutoRoute
Revit 平台:所有
Revit 版本:2011.0
首次发布于:2010.0
编程语言:C#
技能水平:初级
类别:MEP(机电管道)
类型:ExternalCommand (外部命令)
主题:布置管道和配件。
摘要:此示例演示了如何在基础供气设备和2个端子之间布线一组风管和管件。
相关类:
Autodesk.Revit.DB.Mechanical.MechanicalSystem
Autodesk.Revit.DB.Mechanical.Duct
Autodesk.Revit.DB.FamilyInstance
Autodesk.Revit.DB.Connector
Autodesk.Revit.DB.Document
项目文件:
Command.cs此文件包含从IExternalCommand继承的类Command。它的功能是在一个基本供气设备和2个终端之间布置一组管道和配件。
功能:
-若要创建机械系统,请使用Document.create.NewMechanicalSystem。
-若要定义管线,请首先找到界定所有三个图元的边界框,然后尝试将X轴和Y轴上的中线、四分之一线作为带有一系列风管的主干,这些风管将通过管件和风管连接到图元。
-若要创建风管,请使用Document.create.NewDuct。
-若要创建管件,请使用Document.create.NewElbowFitting和Document.create.NewTeeFitting。
-要在连接器之间建立连接,请使用Connector.ConnectTo
实施:
1.运行命令。(在此之前,您可以移动端子和设备的位置)
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.Linq;
using System.Text;
using Autodesk.Revit.DB;
namespace Revit.SDK.Samples.RoutingPreferenceTools.CS
{
/// <summary>
/// Main Revit command
/// </summary>
[Autodesk.Revit.Attributes.Transaction(Autodesk.Revit.Attributes.TransactionMode.ReadOnly)]
public class Command : Autodesk.Revit.UI.IExternalCommand
{
/// <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, Autodesk.Revit.DB.ElementSet elements)
{
if (!Validation.ValidateMep(commandData.Application.Application))
{
Validation.MepWarning();
return Autodesk.Revit.UI.Result.Succeeded;
}
if (!Validation.ValidatePipesDefined(commandData.Application.ActiveUIDocument.Document))
{
Validation.PipesDefinedWarning();
return Autodesk.Revit.UI.Result.Succeeded;
}
MainWindow mainWindow = new MainWindow(commandData.Application);
mainWindow.ShowDialog();
return Autodesk.Revit.UI.Result.Succeeded;
}
}
}
版权所有 :无锡模信建筑科技有限公司 苏ICP备2021028830号-1 BIM建模|BIM技术应用|BIM软件开发
联系地址:江苏省无锡市新吴区龙山路4号B座705 手机:18761516598