Revity:查找并修改类型参数和实例参数

要先明白类型参数和实例参数怎么拿到。

 

类型参数的取法:

是基于族类型(FamilySymbol)来取的。当你得到一个族类型对象时,就可以使用下述三个方法来得到类型参数:

 

 

 

 当然,实际还有更多方法。

 

需要注意的是,这三个方法,都定义在Element基类中:

 

 ---------------

下面看下实例参数的取法:

实例参数和类型参数是一样的,都是上面的方法。所不同的是他们的对象不同。

类型参数是使用对象FamilySymbol取到的,而实例参数是使用对象FamilyInstance取到的。

这2个对象,都继承自Element基类,所以,他们取参数,都是上面的那几个方法,是一样的。

 

-------------------

设置类型参数和实例参数的参数值,也就是修改参数值,也是一样的:

 

 使用如上图红圈的方法即可。

 

最后,我列出一个Element扩展类,供您使用,你只要在项目中直接使用即可:

using Autodesk.Revit.DB;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace RevitDevelopment.Extensions
{
    /// <summary>
    /// 与元素有关的公共方法
    /// </summary>
    /// <creator>marc</creator>
    public static class ElementExtensions
    {
        /// <summary>
        /// 查找参数
        /// </summary>
        /// <param name="element">族类型</param>
        /// <param name="parameterName">族参数名称</param>
        public static Parameter FindParameter(this Element element, string parameterName)
        {
            IList<Parameter> parameters = element.GetParameters(parameterName);
            CheckParametersCount(parameters, parameterName);

            return parameters[0];
        }

        /// <summary>
        /// 设置族参数值
        /// </summary>
        /// <param name="element">族类型</param>
        /// <param name="parameterName">族参数名称</param>
        /// <param name="parameterValue">族参数值。自动转英尺。</param>
        public static void SetParameterValue(this Element element, string parameterName, double parameterValue)
        {
            IList<Parameter> parameters = element.GetParameters(parameterName);
            CheckParametersCount(parameters, parameterName);

            Parameter p = parameters[0];
            if (p.StorageType != StorageType.Double)
            {
                throw new InvalidOperationException("参数接受的类型为" + nameof(Double));
            }

            CheckParameterIsReadOnly(p);

            p.Set(parameterValue / RevitConsts.FTToMMScale);
        }

        /// <summary>
        /// 设置族参数值
        /// </summary>
        /// <param name="element">族类型</param>
        /// <param name="parameterName">族参数名称</param>
        /// <param name="parameterValue">族参数值</param>
        public static void SetParameterValue(this Element element, string parameterName, string parameterValue)
        {
            IList<Parameter> parameters = element.GetParameters(parameterName);
            CheckParametersCount(parameters, parameterName);

            Parameter p = parameters[0];
            if (p.StorageType != StorageType.String)
            {
                throw new InvalidOperationException("参数接受的类型为" + nameof(String));
            }

            CheckParameterIsReadOnly(p);

            p.Set(parameterValue);
        }

        /// <summary>
        /// 设置族参数值。将字符串的值直接赋给参数。
        /// </summary>
        /// <param name="element">族类型</param>
        /// <param name="parameterName">族参数名称</param>
        /// <param name="parameterValueString">族参数值</param>
        public static void SetParameterValueString(this Element element, string parameterName, string parameterValueString)
        {
            IList<Parameter> parameters = element.GetParameters(parameterName);
            CheckParametersCount(parameters, parameterName);

            Parameter p = parameters[0];

            CheckParameterIsReadOnly(p);

            p.SetValueString(parameterValueString);
        }

        /// <summary>
        /// 设置族参数值
        /// </summary>
        /// <param name="element">族类型</param>
        /// <param name="parameterName">族参数名称</param>
        /// <param name="parameterValue">族参数值</param>
        public static void SetParameterValue(this Element element, string parameterName, int parameterValue)
        {
            IList<Parameter> parameters = element.GetParameters(parameterName);
            CheckParametersCount(parameters, parameterName);

            Parameter p = parameters[0];
            if (p.StorageType != StorageType.Double)
            {
                throw new InvalidOperationException("参数接受的类型为" + nameof(Int32));
            }

            CheckParameterIsReadOnly(p);

            p.Set(parameterValue);
        }

        /// <summary>
        /// 检查参数个数是否正常
        /// </summary>
        /// <param name="parameters">参数列表</param>
        /// <param name="parameterName">参数名</param>
        private static void CheckParametersCount(IList<Parameter> parameters, string parameterName)
        {
            if (parameters.Count == 0)
            {
                throw new InvalidOperationException($"不存在名为【{parameterName}】的参数");
            }
            else if (parameters.Count > 1)
            {
                throw new InvalidOperationException($"存在多个名为【{parameterName}】的参数");
            }
        }

        /// <summary>
        /// 检测参数是否只读
        /// </summary>
        /// <param name="parameter">参数</param>
        private static void CheckParameterIsReadOnly(Parameter parameter)
        {
            if (parameter.IsReadOnly)
            {
                throw new InvalidOperationException("参数只读,不能修改");
            }
        }
    }
}

  

 

 上图红圈,是该类的使用方法。上面红圈是类型参数值的修改。下面红圈是实体参数值的修改。

posted @ 2020-08-05 15:55    阅读(998)  评论(0编辑  收藏  举报