ウォークスルー: 選択した要素を取得する

ウォークスルー: 選択した要素を取得する

このセクションでは、Revit から選択した要素を取得するアドイン アプリケーションについて説明します。

アドインアプリケーションでは、特定の要素に対する特定の操作を実行できます。たとえば、要素のパラメータ値を取得または変更することができます。パラメータ値を取得するには、次の手順を実行します。

  1. 新しいプロジェクトを作成し、前のウォークスルーで簡単に説明したとおりに参照を追加します。
  2. 選択した要素を取得するには、UIApplication.ActiveUIDocument.Selection.GetElementIds()メソッドを使用します。

GetElementIds()は、選択した要素の ElementIds のコレクションを返します。これは foreach ループで繰り返すことができます。選択した各 ElementId の Element オブジェクトを取得するには、Document.GetElement()メソッドを使用します。

次のコードは、選択した要素の ID を取得する方法の例です。

コード領域 2-7: 選択した要素を取得

[Autodesk.Revit.Attributes.Transaction(TransactionMode.ReadOnly)]
public class Document_Selection : IExternalCommand
{
    public Autodesk.Revit.UI.Result Execute(ExternalCommandData commandData,
        ref string message, ElementSet elements)
    {
        try
        {
            // Select some elements in Revit before invoking this command

            // Get the handle of current document.
            UIDocument uidoc = commandData.Application.ActiveUIDocument;
                
            // Get the element selection of current document.
            Selection selection = uidoc.Selection;
            ICollection<ElementId> selectedIds = uidoc.Selection.GetElementIds();

            if (0 == selectedIds.Count)
            {
                // If no elements selected.
                TaskDialog.Show("Revit","You haven't selected any elements.");
            }
            else
            {
                String info = "Ids of selected elements in the document are: ";
                foreach (ElementId id in selectedIds)
                {
                    info += "\n\t" + id.IntegerValue;
                }

                TaskDialog.Show("Revit",info);
            }
        }
        catch (Exception e)
        {
            message = e.Message;
            return Autodesk.Revit.UI.Result.Failed;
        }

        return Autodesk.Revit.UI.Result.Succeeded;
    }
    /// </ExampleMethod>
}

選択した要素を取得した後は、要素のプロパティまたはパラメータを取得できます。詳細については、「パラメータ」を参照してください。