Revit 里提供了一个IDockablePaneProvider接口,通过这个
接口,可以做一个和Revit里的属性对话框,相似的界面
具体过程是:
先创建一个Page,然后实现这个接口,
然后创建一个DockablePaneId,
再用这个Id 和Page来注册接口,
然后在通过Id来调用这个可停靠窗口
如果想要实现在Revit里选择一个构件,
然后在可停靠窗口里显示一些信息,可以用空闲事件来实现
下面是这个例子的关键代码:
注意 :最好将注册写在APplication里,调用写在Command里,这样不容易出错
注册可停靠窗口:
DockablePaneId id = new DockablePaneId(guid);
My mpp = new My(application);
application.RegisterDockablePane(id, "MyPane", mpp);
return Result.Succeeded;
调用窗口:
DockablePane myp = uiapp.GetDockablePane(id);
myp.Show();
Page代码;
public My(UIControlledApplication uiapp)
{
InitializeComponent();
uiapp.Idling += MyFun;
}
private void MyFun(object sender, Autodesk.Revit.UI.Events.IdlingEventArgs e)
{
UIApplication uiapp = sender as Autodesk.Revit.UI.UIApplication;
Document doc = uiapp.ActiveUIDocument.Document;
ElementId id = uiapp.ActiveUIDocument.Selection.GetElementIds().First();
Element elm = doc.GetElement(id);
this.ElmName.Content = elm.Name;
}
<Page x:Class="MDockablePane.My"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
mc:Ignorable="d"
d:DesignHeight="300" d:DesignWidth="300" Background="White">
<Grid>
<Button Content="Button" HorizontalAlignment="Left" Margin="172,109,0,0" VerticalAlignment="Top" Width="75"/>
<Label Content="构件名称:" HorizontalAlignment="Left" Margin="79,57,0,0" VerticalAlignment="Top"/>
<Label Name="ElmName" Content="" HorizontalAlignment="Left" Margin="154,57,0,0" VerticalAlignment="Top" Width="136"/>
</Grid>
</Page>
public void SetupDockablePane(DockablePaneProviderData data)
{
data.FrameworkElement = this as FrameworkElement;
DockablePaneProviderData d = new DockablePaneProviderData();
data.InitialState = new DockablePaneState();
data.InitialState.DockPosition = DockPosition.Bottom;
}
博主会经常更新一些技术文章,请大家多多关注,
源码下载请加qq群480950299