Você está aqui: Revit C# ::: Dicas & Truques ::: Selection, Seleção |
Como criar um filtro de seleção de elementos no Revit usando a interface ISelectionFilter da Revit C# APIQuantidade de visualizações: 355 vezes |
|
Quando estamos escrevendo macros ou plug-ins Revit que pedem para o usuário selecionar um ou mais elementos, é sempre uma boa idéia fornecer um filtro de elementos, ou seja, quais tipos de elementos serão permitidos na seleção. Isso faz sentido. Imagine, por exemplo, que o seu código está esperando que o usuário selecione uma parede e, sem perceber, o usuário seleciona uma porta. Sua macro ou add-in vai prosseguir com a execução e, caso não provoque um erro imediato, estará trabalhando com o elemento errado. As funções de seleção PickElementsByRectangle(), PickObject() e PickObjects() da classe Selection aceitam um argumento do tipo ISelectionFilter, que uma interface que nos permite definir um filtro para os elementos que poderão ser selecionados pelo usuário. Tudo que temos a fazer é criar uma classe que implementa esta interface e fornecer nossa própria implementação para os métodos AllowElement() e AllowReference(). Veja um trecho de código Revit C# API completo no qual pedimos para o usuário selecionar uma parede. O usuário pode até passar o mouse por cima de outros elementos, mas somente paredes serão destacadas e poderão ser selecionadas: ----------------------------------------------------------------------
Se precisar de ajuda com o código abaixo, pode me chamar
no WhatsApp +55 (62) 98553-6711 (Osmar)
----------------------------------------------------------------------
using System;
using Autodesk.Revit.UI;
using Autodesk.Revit.DB;
using Autodesk.Revit.DB.Structure;
using Autodesk.Revit.UI.Selection;
using System.Collections.Generic;
using System.Linq;
namespace Estudos {
[Autodesk.Revit.Attributes.Transaction(Autodesk.Revit.Attributes.
TransactionMode.Manual)]
[Autodesk.Revit.DB.Macros.AddInId("ED8EC6C4-9489-48F7-B04E-B45B5D1BEB12")]
public partial class ThisApplication {
private void Module_Startup(object sender, EventArgs e) {
// vamos obter uma referência ao UIDocument ativo
UIDocument uidoc = this.ActiveUIDocument;
// agora mostramos uma mensagem para o usuário selecionar uma
// parede
TaskDialog.Show("Aviso", "Selecione uma parede");
// obtemos uma referência ao objeto Selection do
// UIDocument ativo
Selection selecao = uidoc.Selection;
// e finalmente esperamos que o usuário selecione o elemento
FiltroSelecao filtroSelecao = new FiltroSelecao();
Reference selecionado = selecao.PickObject(ObjectType.Element,
filtroSelecao, "Selecione uma parede");
// agora testamos se o usuário realmente selecionou uma
// parede
if (selecionado != null) {
TaskDialog.Show("Aviso", "Você selecionou uma parede.");
}
}
private void Module_Shutdown(object sender, EventArgs e) {
// para fazer alguma limpeza de memória ou algo assim
}
#region Revit Macros generated code
private void InternalStartup() {
this.Startup += new System.EventHandler(Module_Startup);
this.Shutdown += new System.EventHandler(Module_Shutdown);
}
#endregion
}
// classe personalizada que implementa a interface ISelectionFilter
// para criar um filtro de seleção de elementos
public class FiltroSelecao : ISelectionFilter {
// indica os elementos que poderão ser selecionados
public bool AllowElement(Element e) {
// o elemento é do tipo parede?
if (e.Category.Name == "Paredes") {
return true;
}
return false;
}
// em geral este método retorna false para não permitir referências
public bool AllowReference(Reference r, XYZ p) {
return false;
}
}
}
|
|
|
Veja mais Dicas e truques de Revit C# |
Dicas e truques de outras linguagens |
E-Books em PDF |
||||
|
||||
|
||||
Linguagens Mais Populares |
||||
|
1º lugar: Java |






