应用程序:CreateShared
Revit 平台:所有平台
Revit 版本:2011.0
首次发布于:8.0
编程语言:VB.NET
技能水平:初学者
类别:参数
类型:ExternalCommand
主题:创建和修改共享参数。
概述:本示例展示了如何通过API创建共享参数以及如何通过API修改共享参数。
相关类:
Autodesk.Revit.UI.IExternalCommand
Autodesk.Revit.DB.DefinitionFile
Autodesk.Revit.DB.DefinitionGroup
Autodesk.Revit.DB.Definition
Autodesk.Revit.DB.CategorySet
Autodesk.Revit.DB.Category
Autodesk.Revit.DB.Parameters.InstanceBinding
Autodesk.Revit.DB.ParameterSet
Autodesk.Revit.DB.Symbol
项目文件:
Command1.vb
它包含了实现接口IExternalCommand的Command1类,演示了如何通过API添加共享参数。
Command2.vb
它包含了实现接口IExternalCommand的Command2类,演示了如何通过API设置共享参数的值。
描述:
本示例向Revit添加了两个命令。第一个命令展示了如何通过API创建共享参数。请注意,在运行本示例之前必须存在名为RevitParameters.txt的共享参数文件。关于如何创建共享参数文件的详细信息,请参阅Revit帮助文件。第二个命令展示了如何通过API修改共享参数。
描述:
本示例向Revit添加了两个命令。第一个命令展示了如何通过API创建共享参数。请注意,在运行本示例之前必须存在名为RevitParameters.txt的共享参数文件。关于如何创建共享参数文件的详细信息,请参阅Revit帮助文件。第二个命令展示了如何通过API修改共享参数。
本示例提供以下功能。
在Command1中:
- 打开RevitParameters.txt文件并获取DefinitionGroup(如果不存在则创建一个)。然后从该组中获取“APIParameter”定义(如果不存在则创建一个)。
- 为墙体类别创建一个新的实例绑定。
- 将定义的参数绑定和实例绑定添加到项目的ParameterBindingsMap中。
在Command2中:
- 获取“APIParameter”定义。
- 循环遍历项目中的墙体。然后获取每个墙体的“APIParameter”参数并将其值设置为“Hello Revit”。
实施:
1. 在运行本示例之前必须存在一个名为“RevitParameters.txt”的共享参数文件。
2. 打开Revit。
3. 执行外部Command1。
4. 绘制一些墙。
5. 执行外部Command2。
完整的源代码请加入QQ群649037449,在群文件中下载RevitSDK.exe,解压后在文件夹中搜索本文中应用程序名称即可获得完整源码
Command1.vb
'
' (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.
'
Option Explicit On
Imports System
Imports System.IO
Imports Autodesk.Revit.DB
<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 Command1
Implements 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 Function Execute(ByVal commandData As Autodesk.Revit.UI.ExternalCommandData, ByRef message As String, _
ByVal elements As Autodesk.Revit.DB.ElementSet) As Autodesk.Revit.UI.Result _
Implements Autodesk.Revit.UI.IExternalCommand.Execute 'set the shared parameters filename
' Setup a default message in case any exceptions are thrown that we have not
' explicitly handled. On failure the message will be displayed by Revit
message = "The sample failed"
Execute = Autodesk.Revit.UI.Result.Failed
Dim dllLocation As String
dllLocation = Path.GetDirectoryName(System.Reflection.Assembly.GetExecutingAssembly().Location)
Dim paramFilePath As String
paramFilePath = Path.Combine(dllLocation, "RevitParameters.txt")
commandData.Application.Application.SharedParametersFilename = paramFilePath
'open the file
Dim sharedParametersFile As Autodesk.Revit.DB.DefinitionFile
Try
sharedParametersFile = commandData.Application.Application.OpenSharedParameterFile()
Catch ex As Exception
MsgBox("File ""RevitParameters.txt"" not found." & vbNewLine & vbTab & "Exiting function.")
Exit Function
End Try
Try
Dim transaction As Autodesk.Revit.DB.Transaction
transaction = New Autodesk.Revit.DB.Transaction(commandData.Application.ActiveUIDocument.Document, "CreateSharedParameter")
transaction.Start()
'get or create our group
Dim sharedParameterGroup As Autodesk.Revit.DB.DefinitionGroup
sharedParameterGroup = sharedParametersFile.Groups.Item("RevitParameters")
If (sharedParameterGroup Is Nothing) Then
sharedParameterGroup = sharedParametersFile.Groups.Create("RevitParameters")
End If
'get or create the parameter
Dim sharedParameterDefinition As Autodesk.Revit.DB.Definition
sharedParameterDefinition = sharedParameterGroup.Definitions.Item("APIParameter")
Dim externalDefinitonCreationOptions As Autodesk.Revit.DB.ExternalDefinitionCreationOptions
externalDefinitonCreationOptions = New ExternalDefinitionCreationOptions("APIParameter", Autodesk.Revit.DB.ParameterType.Text)
If (sharedParameterDefinition Is Nothing) Then
sharedParameterDefinition = sharedParameterGroup.Definitions.Create(externalDefinitonCreationOptions)
End If
'create a category set with the wall category in it
Dim categories As Autodesk.Revit.DB.CategorySet
categories = commandData.Application.Application.Create.NewCategorySet
Dim wallCategory As Autodesk.Revit.DB.Category
wallCategory = commandData.Application.ActiveUIDocument.Document.Settings.Categories.Item("Walls")
categories.Insert(wallCategory)
'create a new instance binding for the wall categories
Dim instanceBinding As Autodesk.Revit.DB.InstanceBinding
instanceBinding = commandData.Application.Application.Create.NewInstanceBinding(categories)
'add the binding
commandData.Application.ActiveUIDocument.Document.ParameterBindings.Insert(sharedParameterDefinition, instanceBinding)
transaction.Commit()
' change our result to successful
Execute = Autodesk.Revit.UI.Result.Succeeded
Return Execute
Catch ex As Exception
message = ex.Message
Return Execute
End Try
End Function
End Class
版权所有 :无锡模信建筑科技有限公司 苏ICP备2021028830号-1 BIM建模|BIM技术应用|BIM软件开发
联系地址:江苏省无锡市新吴区龙山路4号B座705 手机:18761516598