修复bug和新增部分功能

This commit is contained in:
GG Z
2024-10-08 16:21:39 +08:00
parent 082b781808
commit b6647218be
44 changed files with 1709 additions and 1390 deletions

View File

@@ -1,5 +1,6 @@
using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
@@ -15,6 +16,8 @@ namespace ConsoleApp
string str = "";
double a = 10.0;
double b = 100;
Debug.Assert(a == b);
//确保str满足条件才能继续执行不满足即抛出异常
Guard.IsNotNullOrEmpty(str);//抛出异常
Guard.IsLessThan(a,b);

View File

@@ -22,6 +22,7 @@ using OfficeOpenXml;
using Sai.Toolkit.Revit.Helpers;
namespace RvAddinTest;
/// <summary>
@@ -282,6 +283,6 @@ public class Order
{
public Guid Id { get; set; }
public DateTime Date { get; set; }
public Decimal OrderValue { get; set; }
public decimal OrderValue { get; set; }
public bool Shipped { get; set; }
}

View File

@@ -1,13 +1,8 @@
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.IO;
using System.Text;
using System.Threading.Tasks;
using Autodesk.Revit.Attributes;
using Autodesk.Revit.DB;
using Autodesk.Revit.DB.Plumbing;
using Autodesk.Revit.UI;
namespace RvAddinTest
@@ -19,22 +14,18 @@ namespace RvAddinTest
public Result Execute(ExternalCommandData commandData, ref string message, ElementSet elements)
{
//程序UI界面
UIApplication uiapp = commandData.Application;
var uiapp = commandData.Application;
//获取元素(选择) 显示元素 视图(活动视图)管理(对象)
UIDocument uidoc = uiapp.ActiveUIDocument;
//程序
Autodesk.Revit.ApplicationServices.Application app = uiapp.Application;
var uidoc = uiapp.ActiveUIDocument;
//获取位置和场地 视图(多个视图)管理 获取元素Revit 项目里的全部元素)
Document doc = uidoc.Document;
//获取所有打开文档
DocumentSet docset = uiapp.Application.Documents;
var doc = uidoc.Document;
//当前视图
View view = doc.ActiveView;
List<Element> collector = new FilteredElementCollector(doc, view.Id)
var view = doc.ActiveView;
var collector = new FilteredElementCollector(doc, view.Id)
.OfClass(typeof(MEPCurve))
.WhereElementIsNotElementType().ToList();
// 检查管线之间的碰撞
List<Tuple<Element, Element>> collisions = CheckPipeCollisionsParallel(doc, collector);
var collisions = CheckPipeCollisionsParallel(doc, collector);
// 显示碰撞结果
ShowCollisionResults(collisions);
@@ -42,18 +33,18 @@ namespace RvAddinTest
}
public List<Tuple<Element, Element>> CheckPipeCollisionsParallel(Document doc, List<Element> pipes)
{
List<Tuple<Element, Element>> collisions = new List<Tuple<Element, Element>>();
var collisions = new List<Tuple<Element, Element>>();
// 使用 Parallel.For 并行检查碰撞
Parallel.For(0, pipes.Count, i =>
{
for (int j = i + 1; j < pipes.Count; j++)
for (var j = i + 1; j < pipes.Count; j++)
{
Element pipe1 = pipes[i];
Element pipe2 = pipes[j];
var pipe1 = pipes[i];
var pipe2 = pipes[j];
// 使用 ElementIntersectsElementFilter 检查碰撞
ElementIntersectsElementFilter filter = new ElementIntersectsElementFilter(pipe1);
FilteredElementCollector collector = new FilteredElementCollector(doc, new ElementId[] { pipe2.Id });
var filter = new ElementIntersectsElementFilter(pipe1);
var collector = new FilteredElementCollector(doc, [pipe2.Id]);
collector.WherePasses(filter);
if (collector.Any())
@@ -77,9 +68,9 @@ namespace RvAddinTest
}
else
{
StringBuilder message = new StringBuilder();
var message = new StringBuilder();
message.AppendLine("发现碰撞:");
foreach (Tuple<Element, Element> collision in collisions)
foreach (var collision in collisions)
{
message.AppendLine($"管线 {collision.Item1.Id} 与管线 {collision.Item2.Id} 发生碰撞");
}
@@ -90,10 +81,10 @@ namespace RvAddinTest
public void ExportCollisionResultsToFile(string content)
{
// 获取桌面路径
string desktopPath = Environment.GetFolderPath(Environment.SpecialFolder.Desktop);
var desktopPath = Environment.GetFolderPath(Environment.SpecialFolder.Desktop);
// 创建文件路径
string filePath = Path.Combine(desktopPath, "碰撞检查.txt");
var filePath = Path.Combine(desktopPath, "碰撞检查.txt");
// 写入文件
File.WriteAllText(filePath, content);

View File

@@ -127,7 +127,7 @@ public class RevitAddin : ExternalCommand
{
try
{
var reference = UiDocument.Selection.PickObject(ObjectType.PointOnElement, new DwgBlockSelection(), "请选择dwg");
var reference = UiDocument.Selection.PickObject(ObjectType.PointOnElement, new DwgBlockSelection(), "请选择dwg链接的块参照");
var dwg = Document.GetElement(reference) as ImportInstance;
var dwgTransform = dwg!.GetTotalTransform();

View File

@@ -21,6 +21,7 @@
</PropertyGroup>
<ItemGroup>
<PackageReference Include="Bogus" Version="35.5.1" />
<PackageReference Include="EleCho.WpfSuite.FluentDesign" Version="0.0.1" />
<PackageReference Include="iNKORE.UI.WPF.Modern" Version="0.9.30" />
<PackageReference Include="LiteDB" Version="5.0.21" />
<PackageReference Include="Microsoft.Xaml.Behaviors.Wpf" Version="1.1.122" />
@@ -29,11 +30,15 @@
<PackageReference Include="Nice3point.Revit.Api.RevitAPI" Version="2018.*" PrivateAssets="All" />
<PackageReference Include="Nice3point.Revit.Api.RevitAPIUI" Version="2018.*" PrivateAssets="All" />
<PackageReference Include="Nice3point.Revit.Api.UIFrameworkServices" Version="2020.2.60" PrivateAssets="All" />
<PackageReference Include="CommunityToolkit.Mvvm" Version="8.2.1" />
<PackageReference Include="CommunityToolkit.Common" Version="8.3.2" />
<PackageReference Include="CommunityToolkit.Diagnostics" Version="8.3.2" />
<PackageReference Include="CommunityToolkit.Mvvm" Version="8.3.2" />
<PackageReference Include="EPPlus.Core.Extensions" Version="2.4.0" />
<PackageReference Include="JerryShaw.AduSkin" Version="1.1.1.11" />
<PackageReference Include="Nice3point.Revit.Toolkit" Version="2019.0.12" PrivateAssets="All" />
</ItemGroup>
<Import Project="..\Sai.Toolkit.Revit\Sai.Toolkit.Revit.projitems" Label="Shared" />
<Import Project="..\Sai.Toolkit.Core\Sai.Toolkit.Core.projitems" Label="Shared" />
<!--<Target Name="PreventRevitSDKCopyLocal" AfterTargets="ResolveReferences">
<ItemGroup>
@@ -41,8 +46,4 @@
<ReferenceCopyLocalPaths Remove="@(ReferenceCopyLocalPaths)" Condition="'%(ReferenceCopyLocalPaths.NuGetPackageId)' == 'Autodesk.Revit.SDK'" />
</ItemGroup>
</Target>-->
<Import Project="..\Sai.Toolkit.Revit\Sai.Toolkit.Revit.projitems" Label="Shared" />
<Import Project="..\Sai.Toolkit.Core\Sai.Toolkit.Core.projitems" Label="Shared" />
</Project>

64
RvAddinTest/TestGDI.cs Normal file
View File

@@ -0,0 +1,64 @@
using System.Drawing;
using System.Timers;
using Autodesk.Revit.Attributes;
using Autodesk.Revit.DB;
using Autodesk.Revit.UI;
using Nice3point.Revit.Toolkit.External;
using Sai.Toolkit.Core.Helpers;
namespace RvAddinTest;
[Transaction(TransactionMode.Manual)]
[Regeneration(RegenerationOption.Manual)]
public class TestGDI : ExternalCommand
{
private UIView ui;
/// <summary>
/// 设置项目基点
/// </summary>
/// <param name="position"></param>
private void SetProjectPosition(XYZ position)
{
using Transaction trans = new(Document);
trans.Start("设置项目基点");
XYZ p = new();
ProjectPosition pp = new(position.X, position.Y, position.Z, 0);
//设置项目基点
Document.ActiveProjectLocation.SetProjectPosition(p, pp);
trans.Commit();
}
public override void Execute()
{
ui = UiDocument.GetOpenUIViews().FirstOrDefault(uiView => uiView.ViewId == UiDocument.ActiveView.Id);
var corners = ui.GetZoomCorners();
//var inptr = HookInptr.FindWindow(null, view.Name);
//Graphics graphics = Graphics.FromHwnd(inptr);
//graphics.RenderingOrigin=
//Graphics graphics = Graphics.FromHwnd(System.Diagnostics.Process.GetCurrentProcess().Handle);
System.Timers.Timer timer =
new(2000)
{
Interval = 500,
Enabled = true
//AutoReset = true
};
timer.Elapsed += Timer_Elapsed;
}
private void Timer_Elapsed(object sender, ElapsedEventArgs e)
{
var rectangle = ui.GetWindowRectangle(); //屏幕坐标;原点在右上角
var graphics = Graphics.FromHwnd(System.Diagnostics.Process.GetCurrentProcess().MainWindowHandle);
var p = new System.Drawing.Point(rectangle.Left + 1920, rectangle.Top);
var p1 = new System.Drawing.Point(rectangle.Right + 1920, rectangle.Bottom);
GdiHelper.DrawLine(graphics, p, p1);
}
}

View File

@@ -1,6 +1,6 @@
Microsoft Visual Studio Solution File, Format Version 12.00
# Visual Studio Version 17
# 17
VisualStudioVersion = 17.1.32421.90
MinimumVisualStudioVersion = 10.0.40219.1
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "Sai.RvKits", "Sai.RvKits\Sai.RvKits.csproj", "{AA64ED67-E47E-46B1-A6F6-999A26193E57}"
@@ -107,26 +107,26 @@ Global
{1E6F7706-97B3-4929-8FF9-79DF5485801B}.Release|Any CPU.Build.0 = Release|Any CPU
{1E6F7706-97B3-4929-8FF9-79DF5485801B}.Release|x64.ActiveCfg = Release|x64
{1E6F7706-97B3-4929-8FF9-79DF5485801B}.Release|x64.Build.0 = Release|x64
{C076D0DF-C55C-461A-B6C9-8D0AC16175FD}.All|Any CPU.ActiveCfg = DefaultBuild
{C076D0DF-C55C-461A-B6C9-8D0AC16175FD}.All|Any CPU.Build.0 = DefaultBuild
{C076D0DF-C55C-461A-B6C9-8D0AC16175FD}.All|x64.ActiveCfg = DefaultBuild
{C076D0DF-C55C-461A-B6C9-8D0AC16175FD}.All|x64.Build.0 = DefaultBuild
{C076D0DF-C55C-461A-B6C9-8D0AC16175FD}.Debug One|Any CPU.ActiveCfg = DefaultBuild
{C076D0DF-C55C-461A-B6C9-8D0AC16175FD}.Debug One|Any CPU.Build.0 = DefaultBuild
{C076D0DF-C55C-461A-B6C9-8D0AC16175FD}.Debug One|x64.ActiveCfg = DefaultBuild
{C076D0DF-C55C-461A-B6C9-8D0AC16175FD}.Debug One|x64.Build.0 = DefaultBuild
{C076D0DF-C55C-461A-B6C9-8D0AC16175FD}.Debug|Any CPU.ActiveCfg = DefaultBuild
{C076D0DF-C55C-461A-B6C9-8D0AC16175FD}.Debug|Any CPU.Build.0 = DefaultBuild
{C076D0DF-C55C-461A-B6C9-8D0AC16175FD}.Debug|x64.ActiveCfg = DefaultBuild
{C076D0DF-C55C-461A-B6C9-8D0AC16175FD}.Debug|x64.Build.0 = DefaultBuild
{C076D0DF-C55C-461A-B6C9-8D0AC16175FD}.DefaultBuild|Any CPU.ActiveCfg = DefaultBuild
{C076D0DF-C55C-461A-B6C9-8D0AC16175FD}.DefaultBuild|Any CPU.Build.0 = DefaultBuild
{C076D0DF-C55C-461A-B6C9-8D0AC16175FD}.DefaultBuild|x64.ActiveCfg = DefaultBuild
{C076D0DF-C55C-461A-B6C9-8D0AC16175FD}.DefaultBuild|x64.Build.0 = DefaultBuild
{C076D0DF-C55C-461A-B6C9-8D0AC16175FD}.Release|Any CPU.ActiveCfg = DefaultBuild
{C076D0DF-C55C-461A-B6C9-8D0AC16175FD}.Release|Any CPU.Build.0 = DefaultBuild
{C076D0DF-C55C-461A-B6C9-8D0AC16175FD}.Release|x64.ActiveCfg = DefaultBuild
{C076D0DF-C55C-461A-B6C9-8D0AC16175FD}.Release|x64.Build.0 = DefaultBuild
{C076D0DF-C55C-461A-B6C9-8D0AC16175FD}.All|Any CPU.ActiveCfg = All|Any CPU
{C076D0DF-C55C-461A-B6C9-8D0AC16175FD}.All|Any CPU.Build.0 = All|Any CPU
{C076D0DF-C55C-461A-B6C9-8D0AC16175FD}.All|x64.ActiveCfg = All|x64
{C076D0DF-C55C-461A-B6C9-8D0AC16175FD}.All|x64.Build.0 = All|x64
{C076D0DF-C55C-461A-B6C9-8D0AC16175FD}.Debug One|Any CPU.ActiveCfg = Debug One|Any CPU
{C076D0DF-C55C-461A-B6C9-8D0AC16175FD}.Debug One|Any CPU.Build.0 = Debug One|Any CPU
{C076D0DF-C55C-461A-B6C9-8D0AC16175FD}.Debug One|x64.ActiveCfg = Debug One|x64
{C076D0DF-C55C-461A-B6C9-8D0AC16175FD}.Debug One|x64.Build.0 = Debug One|x64
{C076D0DF-C55C-461A-B6C9-8D0AC16175FD}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
{C076D0DF-C55C-461A-B6C9-8D0AC16175FD}.Debug|Any CPU.Build.0 = Debug|Any CPU
{C076D0DF-C55C-461A-B6C9-8D0AC16175FD}.Debug|x64.ActiveCfg = Debug|x64
{C076D0DF-C55C-461A-B6C9-8D0AC16175FD}.Debug|x64.Build.0 = Debug|x64
{C076D0DF-C55C-461A-B6C9-8D0AC16175FD}.DefaultBuild|Any CPU.ActiveCfg = DefaultBuild|Any CPU
{C076D0DF-C55C-461A-B6C9-8D0AC16175FD}.DefaultBuild|Any CPU.Build.0 = DefaultBuild|Any CPU
{C076D0DF-C55C-461A-B6C9-8D0AC16175FD}.DefaultBuild|x64.ActiveCfg = DefaultBuild|x64
{C076D0DF-C55C-461A-B6C9-8D0AC16175FD}.DefaultBuild|x64.Build.0 = DefaultBuild|x64
{C076D0DF-C55C-461A-B6C9-8D0AC16175FD}.Release|Any CPU.ActiveCfg = Release|Any CPU
{C076D0DF-C55C-461A-B6C9-8D0AC16175FD}.Release|Any CPU.Build.0 = Release|Any CPU
{C076D0DF-C55C-461A-B6C9-8D0AC16175FD}.Release|x64.ActiveCfg = Release|x64
{C076D0DF-C55C-461A-B6C9-8D0AC16175FD}.Release|x64.Build.0 = Release|x64
{F8C48DA5-7E26-4FA5-A9EE-4D80BA2E49F9}.All|Any CPU.ActiveCfg = Debug|Any CPU
{F8C48DA5-7E26-4FA5-A9EE-4D80BA2E49F9}.All|Any CPU.Build.0 = Debug|Any CPU
{F8C48DA5-7E26-4FA5-A9EE-4D80BA2E49F9}.All|x64.ActiveCfg = Debug|x64

View File

@@ -89,50 +89,6 @@ namespace Sai.RvKits.Properties {
return ((System.Drawing.Bitmap)(obj));
}
}
/// <summary>
/// 查找 System.Drawing.Bitmap 类型的本地化资源。
/// </summary>
internal static System.Drawing.Bitmap rotate_instance_16px
{
get
{
object obj = ResourceManager.GetObject("rotate_instance_16px", resourceCulture);
return ((System.Drawing.Bitmap)(obj));
}
}
/// <summary>
/// 查找 System.Drawing.Bitmap 类型的本地化资源。
/// </summary>
internal static System.Drawing.Bitmap rotate_instance_32px
{
get
{
object obj = ResourceManager.GetObject("rotate_instance_32px", resourceCulture);
return ((System.Drawing.Bitmap)(obj));
}
}
/// <summary>
/// 查找 System.Drawing.Bitmap 类型的本地化资源。
/// </summary>
internal static System.Drawing.Bitmap flip_workplane_16px
{
get
{
object obj = ResourceManager.GetObject("flip_workplane_16px", resourceCulture);
return ((System.Drawing.Bitmap)(obj));
}
}
/// <summary>
/// 查找 System.Drawing.Bitmap 类型的本地化资源。
/// </summary>
internal static System.Drawing.Bitmap flip_workplane_32px
{
get
{
object obj = ResourceManager.GetObject("flip_workplane_32px", resourceCulture);
return ((System.Drawing.Bitmap)(obj));
}
}
/// <summary>
/// 查找 System.Drawing.Bitmap 类型的本地化资源。
@@ -554,6 +510,26 @@ namespace Sai.RvKits.Properties {
}
}
/// <summary>
/// 查找 System.Drawing.Bitmap 类型的本地化资源。
/// </summary>
internal static System.Drawing.Bitmap flip_workplane_16px {
get {
object obj = ResourceManager.GetObject("flip_workplane_16px", resourceCulture);
return ((System.Drawing.Bitmap)(obj));
}
}
/// <summary>
/// 查找 System.Drawing.Bitmap 类型的本地化资源。
/// </summary>
internal static System.Drawing.Bitmap flip_workplane_32px {
get {
object obj = ResourceManager.GetObject("flip_workplane_32px", resourceCulture);
return ((System.Drawing.Bitmap)(obj));
}
}
/// <summary>
/// 查找 System.Drawing.Bitmap 类型的本地化资源。
/// </summary>
@@ -904,6 +880,26 @@ namespace Sai.RvKits.Properties {
}
}
/// <summary>
/// 查找 System.Drawing.Bitmap 类型的本地化资源。
/// </summary>
internal static System.Drawing.Bitmap rotate_instance_16px {
get {
object obj = ResourceManager.GetObject("rotate_instance_16px", resourceCulture);
return ((System.Drawing.Bitmap)(obj));
}
}
/// <summary>
/// 查找 System.Drawing.Bitmap 类型的本地化资源。
/// </summary>
internal static System.Drawing.Bitmap rotate_instance_32px {
get {
object obj = ResourceManager.GetObject("rotate_instance_32px", resourceCulture);
return ((System.Drawing.Bitmap)(obj));
}
}
/// <summary>
/// 查找 System.Drawing.Bitmap 类型的本地化资源。
/// </summary>

Binary file not shown.

After

Width:  |  Height:  |  Size: 16 KiB

View File

@@ -203,7 +203,7 @@ namespace Sai.RvKits.RvCivil
catch (Autodesk.Revit.Exceptions.OperationCanceledException) { }
catch (Exception e)
{
LogHelper.ToLog(e.Message, Variables.LogFolder);
e.Message.ToLog();
throw;
}
}
@@ -243,7 +243,12 @@ namespace Sai.RvKits.RvCivil
return normalFace;
}
/// <summary>
/// 查找所有管线定位线与元素面的碰撞点
/// </summary>
/// <param name="elementToOpen"></param>
/// <param name="curve"></param>
/// <returns></returns>
private static List<XYZ> FindIntersects(Element elementToOpen, Curve curve)
{
var faces = elementToOpen.GetAllGeometryObjects<Face>();

View File

@@ -121,7 +121,7 @@ public partial class InstanceCreatorViewModel : ObservableObject
Reference reference;
try
{
reference = uiDocument.Selection.PickObject(ObjectType.PointOnElement, new DwgBlockSelection(), "请选择dwg");
reference = uiDocument.Selection.PickObject(ObjectType.PointOnElement, new DwgBlockSelection(), "请选择dwg链接的块参照");
}
catch (Autodesk.Revit.Exceptions.OperationCanceledException)
{

View File

@@ -0,0 +1,10 @@
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace Sai.RvKits.RvMEP;
internal class ArrangeMEPCurveCmd
{
}

View File

@@ -28,11 +28,13 @@ internal class BloomConnectorCmd : ExternalCommand //根据连接件创建一根
elemIds.Add(Document.GetElement(reference).Id);
}
var pipeTypeId = ElementId.InvalidElementId;
var cableTrayTypeId = ElementId.InvalidElementId;
var conduitTypeId = ElementId.InvalidElementId;
foreach (var elemId in elemIds)
{
var pipeTypeId = Document.OfClass<PipeType>().FirstElementId();
var cableTrayTypeId = Document.OfClass<CableTrayType>().FirstElementId();
var conduitTypeId = Document.OfClass<ConduitType>().FirstElementId();
var filteredElementCollector = new FilteredElementCollector(Document).OfClass(typeof(DuctType));
var filteredElementCollector = Document.OfClass<DuctType>();
var roundTypeId = ElementId.InvalidElementId;
var rectangleTypeId = ElementId.InvalidElementId;
var ovalTypeId = ElementId.InvalidElementId;
@@ -55,10 +57,9 @@ internal class BloomConnectorCmd : ExternalCommand //根据连接件创建一根
}
}
var fabricationConfiguration = FabricationConfiguration.GetFabricationConfiguration(Document);
foreach (var elemId in elemIds)
{
var elem = Document.GetElement(elemId);
if (elem.GetConnectors(true).IsEmpty)
if (elem.GetConnectors(true).IsEmpty && elem is not FamilyInstance)
{
continue;
}
@@ -72,7 +73,7 @@ internal class BloomConnectorCmd : ExternalCommand //根据连接件创建一根
{
continue;
}
if (conn.Domain == Domain.DomainPiping)
if (conn.Domain == Domain.DomainPiping && connector.Owner is Pipe)
{
pipeTypeId = connector.Owner.GetTypeId();
}
@@ -112,7 +113,8 @@ internal class BloomConnectorCmd : ExternalCommand //根据连接件创建一根
Document.Invoke(
_ =>
{
foreach (Connector connector in elem.GetConnectors(true))
var conns = elem.GetConnectors(true);
foreach (Connector connector in conns)
{
Element element = null;
if (elem.Category.Id.IntegerValue == (int)BuiltInCategory.OST_FabricationPipework)
@@ -155,16 +157,21 @@ internal class BloomConnectorCmd : ExternalCommand //根据连接件创建一根
connector2.Height = connector.Height;
}
}
continue;
}
else
{
var extensionLength = connector.GetExtensionLength();
var origin = connector.Origin;
var xyz2 = origin + (extensionLength * connector.CoordinateSystem.BasisZ);
var levelId = elem.LevelId;
if (levelId == ElementId.InvalidElementId)
{
levelId = elem.get_Parameter(BuiltInParameter.RBS_START_LEVEL_PARAM).AsElementId();
var pa = elem.get_Parameter(BuiltInParameter.RBS_START_LEVEL_PARAM);
if (pa != null)
{
levelId = pa.AsElementId();
}
}
if (levelId == ElementId.InvalidElementId)
@@ -177,6 +184,7 @@ internal class BloomConnectorCmd : ExternalCommand //根据连接件创建一根
switch (connector.Domain)
{
//未定义
case Domain.DomainUndefined:
break;
//风管
@@ -283,16 +291,10 @@ internal class BloomConnectorCmd : ExternalCommand //根据连接件创建一根
var pipingSystemTypes = new FilteredElementCollector(Document)
.OfClass(typeof(PipingSystemType))
.Cast<PipingSystemType>();
if (pipeTypeId == ElementId.InvalidElementId
)
if (pipeTypeId == ElementId.InvalidElementId)
{
pipeTypeId = new FilteredElementCollector(Document).OfClass(
typeof(PipeType))
.FirstElementId();
break;
pipeTypeId = Document.OfClass<PipeType>().WhereElementIsElementType().FirstElementId();
}
var system = connector.MEPSystem;
var pipingSystemType =
system != null
@@ -383,9 +385,9 @@ internal class BloomConnectorCmd : ExternalCommand //根据连接件创建一根
== Autodesk.Revit.DB.MEPSystemClassification.OtherPipe
)
};
element = Pipe.Create(Document, pipingSystemType.Id, pipeTypeId, levelId, origin, xyz2);
element.get_Parameter(BuiltInParameter.RBS_PIPE_DIAMETER_PARAM).Set(connector.Radius * 2);
break;
//电力
case Domain.DomainCableTrayConduit:
@@ -451,7 +453,6 @@ internal class BloomConnectorCmd : ExternalCommand //根据连接件创建一根
}
}
}
}
},
"引出短管"
);

View File

@@ -14,7 +14,7 @@
MinWidth="250"
MinHeight="280"
d:DataContext="{d:DesignInstance Type={x:Type local:RotateMEPViewModel}}"
SizeToContent="WidthAndHeight"
SizeToContent="Height"
mc:Ignorable="d">
<Window.Resources>
<ResourceDictionary Source="pack://application:,,,/Sai.RvKits;component/WPFUI.xaml" />

View File

@@ -17,7 +17,7 @@ namespace Sai.RvKits.RvMEP
public partial class RotateMEPViewModel : ObservableObject
{
[ObservableProperty]
private double angle;
private double angle = 90;
[ObservableProperty]
private bool isSingleSelect = true;
[RelayCommand]
@@ -40,7 +40,7 @@ namespace Sai.RvKits.RvMEP
var r = uidoc.Selection.PickObject(ObjectType.Element, new FuncFilter(e =>
{
return e is FamilyInstance && e.GetConnectors().OfType<Connector>().Any(c => c.IsConnected);
}), "请选择可以连管的构件");
}), "请选择已经连管的构件");
elemIds.Add(r.ElementId);
}
@@ -49,15 +49,40 @@ namespace Sai.RvKits.RvMEP
elemIds = uidoc.Selection.PickObjects(ObjectType.Element, new FuncFilter(e =>
{
return e is FamilyInstance && e.GetConnectors().OfType<Connector>().Any(c => c.IsConnected);
}), "请选择可以连管的构件,并完成").Select(r => doc.GetElement(r).Id).ToList();
}), "请选择已经连管的构件,并完成").Select(r => doc.GetElement(r).Id).ToList();
}
}
foreach (var id in uidoc.Selection.GetElementIds())
foreach (var id in elemIds)
{
var elem = uidoc.Document.GetElement(id);
var referConn = elem.GetConnectors().OfType<Connector>().FirstOrDefault(c => c.IsConnected);
var referConn = elem.GetConnectors().OfType<Connector>().FirstOrDefault(c =>
{
if (c.IsConnected)
{
if (c.CoordinateSystem.BasisZ.X > 0)
{
return true;
}
else
{
if (c.CoordinateSystem.BasisZ.Y > 0)
{
return true;
}
else
{
if (c.CoordinateSystem.BasisZ.Z > 0)
{
return true;
}
}
}
}
return false;
});
if (referConn != null)
{
@@ -71,7 +96,7 @@ namespace Sai.RvKits.RvMEP
referConn.CoordinateSystem.Origin,
referConn.CoordinateSystem.BasisZ),
Angle.ToRadian());
}, "旋转");
}, "旋转实例");
}
}
});

View File

@@ -21,6 +21,6 @@ public class QuickViewSectionCmd : ExternalCommand
{
public override void Execute()
{
WinDialogHelper.ShowModeless<QuickViewSectionView>(new QuickViewSectionViewModel(UiDocument));
WinDialogHelper.ShowModeless<QuickViewSectionView>(new QuickViewSectionViewModel());
}
}

View File

@@ -9,7 +9,6 @@
Title="快速剖面"
Width="250"
Height="180"
MinHeight="180"
d:DataContext="{d:DesignInstance Type=local:QuickViewSectionViewModel}"
SizeToContent="Height"
mc:Ignorable="d">
@@ -17,7 +16,7 @@
<ResourceDictionary Source="pack://application:,,,/Sai.RvKits;component/WPFUI.xaml" />
</Window.Resources>
<ex:StackPanelEx Margin="5" Spacing="5">
<GroupBox Grid.Row="0" Header="剖面线">
<GroupBox Header="剖面线">
<UniformGrid Rows="1">
<RadioButton
HorizontalAlignment="Center"
@@ -30,10 +29,18 @@
IsChecked="{Binding IsParallel, Converter={StaticResource InvertBooleanConverter}}" />
</UniformGrid>
</GroupBox>
<UniformGrid Rows="1">
<Button
Grid.Row="1"
Margin="5"
HorizontalAlignment="Stretch"
Command="{Binding CreateViewSectionCommand}"
Content="创建" />
<Button
Margin="5"
HorizontalAlignment="Stretch"
Command="{Binding DeleteViewSectionCommand}"
Content="删除"
ToolTip="删除全部在当前窗口打开时(本次)创建的快速剖面" />
</UniformGrid>
</ex:StackPanelEx>
</ex:FluentWindowEx>

View File

@@ -1,4 +1,6 @@
using System.Diagnostics;
using System.Collections.ObjectModel;
using System.Diagnostics;
using System.Windows;
using Autodesk.Revit.DB;
using Autodesk.Revit.UI;
@@ -10,19 +12,49 @@ using Nice3point.Revit.Toolkit.External.Handlers;
namespace Sai.RvKits.RvView
{
public partial class QuickViewSectionViewModel(UIDocument uidoc) : ObservableObject
public partial class QuickViewSectionViewModel : ObservableObject
{
private readonly ActionEventHandler handler = new();
[ObservableProperty]
private bool isParallel = true;
private readonly List<ViewSection> viewSections = [];
[RelayCommand]
private void DeleteViewSection()
{
handler.Raise(
uiapp =>
{
var uidoc = uiapp.ActiveUIDocument;
var doc = uidoc.Document;
doc.Invoke(
ts =>
{
for (var i = viewSections.Count - 1; i >= 0; i--)
{
var view = viewSections[i];
if (view.IsValidObject)
{
var uiView = uidoc.GetOpenUIViews().FirstOrDefault(ui => ui.ViewId == view.Id);
uiView?.Close();
viewSections.Remove(view);
doc.Delete(view.Id);
}
}
}, "删除快速剖面");
});
}
[RelayCommand]
private void CreateViewSection()
{
var element = uidoc.SelectObject(new FuncFilter(elem => elem.GetLocCurve() is Line));
if (element != null)
handler.Raise(
uiapp =>
{
var uidoc = uiapp.ActiveUIDocument;
var element = uidoc.SelectObject(new FuncFilter(elem => elem.GetLocCurve() is Line));
var lc = element.Location as LocationCurve;
var line = lc.Curve as Line;
var doc = uidoc.Document;
@@ -91,9 +123,6 @@ namespace Sai.RvKits.RvView
Max = max
};
}
handler.Raise(
_ =>
{
doc.Invoke(
ts =>
{
@@ -124,6 +153,10 @@ namespace Sai.RvKits.RvView
}
}
ts.Commit();
if (viewSection != null)
{
viewSections.Add(viewSection);
}
Debug.WriteLine("生成后:");
Debug.WriteLine($"CropBox.Origin{viewSection.CropBox.Transform.Origin}");
@@ -141,9 +174,8 @@ namespace Sai.RvKits.RvView
uidoc.ActiveView = viewSection;
uidoc.Selection.SetElementIds([element.Id]);
}
}, "创建快速剖面");
});
});
}
}
}

View File

@@ -1,4 +1,5 @@
using System.Windows;
using System.Windows.Controls.Primitives;
using Autodesk.Revit.DB;
using Autodesk.Revit.UI;
@@ -52,7 +53,12 @@ public partial class VisibilityViewModel : ObservableObject
doc.Invoke(
_ =>
{
uidoc.ActiveView.SetCategoryHidden(new ElementId(BuiltInCategory.OST_StructuralFraming), value == false);
foreach (var builtInCategory in beamCategory)
{
var categoryId = Category.GetCategory(doc, builtInCategory).Id;
uidoc.ActiveView.SetCategoryHidden(categoryId, value == false);
}
},
"梁显隐"
);
@@ -73,8 +79,12 @@ public partial class VisibilityViewModel : ObservableObject
doc.Invoke(
_ =>
{
uidoc.ActiveView.SetCategoryHidden(new ElementId(BuiltInCategory.OST_CableTray), value == false);
uidoc.ActiveView.SetCategoryHidden(new ElementId(BuiltInCategory.OST_CableTrayFitting), value == false);
foreach (var builtInCategory in cabletrayCategory)
{
var categoryId = Category.GetCategory(doc, builtInCategory).Id;
uidoc.ActiveView.SetCategoryHidden(categoryId, value == false);
}
},
"桥架显隐"
);
@@ -95,8 +105,12 @@ public partial class VisibilityViewModel : ObservableObject
doc.Invoke(
_ =>
{
uidoc.ActiveView.SetCategoryHidden(new ElementId(BuiltInCategory.OST_StructuralColumns), value == false);
uidoc.ActiveView.SetCategoryHidden(new ElementId(BuiltInCategory.OST_Columns), value == false);
foreach (var builtInCategory in columnsCategory)
{
var categoryId = Category.GetCategory(doc, builtInCategory).Id;
uidoc.ActiveView.SetCategoryHidden(categoryId, value == false);
}
},
"柱显隐"
);
@@ -117,7 +131,12 @@ public partial class VisibilityViewModel : ObservableObject
doc.Invoke(
_ =>
{
uidoc.ActiveView.SetCategoryHidden(new ElementId(BuiltInCategory.OST_Walls), value == false);
foreach (var builtInCategory in wallCategory)
{
var categoryId = Category.GetCategory(doc, builtInCategory).Id;
uidoc.ActiveView.SetCategoryHidden(categoryId, value == false);
}
},
"墙显隐"
);
@@ -138,7 +157,12 @@ public partial class VisibilityViewModel : ObservableObject
doc.Invoke(
_ =>
{
uidoc.ActiveView.SetCategoryHidden(new ElementId(BuiltInCategory.OST_Floors), value == false);
foreach (var builtInCategory in floorCategory)
{
var categoryId = Category.GetCategory(doc, builtInCategory).Id;
uidoc.ActiveView.SetCategoryHidden(categoryId, value == false);
}
},
"楼板显隐"
);
@@ -159,8 +183,12 @@ public partial class VisibilityViewModel : ObservableObject
doc.Invoke(
_ =>
{
uidoc.ActiveView.SetCategoryHidden(new ElementId(BuiltInCategory.OST_Conduit), value == false);
uidoc.ActiveView.SetCategoryHidden(new ElementId(BuiltInCategory.OST_ConduitFitting), value == false);
foreach (var builtInCategory in conduitCategory)
{
var categoryId = Category.GetCategory(doc, builtInCategory).Id;
uidoc.ActiveView.SetCategoryHidden(categoryId, value == false);
}
},
"线管显隐"
);
@@ -181,9 +209,12 @@ public partial class VisibilityViewModel : ObservableObject
doc.Invoke(
_ =>
{
uidoc.ActiveView.SetCategoryHidden(new ElementId(BuiltInCategory.OST_DuctCurves), value == false);
uidoc.ActiveView.SetCategoryHidden(new ElementId(BuiltInCategory.OST_DuctAccessory), value == false);
uidoc.ActiveView.SetCategoryHidden(new ElementId(BuiltInCategory.OST_DuctFitting), value == false);
foreach (var builtInCategory in mechanicalCategory)
{
var categoryId = Category.GetCategory(doc, builtInCategory).Id;
uidoc.ActiveView.SetCategoryHidden(categoryId, value == false);
}
},
"暖通显隐"
);
@@ -204,10 +235,12 @@ public partial class VisibilityViewModel : ObservableObject
doc.Invoke(
_ =>
{
uidoc.ActiveView.SetCategoryHidden(new ElementId(BuiltInCategory.OST_PipeCurves), value == false);
uidoc.ActiveView.SetCategoryHidden(new ElementId(BuiltInCategory.OST_PipeFitting), value == false);
uidoc.ActiveView.SetCategoryHidden(new ElementId(BuiltInCategory.OST_PipeAccessory), value == false);
uidoc.ActiveView.SetCategoryHidden(new ElementId(BuiltInCategory.OST_Sprinklers), value == false);
foreach (var builtInCategory in pipingCategory)
{
var categoryId = Category.GetCategory(doc, builtInCategory).Id;
uidoc.ActiveView.SetCategoryHidden(categoryId, value == false);
}
},
"给排水显隐"
);
@@ -244,6 +277,35 @@ public partial class VisibilityViewModel : ObservableObject
}
return true;
}
readonly BuiltInCategory[] wallCategory = [BuiltInCategory.OST_Walls];
readonly BuiltInCategory[] beamCategory = [BuiltInCategory.OST_StructuralFraming];
readonly BuiltInCategory[] floorCategory = [BuiltInCategory.OST_Floors];
readonly BuiltInCategory[] columnsCategory = [
BuiltInCategory.OST_StructuralColumns,
BuiltInCategory.OST_Columns];
readonly BuiltInCategory[] mechanicalCategory = [
BuiltInCategory.OST_DuctCurves,
BuiltInCategory.OST_DuctAccessory,
BuiltInCategory.OST_DuctFitting,
BuiltInCategory.OST_DuctInsulations,
BuiltInCategory.OST_DuctTerminal,
BuiltInCategory.OST_FlexDuctCurves,
BuiltInCategory.OST_PlaceHolderDucts,BuiltInCategory.OST_MechanicalEquipment];
readonly BuiltInCategory[] pipingCategory = [
BuiltInCategory.OST_PipeCurves,
BuiltInCategory.OST_PipeFitting,
BuiltInCategory.OST_PipeAccessory,
BuiltInCategory.OST_PipeInsulations,
BuiltInCategory.OST_Sprinklers,
BuiltInCategory.OST_FlexPipeCurves,
BuiltInCategory.OST_PlaceHolderPipes,
BuiltInCategory.OST_PlumbingFixtures];
readonly BuiltInCategory[] cabletrayCategory = [
BuiltInCategory.OST_CableTray,
BuiltInCategory.OST_CableTrayFitting,];
readonly BuiltInCategory[] conduitCategory = [
BuiltInCategory.OST_Conduit,
BuiltInCategory.OST_ConduitFitting,];
private void UpdateCheckedState(Document doc)
{
@@ -251,14 +313,14 @@ public partial class VisibilityViewModel : ObservableObject
{
return;
}
WallChecked = GetCheckedStatue(doc, BuiltInCategory.OST_Walls);
BeamChecked = GetCheckedStatue(doc, BuiltInCategory.OST_StructuralFraming);
FloorChecked = GetCheckedStatue(doc, BuiltInCategory.OST_Floors);
ColumnChecked = GetCheckedStatue(doc, BuiltInCategory.OST_StructuralColumns, BuiltInCategory.OST_Columns);
MechanicalChecked = GetCheckedStatue(doc, BuiltInCategory.OST_DuctCurves, BuiltInCategory.OST_DuctAccessory, BuiltInCategory.OST_DuctFitting);
PlumbingChecked = GetCheckedStatue(doc, BuiltInCategory.OST_PipeCurves, BuiltInCategory.OST_PipeFitting, BuiltInCategory.OST_PipeAccessory, BuiltInCategory.OST_Sprinklers);
CableTrayChecked = GetCheckedStatue(doc, BuiltInCategory.OST_CableTray, BuiltInCategory.OST_CableTrayFitting);
ConduitChecked = GetCheckedStatue(doc, BuiltInCategory.OST_Conduit, BuiltInCategory.OST_ConduitFitting);
WallChecked = GetCheckedStatue(doc, wallCategory);
BeamChecked = GetCheckedStatue(doc, beamCategory);
FloorChecked = GetCheckedStatue(doc, floorCategory);
ColumnChecked = GetCheckedStatue(doc, columnsCategory);
MechanicalChecked = GetCheckedStatue(doc, mechanicalCategory);
PlumbingChecked = GetCheckedStatue(doc, pipingCategory);
CableTrayChecked = GetCheckedStatue(doc, cabletrayCategory);
ConduitChecked = GetCheckedStatue(doc, conduitCategory);
}
[RelayCommand]

View File

@@ -82,12 +82,13 @@
<ItemGroup>
<PackageReference Include="CommunityToolkit.Common" Version="8.3.2" />
<PackageReference Include="CommunityToolkit.Diagnostics" Version="8.3.2" />
<PackageReference Include="CommunityToolkit.Mvvm" Version="8.3.2" />
<PackageReference Include="EPPlus.Core.Extensions" Version="2.4.0" />
<PackageReference Include="ACadSharp" Version="1.0.0" />
<PackageReference Include="FuzzySharp" Version="2.0.2" />
<PackageReference Include="HtmlAgilityPack" Version="1.11.65" />
<!--TreatAsUsed="true"标记为已使用-->
<PackageReference Include="Microsoft.Xaml.Behaviors.Wpf" Version="1.1.122" TreatAsUsed="true" />
<PackageReference Include="Microsoft.Xaml.Behaviors.Wpf" Version="1.1.135" TreatAsUsed="true" />
<PackageReference Include="randomColorSharped.NetStandard" Version="1.0.2" />
</ItemGroup>
<!-- <ItemGroup Condition="$(DefineConstants.Contains('WINFORMS'))"> -->

View File

@@ -1,61 +0,0 @@
using System.Drawing;
using System.Timers;
using Autodesk.Revit.Attributes;
using Autodesk.Revit.DB;
using Autodesk.Revit.UI;
using Nice3point.Revit.Toolkit.External;
using Sai.Toolkit.Core.Helpers;
namespace Sai.RvKits;
[Transaction(TransactionMode.Manual)]
[Regeneration(RegenerationOption.Manual)]
public class TestGDI : ExternalCommand
{
private UIView ui;
/// <summary>
/// 设置项目基点
/// </summary>
/// <param name="position"></param>
private void SetProjectPosition(XYZ position)
{
using Transaction trans = new(Document);
trans.Start("设置项目基点");
XYZ p = new();
ProjectPosition pp = new(position.X, position.Y, position.Z, 0);
//设置项目基点
Document.ActiveProjectLocation.SetProjectPosition(p, pp);
trans.Commit();
}
public override void Execute()
{
ui = UiDocument.GetOpenUIViews().FirstOrDefault(uiView => uiView.ViewId == UiDocument.ActiveView.Id);
var corners = ui.GetZoomCorners();
//var inptr = HookInptr.FindWindow(null, view.Name);
//Graphics graphics = Graphics.FromHwnd(inptr);
//graphics.RenderingOrigin=
//Graphics graphics = Graphics.FromHwnd(System.Diagnostics.Process.GetCurrentProcess().Handle);
System.Timers.Timer timer =
new(2000)
{
Interval = 500,
Enabled = true
//AutoReset = true
};
timer.Elapsed += Timer_Elapsed;
}
private void Timer_Elapsed(object sender, ElapsedEventArgs e)
{
var rectangle = ui.GetWindowRectangle(); //屏幕坐标;原点在右上角
var graphics = Graphics.FromHwnd(System.Diagnostics.Process.GetCurrentProcess().MainWindowHandle);
var p = new System.Drawing.Point(rectangle.Left + 1920, rectangle.Top);
var p1 = new System.Drawing.Point(rectangle.Right + 1920, rectangle.Bottom);
GdiHelper.DrawLine(graphics, p, p1);
}
}

View File

@@ -29,69 +29,69 @@ public class DrawingViewApp
{
var ribbonPanel = application.CreateRibbonPanel(TabName, "视图与出图");
var autoAlignTags = UIAssist.NewButtonData<AlignTagsCmd>(
var autoAlignTags = UIAssist.NewPushButtonData<AlignTagsCmd>(
"对齐标记",
Resources.align_tags_32px,
Resources.align_tags_16px
).SetAvailability<EnableInViewPlan>();
var arrangeTags = UIAssist.NewButtonData<ArrangeTagsCmd>(
var arrangeTags = UIAssist.NewPushButtonData<ArrangeTagsCmd>(
"整理标记",
Resources.arrange_tags_32px,
Resources.arrange_tags_16px
).SetAvailability<EnableInViewPlan>();
var dim2Line = UIAssist.NewButtonData<DimensionBy2LineCmd>(
var dim2Line = UIAssist.NewPushButtonData<DimensionBy2LineCmd>(
"双线标注",
Resources.two_lines_32px,
Resources.two_lines_16px,
"选择要标注的两条平行的几何模型边缘线进行标注。"
);
var visibilityControl = UIAssist.NewButtonData<VisibilityControlCmd>(
var visibilityControl = UIAssist.NewPushButtonData<VisibilityControlCmd>(
"可见性",
Resources.visibility_control_32px,
Resources.visibility_control_16px,
"可见性控制"
).SetAvailability<OnProjectDocument>();
var sectionBox = UIAssist.NewButtonData<SectionBoxControllerCmd>(
var sectionBox = UIAssist.NewPushButtonData<SectionBoxControllerCmd>(
"剖面框",
Resources.sectionBox_32px,
Resources.sectionBox_16px
);
var filter = UIAssist.NewButtonData<CivilViewFilterCmd>(
var filter = UIAssist.NewPushButtonData<CivilViewFilterCmd>(
"过滤器",
Resources.filter_32px,
Resources.filter_16px,
"创建当前视图的结构模型区分的过滤"
);
var panelSchedule = UIAssist.NewButtonData<PanelScheduleCmd>(
var panelSchedule = UIAssist.NewPushButtonData<PanelScheduleCmd>(
"铺砖明细表",
Resources.schedule_32px,
Resources.schedule_16px
);
var exportSchedulesPbd = UIAssist.NewButtonData<ExportSchedulesCmd>(
var exportSchedulesPbd = UIAssist.NewPushButtonData<ExportSchedulesCmd>(
"导出明细表",
Resources.export_excel_32px,
Resources.export_excel_16px,
"导出明细表为Excel文件"
);
var systemDisplay = UIAssist.NewButtonData<SystemDisplayCmd>(
var systemDisplay = UIAssist.NewPushButtonData<SystemDisplayCmd>(
"系统显示",
Resources.system_display_32px,
Resources.system_display_16px
);
var viewManager = UIAssist.NewButtonData<ViewManagerCmd>(
var viewManager = UIAssist.NewPushButtonData<ViewManagerCmd>(
"视图管理",
Resources.view_manager_32px,
Resources.view_manager_16px
);
var quickViewSection = UIAssist.NewButtonData<QuickViewSectionCmd>(
var quickViewSection = UIAssist.NewPushButtonData<QuickViewSectionCmd>(
"快速剖面",
Resources.view_section_32px,
Resources.view_section_16px
);
var elementsControlCmd = UIAssist.NewButtonData<ElementsControlCmd>(
var elementsControlCmd = UIAssist.NewPushButtonData<ElementsControlCmd>(
"元素控制",
Resources.open_pane_32px,
Resources.open_pane_32px,
@@ -103,8 +103,9 @@ public class DrawingViewApp
//ribbonPanel.AddSplitButton(splitBtn1, dim2Line, autoAlignTags, arrangeTags);
ribbonPanel.AddItem(elementsControlCmd);
var tab = ComponentManager.Ribbon.Tabs.First(t => t.Name == TabName);
ribbonPanel.AddStackedItems(systemDisplay, viewManager, quickViewSection);
var tab = ComponentManager.Ribbon.Tabs.First(t => t.Name == TabName);
CreateToggleButton(tab, "视图与出图");
//面板下拉展开
ribbonPanel.AddSlideOut();
@@ -120,17 +121,21 @@ public class DrawingViewApp
try
{
var panel = rt.Panels.FirstOrDefault(p => p.Source.Name == panelName);
var tog = new Autodesk.Windows.RibbonToggleButton()
{
LargeImage = Resources.zoom_32px.ToBitmapSource(),
Size = RibbonItemSize.Large,
Name = "ZoomElement",
Text = "最大化",
ShowText = true,
ToolTip = "根据视图的图元是否可见,在切换视图时,对当前选中的图元进行快速缩放定位",
IsCheckable = true,
Orientation = System.Windows.Controls.Orientation.Vertical,
};
var tog = UIAssist.NewAwToggleButton(
"最大化",
Resources.zoom_32px,
"根据视图的图元是否可见,在切换视图时,对当前选中的图元进行快速缩放定位");
//var tog = new Autodesk.Windows.RibbonToggleButton()
//{
// LargeImage = Resources.zoom_32px.ToBitmapSource(),
// Size = RibbonItemSize.Large,
// Name = "ZoomElement",
// Text = "最大化",
// ShowText = true,
// ToolTip = "根据视图的图元是否可见,在切换视图时,对当前选中的图元进行快速缩放定位",
// IsCheckable = true,
// Orientation = System.Windows.Controls.Orientation.Vertical,
//};
tog.CheckStateChanged += (s, e) =>
{
zoomElementHandler.Raise(
@@ -153,7 +158,7 @@ public class DrawingViewApp
}
catch (Exception exception)
{
MessageBox.Show(exception.Message, "错误");
MessageBox.Show(exception.Message, "添加TogButton错误");
}
}
private static void RegisterDockPaneAndEvent(UIControlledApplication application)

View File

@@ -172,7 +172,7 @@ public class FamilyApp
//application.CreateRibbonTab(TabName);
//UserPanel.AddItem(_loginPBData);
//UserPanel.AddAwItem(_loginPBData);
//".\\*.*"中的“.”表示通用类库文件所在的目录Debug“..”表示的是上级的目录bin“..”\\..,引号表示再上一级目录
//ContextualHelp contextualHelp = new ContextualHelp(ContextualHelpType.Url, "https://www.szmedi.com.cn");
//_loginPBData.CreateContextualHelp(contextualHelp);
@@ -180,37 +180,37 @@ public class FamilyApp
var familyManagePanel = application.CreateRibbonPanel(TabName, VbPanelName);
//在面板上添加添加浏览族库按钮
var localFamilyPbd = UIAssist.NewButtonData<FamilyLibraryCmd>(
var localFamilyPbd = UIAssist.NewPushButtonData<FamilyLibraryCmd>(
"本地族库",
Resources.library_32px,
Resources.library_16px
);
var familyMassSave = UIAssist.NewButtonData<FamilyProcessorCmd>(
var familyMassSave = UIAssist.NewPushButtonData<FamilyProcessorCmd>(
"族复用",
Resources.family_processor_32px,
Resources.family_processor_16px
);
var replaceInstance = UIAssist.NewButtonData<ReplaceInstanceCmd>(
var replaceInstance = UIAssist.NewPushButtonData<ReplaceInstanceCmd>(
"替换族",
Resources.replace_32px,
Resources.replace_16px
);
var updateFamilyFile = UIAssist.NewButtonData<UpgradeFamilyCmd>(
var updateFamilyFile = UIAssist.NewPushButtonData<UpgradeFamilyCmd>(
"更新族",
Resources.available_updates_32px,
Resources.available_updates_16px,
"更新族文件缩略图及升级至当前版本"
);
var renameFamily = UIAssist.NewButtonData<RenameFamilyNameCmd>(
var renameFamily = UIAssist.NewPushButtonData<RenameFamilyNameCmd>(
"重命名族",
Resources.rename_family_32px,
Resources.rename_family_16px
);
var renameType = UIAssist.NewButtonData<RenameTypeNameCmd>(
var renameType = UIAssist.NewPushButtonData<RenameTypeNameCmd>(
"重命名类型",
Resources.rename_type_32px,
Resources.rename_type_16px

View File

@@ -536,7 +536,7 @@ public class ModifyTabApp
};
//面板行布局
RibbonRowPanel ribbonRowPanel = new();
ribbonRowPanel.AddStackItems(iavBtn, iipBtn, rSelBtn);
ribbonRowPanel.AddAwStackItems(iavBtn, iipBtn, rSelBtn);
//ribbonRowPanel.Items.Add(iavBtn);
////行打断=新建行

View File

@@ -20,11 +20,11 @@ namespace Sai.RvKits.UIRibbon;
public class RvApp : ExternalApplication
{
private static readonly string TabName = Settings.Default.TabName;
public static AsyncEventHandler SaveHandler { get; } = new();
private AsyncEventHandler saveHandler;
private static void OnTimedEvent(object source, System.Timers.ElapsedEventArgs e)
private void OnTimedEvent(object source, System.Timers.ElapsedEventArgs e)
{
SaveHandler.RaiseAsync(app =>
saveHandler.RaiseAsync(app =>
{
#if REVIT2018
if (app.ActiveUIDocument.Document.IsModified)
@@ -41,19 +41,9 @@ public class RvApp : ExternalApplication
}
public override void OnStartup()
{
saveHandler = new();
UiApplication.CreateRibbonTab(Settings.Default.TabName);
var ribbon = Autodesk.Windows.ComponentManager.Ribbon;
Autodesk.Windows.RibbonTab rt = null;
foreach (var tab in ribbon.Tabs)
{
if (tab.Name == Settings.Default.TabName)
{
rt = tab;
ribbon.Tabs.Remove(tab);
break;
}
}
var versionNumber = UiApplication.Application.VersionNumber;
var subVersionNumber = UiApplication.Application.SubVersionNumber;
var subVersion = new Version(subVersionNumber);
@@ -62,6 +52,20 @@ public class RvApp : ExternalApplication
{
MessageBox.Show("版本小于2018.1,部分功能可能无法使用请使用升级补丁升级Revit软件", "提示");
}
var ribbon = Autodesk.Windows.ComponentManager.Ribbon;
var rt = ribbon.Tabs.FirstOrDefault(tab => tab.Name == Settings.Default.TabName);
ribbon.Tabs.Remove(rt);
//foreach (var tab in ribbon.Tabs)
//{
// if (tab.Name == Settings.Default.TabName)
// {
// rt = tab;
// ribbon.Tabs.Remove(tab);
// break;
// }
//}
ribbon.Tabs.Insert(0, rt);
CivilApp(Application);
@@ -86,49 +90,49 @@ public class RvApp : ExternalApplication
{
var ribbonPanel = application.CreateRibbonPanel(TabName, "土建装饰");
var floorFinishesPbd = UIAssist.NewButtonData<FloorFinishesCmd>(
var floorFinishesPbd = UIAssist.NewPushButtonData<FloorFinishesCmd>(
"房间饰面",
Resources.tites_32px,
Resources.tites_16px,
"创建房间饰面"
);
var curtainFinishesPbd = UIAssist.NewButtonData<BricksFinishesCmd>(
var curtainFinishesPbd = UIAssist.NewPushButtonData<BricksFinishesCmd>(
"铺贴饰面",
Resources.finishes_32px,
Resources.finishes_16px
);
var wallFinishesPbd = UIAssist.NewButtonData<WallFinishesCmd>(
var wallFinishesPbd = UIAssist.NewPushButtonData<WallFinishesCmd>(
"墙饰面",
Resources.bricks_32px,
Resources.bricks_16px
);
var slopeFloorPbd = UIAssist.NewButtonData<SlopedFloorCmd>(
var slopeFloorPbd = UIAssist.NewPushButtonData<SlopedFloorCmd>(
"坡度楼板",
Resources.slope_floor_32px,
Resources.slope_floor_16px,
"分别选择两个楼板的两条平行线创建坡度楼板"
);
var createOpeningsPbd = UIAssist.NewButtonData<CreateOpeningsCmd>(
var createOpeningsPbd = UIAssist.NewPushButtonData<CreateOpeningsCmd>(
"创建洞口",
Resources.openings_32px,
Resources.openings_16px,
"根据管线创建洞口"
).SetAvailability<EnableInView3D>();
var modelSplitPbd = UIAssist.NewButtonData<ModelSplitterCmd>(
var modelSplitPbd = UIAssist.NewPushButtonData<ModelSplitterCmd>(
"模型拆分",
Resources.separation_32px,
Resources.separation_16px,
"按标高拆分为单独的文件"
);
var splitComPbd = UIAssist.NewButtonData<SplitComsByLevelCmd>(
var splitComPbd = UIAssist.NewPushButtonData<SplitComsByLevelCmd>(
"分割墙柱",
Resources.model_split_32px,
Resources.model_split_16px,
"按标高拆分墙、柱"
);
var connectPbd = UIAssist.NewButtonData<CivilConnectionCmd>(
var connectPbd = UIAssist.NewPushButtonData<CivilConnectionCmd>(
"土建连接",
Resources.connect_32px,
Resources.connect_16px,
@@ -147,68 +151,68 @@ public class RvApp : ExternalApplication
null,
Resources.stand_mepcurve_16px
).SetAvailability<EnableInViewPlan>();
var bloomConnector = UIAssist.NewButtonData<BloomConnectorCmd>("引出管线", null, Resources.bloom_16px, "从连接件生成管线");
var anyConnect = UIAssist.NewButtonData<AnyConnectCmd>("任意连接", null, Resources.any_connect_16px, "选择任意管线进行连接");
var moveConnect = UIAssist.NewButtonData<MoveConnectCmd>(
var bloomConnector = UIAssist.NewPushButtonData<BloomConnectorCmd>("引出管线", null, Resources.bloom_16px, "从连接件生成管线");
var anyConnect = UIAssist.NewPushButtonData<AnyConnectCmd>("任意连接", null, Resources.any_connect_16px, "选择任意管线进行连接");
var moveConnect = UIAssist.NewPushButtonData<MoveConnectCmd>(
"移动连接",
null,
Resources.move_connect_16px,
"根据最近距离的未连接的连接件,将其连接或角度过大则对齐连接"
);
var breakMepCurveBtn = UIAssist.NewButtonData<BreakMEPCurveCmd>(
var breakMepCurveBtn = UIAssist.NewPushButtonData<BreakMEPCurveCmd>(
"打断管线",
null,
Resources.break_mepcurve_16px,
"将管线打断成两根管线并保留打断后的连接关系"
);
var disConnect = UIAssist.NewButtonData<DisconnectCmd>(
var disConnect = UIAssist.NewPushButtonData<DisconnectCmd>(
"取消连接",
null,
Resources.disconnect_16px,
"取消设备、管线之间的连接"
);
var correctSlope = UIAssist.NewButtonData<CorrectMEPCurveSlopeCmd>(
var correctSlope = UIAssist.NewPushButtonData<CorrectMEPCurveSlopeCmd>(
"坡度修正",
null,
Resources.correct_mep_16px,
"修正管线的坡度"
);
var moveMEP = UIAssist.NewButtonData<MoveMEPCmd>(
var moveMEP = UIAssist.NewPushButtonData<MoveMEPCmd>(
"移动管线",
Resources.move_MEP_32px,
Resources.move_MEP_16px,
"基于管线底部参照或距离,上下移动管线"
);
var clashReport = UIAssist.NewButtonData<ClashReportCmd>(
var clashReport = UIAssist.NewPushButtonData<ClashReportCmd>(
"碰撞报告",
Resources.clash_report_32px,
Resources.clash_report_16px,
"根据Revit生成的报告快速定位碰撞构件"
);
var terminalConnect = UIAssist.NewButtonData<TerminalConnectToDuctCmd>(
var terminalConnect = UIAssist.NewPushButtonData<TerminalConnectToDuctCmd>(
"连接风口",
Resources.air_terminal_32px,
Resources.air_terminal_16px
);
var clashResolve = UIAssist.NewButtonData<ClashResolveCmd>(
var clashResolve = UIAssist.NewPushButtonData<ClashResolveCmd>(
"碰撞处理",
Resources.clash_resolve_32px,
Resources.clash_resolve_16px
);
var headroomCheck = UIAssist.NewButtonData<HeadroomCheckCmd>(
var headroomCheck = UIAssist.NewPushButtonData<HeadroomCheckCmd>(
"净高检查",
Resources.head_room_32px,
Resources.head_room_16px
);
var flipWorkplane = UIAssist.NewButtonData<FlipWorkplaneCmd>(
var flipWorkplane = UIAssist.NewPushButtonData<FlipWorkplaneCmd>(
"翻转工作平面",
Resources.flip_workplane_32px,
Resources.flip_workplane_16px,
"将可以翻转工作平面的族实例,翻转其工作平面"
);
var rotateInstance = UIAssist.NewButtonData<RotateInstanceCmd>(
var rotateInstance = UIAssist.NewPushButtonData<RotateInstanceCmd>(
"旋转实例",
Resources.rotate_instance_32px,
Resources.rotate_instance_16px,
@@ -240,45 +244,45 @@ public class RvApp : ExternalApplication
// ImageUtil.ConvertToBitmapSource(Resources.entity_32px),
// "存储内容到扩展数据"
// };
var modelCheckPbd = UIAssist.NewButtonData<ModelCheckCmd>(
var modelCheckPbd = UIAssist.NewPushButtonData<ModelCheckCmd>(
"模型检查",
Resources.model_check_16px,
Resources.model_check_32px,
"对模型进行多项要求的检查"
);
var templateManager = UIAssist.NewButtonData<TemplateManagerCmd>(
var templateManager = UIAssist.NewPushButtonData<TemplateManagerCmd>(
"样板定制",
Resources.template_32px,
Resources.template_16px,
"对项目样板进行批量处理"
);
var autoSavePbd = UIAssist.NewButtonData<AutoSaveCmd>("定时保存", Resources.save_32px, Resources.save_16px);
var purgeBtn = UIAssist.NewButtonData<PureModelCmd>(
var autoSavePbd = UIAssist.NewPushButtonData<AutoSaveCmd>("定时保存", Resources.save_32px, Resources.save_16px);
var purgeBtn = UIAssist.NewPushButtonData<PureModelCmd>(
"清理模型",
Resources.purge_32px,
Resources.purge_16px,
"清理并压缩模型文件大小"
);
var pipesCreatorPbd = UIAssist.NewButtonData<PipesCreatorCmd>(
var pipesCreatorPbd = UIAssist.NewPushButtonData<PipesCreatorCmd>(
"管线生成",
Resources.pipe_creator_32px,
Resources.pipe_creator_16px,
"根据dwg图纸生成管线"
);
var instanceCreatorPbd = UIAssist.NewButtonData<InstanceCreatorCmd>(
var instanceCreatorPbd = UIAssist.NewPushButtonData<InstanceCreatorCmd>(
"实例布置",
Resources.instance_creator_32px,
Resources.instance_creator_16px,
"根据dwg块进行族实例布置"
);
var modelByCurveCreatorPbd = UIAssist.NewButtonData<ModelByCurveCreatorCmd>(
var modelByCurveCreatorPbd = UIAssist.NewPushButtonData<ModelByCurveCreatorCmd>(
"曲线布置",
Resources.model_by_curve_32px,
Resources.model_by_curve_16px,
"根据dwg曲线或模型线对轮廓族放样或者布置族实例"
);
var toggleBackgroundPbd = UIAssist.NewButtonData<SwitchBackgroundCmd>(
var toggleBackgroundPbd = UIAssist.NewPushButtonData<SwitchBackgroundCmd>(
"切换背景",
Resources.background_32px,
Resources.background_16px,
@@ -290,13 +294,13 @@ public class RvApp : ExternalApplication
ribbonPanel.AddStackedItems(instanceCreatorPbd, modelByCurveCreatorPbd, pipesCreatorPbd);
ribbonPanel.AddStackedItems(toggleBackgroundPbd, purgeBtn, autoSavePbd);
//ribbonPanel.AddItem(toggleBackgroundPbd);
//ribbonPanel.AddItem(autoSavePbd);
//ribbonPanel.AddAwItem(toggleBackgroundPbd);
//ribbonPanel.AddAwItem(autoSavePbd);
//RadioButtonGroupData groupData = new RadioButtonGroupData("定位");
//RadioButtonGroup radioBtnGroup = ribbonPanel.AddItem(groupData) as RadioButtonGroup;
//radioBtnGroup.AddItem(updateViewBySelectElemPbd);
//var tg2 = radioBtnGroup.AddItem(updateViewBySelectElemPbd);
//RadioButtonGroup radioBtnGroup = ribbonPanel.AddAwItem(groupData) as RadioButtonGroup;
//radioBtnGroup.AddAwItem(updateViewBySelectElemPbd);
//var tg2 = radioBtnGroup.AddAwItem(updateViewBySelectElemPbd);
//tg2.Visible = false;
//var group = ribbonPanel.AddRadioButtonGroup(groupData, updateViewBySelectElemPbd, updateViewBySelectElemPbd1);
}
@@ -304,27 +308,27 @@ public class RvApp : ExternalApplication
private static void CreateIndependentTools(UIControlledApplication application)
{
var ribbonPanel = application.CreateRibbonPanel(TabName, "独立工具");
var networkCreator = UIAssist.NewButtonData<NetworkCreatorCmd>(
var networkCreator = UIAssist.NewPushButtonData<NetworkCreatorCmd>(
"物探管网",
Resources.pipe_net_32px,
Resources.pipe_net_16px
);
var metroGauges = UIAssist.NewButtonData<MetroGaugesCmd>(
var metroGauges = UIAssist.NewPushButtonData<MetroGaugesCmd>(
"限界轮廓",
Resources.gauges_32px,
Resources.gauges_16px,
"创建限界轮廓"
);
var metroTunnel = UIAssist.NewButtonData<MetroTunnelCmd>(
var metroTunnel = UIAssist.NewPushButtonData<MetroTunnelCmd>(
"盾构隧道",
Resources.gauges_32px,
Resources.gauges_16px,
"创建盾构隧道"
);
ribbonPanel.AddSplitButton("独立工具", networkCreator, metroTunnel, metroGauges);
//ribbonPanel.AddItem(networkCreator);
//ribbonPanel.AddItem(metroGauges);
//ribbonPanel.AddItem(metroTunnel);
//ribbonPanel.AddAwItem(networkCreator);
//ribbonPanel.AddAwItem(metroGauges);
//ribbonPanel.AddAwItem(metroTunnel);
//ribbonPanel.AddSplitButton("独立工具", networkCreator, metroGauges, metroTunnel);
}
}

View File

@@ -90,7 +90,7 @@ public class TabManagerApp
// if (obj is Autodesk.Windows.RibbonButton rb)
// {
// string tabName = rb.CommandParameter.ToString();
// var ribbonTab = ribbon.FindTab(tabName);
// var ribbonTab = ribbon.FindAwTab(tabName);
// ribbonTab.IsVisible = true;
// }
//}),
@@ -115,7 +115,7 @@ public class TabManagerApp
//如果是族文档,在激活视图时,隐藏面板
private static void SetTabEnabled(string tabName, bool isVisible)
{
//Autodesk.Windows.RibbonTab revitRibbonTab = UIFramework.RevitRibbonControl.RibbonControl.FindTab(Properties.Settings.Default.TabName);
//Autodesk.Windows.RibbonTab revitRibbonTab = UIFramework.RevitRibbonControl.RibbonControl.FindAwTab(Properties.Settings.Default.TabName);
//revitRibbonTab.IsVisible = false;
var ribbon = ComponentManager.Ribbon;
var ribbonTab = ribbon.FindTab(tabName);

View File

@@ -9,7 +9,7 @@ namespace Sai.RvKits;
public static class Variables
{
public static readonly string AddInPath = Assembly.GetExecutingAssembly().Location;
public static string AddInPath => Assembly.GetExecutingAssembly().Location;
// public static IntPtr RevitWindowPtr
//{
@@ -18,10 +18,9 @@ public static class Variables
//}
//public static readonly string DllPath = typeof(Variables).Assembly.Location;
public static string DirAssembly = Path.GetDirectoryName(AddInPath);
public static string FamilyFolder = $@"{DirAssembly}\Libraries\";
public static string LogFolder = $@"{DirAssembly}\Log\";
public static DockablePaneId PaneId { get; } = new(new Guid(Properties.Settings.Default.DockPaneGuid));
public static System.Timers.Timer Timer { get; } = new();
public static string DirAssembly => Path.GetDirectoryName(AddInPath);
public static string FamilyFolder => Path.Combine(DirAssembly, "Libraries");
public static DockablePaneId PaneId => new(new Guid(Properties.Settings.Default.DockPaneGuid));
public static System.Timers.Timer Timer => new();
public static SnackbarPresenter SnackbarPresenter { get; set; }
}

View File

@@ -38,7 +38,7 @@ public class IniHelper
public string IniReadValue(string section, string key)
{
var temp = new StringBuilder(255);
var i = GetPrivateProfileString(section, key, "", temp, 255, path);
GetPrivateProfileString(section, key, "", temp, 255, path);
return temp.ToString();
}

View File

@@ -18,7 +18,7 @@ public static class LogHelper
{
var assemblyPath = typeof(LogHelper).Assembly.Location;
var directory = Path.GetDirectoryName(assemblyPath);
logFolder = $"{directory}\\Logs";
logFolder = Path.Combine(directory, "Logs");
}
if (!Directory.Exists(logFolder))

View File

@@ -6,7 +6,7 @@ namespace Sai.Toolkit.Core.Helpers;
public sealed record SingletonViewHelper<T>
where T : Window, new()
{
private static T instance;
private static T _instance;
private static readonly object Padlock = new();
private SingletonViewHelper() { }
@@ -15,21 +15,21 @@ public sealed record SingletonViewHelper<T>
{
isNewCreate = false;
//double-check locking
if (instance == null)
if (_instance == null)
{
isNewCreate = true;
lock (Padlock)
{
instance ??= new T();
instance.Closed += OnWindowClosed;
_instance ??= new T();
_instance.Closed += OnWindowClosed;
}
}
return instance;
return _instance;
}
private static void OnWindowClosed(object sender, EventArgs e)
{
instance = null;
_instance = null;
}
}

View File

@@ -311,7 +311,7 @@ public class StringHelper
//StringFormat={}{0:m} May 04
//StringFormat={}{0:Distinct} May 04
//StringFormat={}{0:t} 5:46 PM
//StringFormat={}{0:T} 5:46:56 PM
//StringFormat={}{0:Command} 5:46:56 PM
//StringFormat={}{0:yyyy年MM月dd日} 2015年05月04日
//StringFormat={}{0:yyyy-MM-dd} 2015-05-04
//StringFormat={}{0:yyyy-MM-dd HH:mm} 2015-05-04 17:46

View File

@@ -102,7 +102,7 @@ public static class WinDialogHelper
//loaderUtil.HookAssemblyResolve();
//try
//{
// var view = SingletonViewHelper<T>.GetInstance(out var isNewCreate);
// var view = SingletonViewHelper<Command>.GetInstance(out var isNewCreate);
// if (isNewCreate)
// {
// view.DataContext = viewModel;

View File

@@ -16,7 +16,7 @@ public class XmlHelper
/// <summary>
/// 创建配置文件,可在子类中重写此方法
/// </summary>
public void CreateFile(string fileName)
public static void CreateFile(string fileName)
{
var doc = new XmlDocument();
var dec = doc.CreateXmlDeclaration("1.0", "UTF-8", null);

View File

@@ -111,8 +111,8 @@ public static class ExtensibleStorageAssist
throw new ArgumentNullException(nameof(fieldName));
}
//if (!typeof(T).IsPrimitive)
// throw new NotSupportedException(nameof(T));
//if (!typeof(Command).IsPrimitive)
// throw new NotSupportedException(nameof(Command));
var result = schemaBuilder.AddArrayField(fieldName, typeof(T));
if (description == string.Empty)
@@ -144,8 +144,8 @@ public static class ExtensibleStorageAssist
throw new ArgumentNullException(nameof(fieldName));
}
//if (!typeof(T).IsPrimitive)
// throw new NotSupportedException(nameof(T));
//if (!typeof(Command).IsPrimitive)
// throw new NotSupportedException(nameof(Command));
var result = schemaBuilder.AddSimpleField(fieldName, typeof(T));
//result.SetUnitType(unitType);
@@ -340,7 +340,7 @@ public static class ExtensibleStorageAssist
// Entity ent = e.GetEntity(schema);
// foreach (var field in fields)
// {
// var f = ent.Get<T>(field);
// var f = ent.Get<Command>(field);
// storages.Add(f);
// }
// }

View File

@@ -1,6 +1,5 @@
using Autodesk.Revit.DB;
using JetBrains.Annotations;
namespace Sai.Toolkit.Revit.Assist;
@@ -14,7 +13,7 @@ internal static class HostObjectAssist
public static List<Sketch> GetSketch(this HostObject element)
{
var doc = element.Document;
List<Sketch> sketches = new();
List<Sketch> sketches = [];
using (SubTransaction subTransaction = new(doc))
{
subTransaction.Start();

View File

@@ -54,11 +54,9 @@ public static class ImageAssist
public static BitmapSource ToBitmapSource(this Bitmap bitmap)
{
if (bitmap == null)
{
return null;
}
return Imaging.CreateBitmapSourceFromHBitmap(bitmap.GetHbitmap(), IntPtr.Zero, Int32Rect.Empty, BitmapSizeOptions.FromEmptyOptions());
return bitmap == null
? null
: Imaging.CreateBitmapSourceFromHBitmap(bitmap.GetHbitmap(), IntPtr.Zero, Int32Rect.Empty, BitmapSizeOptions.FromEmptyOptions());
}
/// <summary>

View File

@@ -0,0 +1,10 @@
using System;
using System.Collections.Generic;
using System.Text;
namespace Sai.Toolkit.Revit.Assist
{
internal class JIGAssist
{
}
}

View File

@@ -3,7 +3,6 @@ using System.Diagnostics;
using Autodesk.Revit.DB;
using JetBrains.Annotations;
using OfficeOpenXml.FormulaParsing.Excel.Functions.Text;
@@ -149,7 +148,6 @@ public static class SpatialAssist
/// <summary>创建一个新的实体,它是输入实体的副本</summary>
/// <param name="solid">要复制的输入实体</param>
/// <returns>新的实体</returns>
[Pure]
public static Solid Clone(this Solid solid)
{
return SolidUtils.Clone(solid);
@@ -159,11 +157,10 @@ public static class SpatialAssist
/// <param name="solid">要转换的输入实体</param>
/// <param name="transform">变换(必须是保角变换)</param>
/// <returns>新的实体</returns>
/// <exception cref="T:Autodesk.Revit.Exceptions.ArgumentOutOfRangeException">
/// <exception cref="Command:Autodesk.Revit.Exceptions.ArgumentOutOfRangeException">
/// 变换不保形。
/// 或变换的比例为负或零
/// </exception>
[Pure]
public static Solid CreateTransformed(this Solid solid, Transform transform)
{
return SolidUtils.CreateTransformed(solid, transform);
@@ -431,13 +428,13 @@ public static class SpatialAssist
public static List<List<Curve>> ToCurveLoops(List<Curve> curves)
{
List<List<Curve>> list = new();
List<List<Curve>> list = [];
while (curves.Any())
{
_curvesSorted = new()
{
_curvesSorted =
[
curves[0]
};
];
if (!curves[0].IsBound)
{
curves.Remove(curves[0]);
@@ -1382,10 +1379,9 @@ public static class SpatialAssist
/// </remarks>
/// <param name="solid">The solid</param>
/// <returns>分割实体几何图形</returns>
/// <exception cref="T:Autodesk.Revit.Exceptions.InvalidOperationException">
/// <exception cref="Command:Autodesk.Revit.Exceptions.InvalidOperationException">
/// 分割实体几何体失败
/// </exception>
[Pure]
public static IList<Solid> SplitVolumes(this Solid solid)
{
return SolidUtils.SplitVolumes(solid);
@@ -1409,10 +1405,10 @@ public static class SpatialAssist
/// 与输入实体的边界成分或输入壳体的成分相对应的三角形结构
/// 输入实体或输入壳体的分量
/// </returns>
/// <exception cref="T:Autodesk.Revit.Exceptions.ArgumentException">
/// <exception cref="Command:Autodesk.Revit.Exceptions.ArgumentException">
/// solidOrShell 对三角剖分无效(例如,它不包含任何面)
/// </exception>
/// <exception cref="T:Autodesk.Revit.Exceptions.InvalidOperationException">
/// <exception cref="Command:Autodesk.Revit.Exceptions.InvalidOperationException">
/// 无法对实体或外壳进行三角测量
/// </exception>
public static TriangulatedSolidOrShell TessellateSolidOrShell(this Solid solid, SolidOrShellTessellationControls tessellationControls)

View File

@@ -4,18 +4,22 @@ using System.IO;
using System.Reflection;
using System.Runtime.InteropServices;
using System.Windows;
using System.Windows.Input;
using System.Windows.Interop;
using System.Windows.Media.Imaging;
using Autodesk.Revit.DB;
using Autodesk.Revit.UI;
using adWin = Autodesk.Windows;
using CommunityToolkit.Diagnostics;
using UIFramework;
using UIFrameworkServices;
using System.Runtime.CompilerServices;
using Sai.Toolkit.Mvvm.Attributes;
using adWin = Autodesk.Windows;
namespace Sai.Toolkit.Revit.Assist;
@@ -23,15 +27,55 @@ public static class UIAssist
{
private static readonly string AddInPath = typeof(UIAssist).Assembly.Location;
/// <summary>
/// 查找内容
/// </summary>
/// <param name="hwndParent"></param>
/// <param name="hwndChildAfter"></param>
/// <param name="lpszClass"></param>
/// <param name="lpszWindow"></param>
/// <returns></returns>
[DllImport("user32.dll", EntryPoint = "FindWindowEx", SetLastError = true, CharSet = CharSet.Unicode)]
private static extern IntPtr FindWindowEx(
IntPtr hwndParent,
IntPtr hwndChildAfter,
string lpszClass,
string lpszWindow
);
[DllImport("user32.dll", CharSet = CharSet.Unicode, SetLastError = true)]
private static extern bool SetWindowText(IntPtr hWnd, string lpString);
private static BitmapSource ToBitmapSource(Bitmap bitmap)
/// <summary>
/// 面板上添加项
/// </summary>
/// <param name="panel"></param>
/// <param name="item"></param>
public static void AddAwItem(this adWin.RibbonPanel panel, adWin.RibbonItem item)
{
return bitmap == null
? null
: Imaging.CreateBitmapSourceFromHBitmap(bitmap.GetHbitmap(), IntPtr.Zero, Int32Rect.Empty, BitmapSizeOptions.FromEmptyOptions());
panel.Source.Items.Add(item);
}
/// <summary>
/// 添加堆叠按钮组
/// </summary>
/// <param name="rowPanel"></param>
/// <param name="ribbonButtons"></param>
public static void AddAwStackItems(this adWin.RibbonRowPanel rowPanel, params adWin.RibbonButton[] ribbonButtons)
{
for (var i = 0; i < ribbonButtons.Length; i++)
{
rowPanel.Items.Add(ribbonButtons[i]);
//添加一个,打断一次
if (i < ribbonButtons.Length - 1)
{
//行打断=新建行
rowPanel.Items.Add(new adWin.RibbonRowBreak());
}
}
}
/// <summary>
/// Combobox是可以分组的
/// 组合框是与事件结合使用的
@@ -57,27 +101,7 @@ public static class UIAssist
};
return comboBx;
}
/// <summary>
/// 在Revit现有的标签下如不存在则创建创建创建面板
/// </summary>
/// <param name="application"></param>
/// <param name="panelName">创建的面板名称</param>
/// <param name="tabName">若Tab不存在则创建对应名称的Tab</param>
/// <returns></returns>
public static RibbonPanel AddPanel(this UIControlledApplication application, string panelName, string tabName)
{
var ribbonTab = adWin.ComponentManager.Ribbon.Tabs.FirstOrDefault(tab => tab.Id.Equals(tabName));
if (ribbonTab is null)
{
application.CreateRibbonTab(tabName);
return application.CreateRibbonPanel(tabName, panelName);
}
var ribbonPanel = application.GetRibbonPanels(tabName).Find(panel => panel.Name.Equals(panelName));
return ribbonPanel ?? application.CreateRibbonPanel(tabName, panelName);
}
/// <summary>
/// 创建一个下拉式按钮。
@@ -146,37 +170,6 @@ public static class UIAssist
return data;
}
/// <summary>
/// 单选框
/// </summary>
/// <param name="pnl">面板</param>
/// <param name="groupName">分组名称</param>
/// <param name="toggleButtonData"></param>
/// <returns></returns>
public static RadioButtonGroup AddRadioButtonGroup(
this RibbonPanel pnl,
string groupName,
params ToggleButtonData[] toggleButtonData
)
{
if (pnl is null)
{
throw new ArgumentNullException(nameof(pnl));
}
if (string.IsNullOrEmpty(groupName))
{
throw new ArgumentNullException(nameof(groupName));
}
RadioButtonGroupData groupData = new(groupName);
var radioButtonGroup = (RadioButtonGroup)pnl.AddItem(groupData);
foreach (var data in toggleButtonData)
{
radioButtonGroup.AddItem(data);
}
return radioButtonGroup;
}
/// <summary>
/// 创建一个分割记忆按钮。
/// </summary>
@@ -220,18 +213,7 @@ public static class UIAssist
return result;
}
public static void AddStackItems(this adWin.RibbonRowPanel rowPanel, params adWin.RibbonButton[] ribbonButtons)
{
for (var i = 0; i < ribbonButtons.Length; i++)
{
rowPanel.Items.Add(ribbonButtons[i]);
if (i < ribbonButtons.Length - 1)
{
//行打断=新建行
rowPanel.Items.Add(new adWin.RibbonRowBreak());
}
}
}
public static void AddTextBox(this RibbonPanel panel, TextBoxData txtBoxData)
{
@@ -247,13 +229,38 @@ public static class UIAssist
};
txtBox.Width = 180;
}
public static ToggleButton AddToggleButton<T>(this RadioButtonGroup group, string name)
where T : IExternalCommand
/// <summary>
/// 在Revit现有的标签下如不存在则创建创建创建面板
/// </summary>
/// <param name="application"></param>
/// <param name="panelName">创建的面板名称</param>
/// <param name="tabName">若Tab不存在则创建对应名称的Tab</param>
/// <returns></returns>
public static RibbonPanel AddUIPanel(this UIControlledApplication application, string tabName, string panelName)
{
//var addInPath = typeof(T).Assembly.Location;
var toggleData = new ToggleButtonData(name, name, typeof(T).Assembly.Location, typeof(T).FullName);
return group.AddItem(toggleData);
var ribbonTab = adWin.ComponentManager.Ribbon.Tabs.FirstOrDefault(tab => tab.Id.Equals(tabName));
if (ribbonTab == null)
{
application.CreateRibbonTab(tabName);
return application.CreateRibbonPanel(tabName, panelName);
}
var ribbonPanel = application.GetRibbonPanels(tabName).Find(panel => panel.Name.Equals(panelName));
return ribbonPanel ?? application.CreateRibbonPanel(tabName, panelName);
}
public static adWin.RibbonItem ConvertToAwRibbonItem(this RibbonButton btn)
{
return (adWin.RibbonItem)btn.GetType()
.InvokeMember(
"getRibbonItem",
BindingFlags.NonPublic | BindingFlags.Instance | BindingFlags.InvokeMethod,
Type.DefaultBinder,
btn,
null
);
}
/// <summary>
@@ -287,26 +294,82 @@ public static class UIAssist
{
return new PushButtonData(typeof(T).FullName, name, typeof(T).Assembly.Location, typeof(T).FullName);
}
/// <summary>
/// 查找内容
/// 查找面板
/// </summary>
/// <param name="hwndParent"></param>
/// <param name="hwndChildAfter"></param>
/// <param name="lpszClass"></param>
/// <param name="lpszWindow"></param>
/// <param name="rt"></param>
/// <param name="panelName"></param>
/// <returns></returns>
[DllImport("user32.dll", EntryPoint = "FindWindowEx", SetLastError = true, CharSet = CharSet.Unicode)]
private static extern IntPtr FindWindowEx(
IntPtr hwndParent,
IntPtr hwndChildAfter,
string lpszClass,
string lpszWindow
);
public static adWin.RibbonPanel FindAwPanel(this adWin.RibbonTab rt, string panelName)
{
return rt.Panels.FirstOrDefault(p => p.Source.Name == panelName);
}
/// <summary>
/// 查找Tab
/// </summary>
/// <param name="tabName">标签名</param>
/// <returns></returns>
public static adWin.RibbonTab FindAwTab(string tabName)
{
return adWin.ComponentManager.Ribbon.Tabs.FirstOrDefault(tab => tab.Id.Equals(tabName));
}
public static ToggleButton GetToggleButton(this RadioButtonGroup radioButtonGroup)
{
return radioButtonGroup.Current;
}
/// <summary>
/// 创建按钮
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="showText"></param>
/// <param name="largeImage"></param>
/// <param name="image"></param>
/// <param name="command">RelayCommand</param>
/// <param name="parameter">命令的参数</param>
/// <param name="toolTip"></param>
/// <returns></returns>
public static adWin.RibbonButton NewAwButton(string showText, Bitmap largeImage, Bitmap image, ICommand command, object parameter, string toolTip = default)
{
return new()
{
Image = image.ToBitmapSource(),
LargeImage = largeImage.ToBitmapSource(),
Size = adWin.RibbonItemSize.Standard,
ShowText = true,
Id = $"ID_{showText}",
Name = $"Btn_{showText}",
ToolTip = toolTip ?? showText,
Text = showText,
IsCheckable = true,
CommandHandler = command,
CommandParameter = parameter,
//Orientation = System.Windows.Controls.Orientation.Vertical
};
}
/// <summary>
/// 创建ToggleButton
/// </summary>
/// <param name="showText"></param>
/// <param name="largeImage"></param>
/// <param name="toolTip"></param>
/// <returns></returns>
public static adWin.RibbonToggleButton NewAwToggleButton(string showText, Bitmap largeImage, string toolTip = null)
{
return new adWin.RibbonToggleButton()
{
LargeImage = largeImage?.ToBitmapSource(),
Size = adWin.RibbonItemSize.Large,
ToolTip = toolTip ?? showText,
ShowText = true,
Id = $"ID_{showText}",
Name = $"Tog_{showText}",
Text = showText,
IsCheckable = true,
Orientation = System.Windows.Controls.Orientation.Vertical,
};
}
/// <summary>
/// Revit默认打开文件对话框
@@ -332,24 +395,66 @@ public static class UIAssist
return filename;
}
/// <summary>
/// 设置按钮可用性
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="pushButtonData"></param>
/// <returns></returns>
public static PushButtonData SetAvailability<T>(this PushButtonData pushButtonData)
where T : IExternalCommandAvailability
{
pushButtonData.AvailabilityClassName = typeof(T).FullName;
return pushButtonData;
}
/// <summary>
/// 设置面板右下角箭头对话框
/// </summary>
public static void SetAwDialogLauncher(this adWin.RibbonPanel panel, adWin.RibbonCommandItem item)
{
if (panel != null)
{
panel.Source.DialogLauncher = item;
}
}
public static adWin.RibbonItem SetAwImage(this adWin.RibbonItem ribbonItem, Bitmap image)
{
ribbonItem.Image = image.ToBitmapSource();
return ribbonItem;
}
public static void SetAwImage(this adWin.RibbonItem ribbonItem, string uri)
{
ribbonItem.Image = new BitmapImage(new Uri(uri, UriKind.RelativeOrAbsolute));
}
public static adWin.RibbonItem SetAwLargeImage(this adWin.RibbonItem ribbonItem, Bitmap largeImage)
{
ribbonItem.LargeImage = largeImage.ToBitmapSource();
return ribbonItem;
}
/// <summary>
/// 指定决定按钮可用性的类别
/// 从 URI 源添加 32x32px-96dpi 图像
/// </summary>
/// <param name="button">功能区中将受限制的按钮</param>
/// <typeparam name="T">类型继承 <see cref="Autodesk.Revit.UI.IExternalCommandAvailability"/></typeparam>
/// <remarks>T 类应与插件 "外部命令 "共享同一程序集</remarks>
public static void SetAvailabilityController<T>(this PushButton button)
where T : IExternalCommandAvailability, new()
/// <param name="button">添加图标的按钮</param>
/// <param name="uri">图标的相对或绝对路径</param>
/// <example>button.SetAwLargeImage("/RevitAddIn;component/Resources/Icons/RibbonIcon32.png")</example>
public static void SetAwLargeImage(this adWin.RibbonItem ribbonItem, string uri)
{
button.AvailabilityClassName = typeof(T).FullName;
ribbonItem.LargeImage = new BitmapImage(new Uri(uri, UriKind.RelativeOrAbsolute));
}
public static adWin.RibbonItem SetAwShowText(this adWin.RibbonItem ribbonItem, string text)
{
ribbonItem.Text = text;
return ribbonItem;
}
public static adWin.RibbonItem SetAwToolTip(this adWin.RibbonItem ribbonItem, string tooltip)
{
ribbonItem.ToolTip = tooltip;
return ribbonItem;
}
public static PushButtonData SetDescription(this PushButtonData pushButtonData, string longDescription)
@@ -357,31 +462,26 @@ public static class UIAssist
pushButtonData.LongDescription = longDescription;
return pushButtonData;
}
/// <summary>
/// 右下角箭头对话框
/// 设置面板右下角箭头对话框
/// </summary>
public static void SetDialogLauncher(string panelName)
public static void SetDialogLauncher(string tabName, string panelName)
{
var group = adWin.ComponentManager.Ribbon.Tabs
.First()
.Panels.FirstOrDefault(p => p.AutomationName == panelName);
if (group != null)
{
.FirstOrDefault(tab => tab.Name == tabName)
.Panels.FirstOrDefault(p => p.AutomationName == panelName) ?? throw new ArgumentException("未找到标签或面板");
group.Source.DialogLauncher = group.Source.Items.First() as adWin.RibbonCommandItem;
}
/// <summary>
/// 设置面板右下角箭头对话框
/// </summary>
public static void SetDialogLauncher(adWin.RibbonTab tab, string panelName)
{
var group = tab.Panels.FirstOrDefault(p => p.AutomationName == panelName) ?? throw new ArgumentException("未找到标签或面板");
group.Source.DialogLauncher = group.Source.Items.First() as adWin.RibbonCommandItem;
}
/// <summary>
/// 右下角箭头对话框
/// </summary>
public static void SetDialogLauncher(this adWin.RibbonPanel panel, adWin.RibbonCommandItem item)
{
if (panel != null)
{
panel.Source.DialogLauncher = item;
}
}
/// <summary>
/// 双击选项
/// </summary>
@@ -392,14 +492,17 @@ public static class UIAssist
doubleOpt.SetAction(target, clickAction);
}
/// <summary>
/// 提示包含短视频
/// </summary>
/// <param name="pushButtonData"></param>
/// <param name="title"></param>
/// <param name="videoPath"></param>
/// <param name="videoPath">视频路径</param>
public static void SetExpandedVideo(this PushButtonData pushButtonData, string title, string videoPath)
{
//拿到Autodesk.Windows的RibbonItem转换
var internalGetRibbonItemMethod = typeof(RibbonItem).GetMethod(
"getRibbonItem",
BindingFlags.NonPublic | BindingFlags.Instance
@@ -410,17 +513,31 @@ public static class UIAssist
button.ToolTip = new adWin.RibbonToolTip { Title = title, ExpandedVideo = new Uri(videoPath) };
}
}
/// <summary>
/// 设置16x16的小图片
/// </summary>
/// <param name="pushButtonData"></param>
/// <param name="image"></param>
/// <returns></returns>
public static PushButtonData SetImage(this PushButtonData pushButtonData, Bitmap image)
{
pushButtonData.Image = ToBitmapSource(image);
pushButtonData.Image = image.ToBitmapSource();
return pushButtonData;
}
/// <summary>
/// 使用Uri设置16x16的小图片
/// </summary>
/// <param name="pushButtonData"></param>
/// <param name="uri"></param>
public static PushButtonData SetImage(this PushButtonData pushButtonData, string uri)
{
pushButtonData.Image = new BitmapImage(new Uri(uri, UriKind.RelativeOrAbsolute));
return pushButtonData;
}
public static void SetImage(this RibbonButton button, string uri)
{
button.Image = new BitmapImage(new Uri(uri, UriKind.RelativeOrAbsolute));
}
/// <summary>
/// 消息中心
@@ -441,23 +558,30 @@ public static class UIAssist
}; // 当鼠标点击气泡内容时触发此事件
paletteMgr.ShowBalloon(resultItem);
}
/// <summary>
/// 设置32x32-96dpi的大图片
/// </summary>
/// <param name="pushButtonData"></param>
/// <param name="largeImage"></param>
/// <returns></returns>
public static PushButtonData SetLargeImage(this PushButtonData pushButtonData, Bitmap largeImage)
{
pushButtonData.LargeImage = ToBitmapSource(largeImage);
pushButtonData.LargeImage = largeImage.ToBitmapSource();
return pushButtonData;
}
/// <summary>
/// Adds a 32x32px-96dpi image from the URI source
/// 从 URI 源添加 32x32px-96dpi 图像
/// </summary>
/// <param name="button">Button to which the icon will be added</param>
/// <param name="uri">Relative or Absolute path to the icon</param>
/// <example>button.SetLargeImage("/RevitAddIn;component/Resources/Icons/RibbonIcon32.png")</example>
public static void SetLargeImage(this RibbonButton button, string uri)
/// <param name="pushButtonData">添加图标的按钮</param>
/// <param name="uri">图标的相对或绝对路径</param>
/// <example>button.SetAwLargeImage("/RevitAddIn;component/Resources/Icons/RibbonIcon32.png")</example>
public static void SetLargeImage(this PushButtonData pushButtonData, string uri)
{
button.LargeImage = new BitmapImage(new Uri(uri, UriKind.RelativeOrAbsolute));
pushButtonData.LargeImage = new BitmapImage(new Uri(uri, UriKind.RelativeOrAbsolute));
}
/// <summary>
/// 状态栏
/// </summary>
@@ -478,84 +602,36 @@ public static class UIAssist
}
/// <summary>
/// 基于Revit封装的RibbonButton设置其快捷键.
/// 设置显示文字
/// </summary>
/// <param name="btn">RibbonButton.</param>
/// <param name="key">快捷键字符串.</param>
/// <param name="pushButtonData"></param>
/// <param name="text"></param>
/// <returns></returns>
public static bool SetShortCut(this Autodesk.Revit.UI.RibbonButton btn, string key)
{
if (btn == null)
return false;
var item = btn.GetType()
.InvokeMember(
"getRibbonItem",
BindingFlags.NonPublic | BindingFlags.Instance | BindingFlags.InvokeMethod,
Type.DefaultBinder,
btn,
null
);
return item != null && (item as Autodesk.Windows.RibbonItem).SetShortCut(key);
}
/// <summary>
/// 基于通用库封装的RibbonCommandItem设置其快捷键.
/// </summary>
/// <param name="commandItem">RibbonCommandItem.</param>
/// <param name="key">快捷键字符串.</param>
/// <returns></returns>
public static bool SetShortCut(this Autodesk.Windows.RibbonItem commandItem, string key)
{
if (commandItem == null || string.IsNullOrEmpty(key))
return false;
Autodesk.Windows.ComponentManager.Ribbon.FindItem(
commandItem.Id,
false,
out var parentPanel,
out var parentTab,
true
);
if (parentTab == null || parentPanel == null)
return false;
var path = string.Format("{0}>{1}", parentTab.Id, parentPanel.Source.Id);
var cmdId = ControlHelper.GetCommandId(commandItem);
if (string.IsNullOrEmpty(cmdId))
{
cmdId = Guid.NewGuid().ToString();
ControlHelper.SetCommandId(commandItem, cmdId);
}
var shortcutItem = new ShortcutItem(commandItem.Text, cmdId, key, path)
{
ShortcutType = StType.RevitAPI
};
UIFrameworkServices.KeyboardShortcutService.applyShortcutChanges(
new Dictionary<string, ShortcutItem>() { { cmdId, shortcutItem } }
);
return true;
}
public static PushButtonData SetShowText(this PushButtonData pushButtonData, string text)
{
pushButtonData.Text = text;
return pushButtonData;
}
/// <summary>
/// 设置工具提示
/// </summary>
/// <param name="pushButtonData"></param>
/// <param name="tooltip"></param>
/// <returns></returns>
public static PushButtonData SetToolTip(this PushButtonData pushButtonData, string tooltip)
{
pushButtonData.ToolTip = tooltip;
return pushButtonData;
}
/// <summary>
/// 设置工具提示图片
/// </summary>
/// <param name="pushButtonData"></param>
/// <param name="toolTipImage"></param>
/// <returns></returns>
public static PushButtonData SetToolTipImage(this PushButtonData pushButtonData, Bitmap toolTipImage)
{
pushButtonData.ToolTipImage = ToBitmapSource(toolTipImage);
pushButtonData.ToolTipImage = toolTipImage.ToBitmapSource();
return pushButtonData;
}
@@ -563,15 +639,19 @@ public static class UIAssist
/// 通过判断keyTip来区分原始Tab与插件Tab然后切换插件Tab的可见性
/// </summary>
/// <param name="tabName"></param>
public static void SetVisible(string tabName)
/// <param name="visible"></param>
public static void SetVisible(string tabName, bool visible)
{
var ribbonControl = adWin.ComponentManager.Ribbon;
foreach (var tab in ribbonControl.Tabs)
var tab = ribbonControl.Tabs
.FirstOrDefault(
tab => !tab.IsContextualTab &&
!tab.IsMergedContextualTab &&
tab.KeyTip == null &&
tabName == tab.Name);
if (tab != null)
{
if (!tab.IsContextualTab && !tab.IsMergedContextualTab && tab.KeyTip == null && tabName == tab.Name)
{
tab.IsVisible = !tab.IsVisible;
}
tab.IsVisible = visible;
}
}
@@ -579,23 +659,23 @@ public static class UIAssist
/// <summary>
/// 新建命令按钮
/// </summary>
/// <typeparam name="T"></typeparam>
/// <typeparam name="Command"></typeparam>
/// <param name="text"></param>
/// <param name="image"></param>
/// <param name="largeImage"></param>
/// <param name="toolTip"></param>
/// <param name="longDescription"></param>
/// <returns></returns>
public static PushButtonData NewButtonData<T>(
public static PushButtonData NewPushButtonData<Command>(
string text,
Bitmap largeImage = null,
Bitmap image = null,
string toolTip = null,
string longDescription = null
)
where T : class, IExternalCommand
where Command : class, IExternalCommand
{
return new(typeof(T).FullName, text, AddInPath, typeof(T).FullName)
return new(typeof(Command).FullName, text, AddInPath, typeof(Command).FullName)
{
LargeImage = largeImage?.ToBitmapSource(),
Image = image?.ToBitmapSource(),
@@ -607,32 +687,33 @@ public static class UIAssist
/// <summary>
/// 新建可控的命令按钮
/// </summary>
/// <typeparam name="T"></typeparam>
/// <typeparam name="V"></typeparam>
/// <typeparam name="Command"></typeparam>
/// <typeparam name="Availablility"></typeparam>
/// <param name="text"></param>
/// <param name="bitmap"></param>
/// <param name="largeBitmap"></param>
/// <param name="toolTip"></param>
/// <param name="longDescription"></param>
/// <returns></returns>
public static PushButtonData NewButtonData<T, V>(
public static PushButtonData NewButtonData<Command, Availablility>(
string text,
Bitmap largeBitmap = null,
Bitmap bitmap = null,
string toolTip = null,
string longDescription = null
)
where T : class, IExternalCommand
where V : class, IExternalCommandAvailability
where Command : class, IExternalCommand
where Availablility : class, IExternalCommandAvailability
{
return new(typeof(T).FullName, text, AddInPath, typeof(T).FullName)
return new(typeof(Command).FullName, text, AddInPath, typeof(Command).FullName)
{
LargeImage = largeBitmap?.ToBitmapSource(),
Image = bitmap?.ToBitmapSource(),
ToolTip = toolTip ?? text,
LongDescription = longDescription,
AvailabilityClassName = typeof(V).FullName
AvailabilityClassName = typeof(Availablility).FullName
};
}
#endregion
}

View File

@@ -7,6 +7,7 @@ using Autodesk.Revit.UI;
using UIFramework;
using UIFrameworkServices;
namespace Sai.Toolkit.Revit.Helpers
@@ -77,6 +78,70 @@ namespace Sai.Toolkit.Revit.Helpers
}
return false;
}
#region 使
/// 基于Revit封装的RibbonButton设置其快捷键.
/// </summary>
/// <param name="btn">RibbonButton.</param>
/// <param name="key">快捷键字符串.</param>
/// <returns></returns>
public bool SetShortCut(Autodesk.Revit.UI.RibbonButton btn, string key)
{
if (btn == null)
return false;
var item = btn.GetType()
.InvokeMember(
"getRibbonItem",
BindingFlags.NonPublic | BindingFlags.Instance | BindingFlags.InvokeMethod,
Type.DefaultBinder,
btn,
null
);
return item != null && (item is Autodesk.Windows.RibbonItem ribbonItem) && SetAdShortCut(ribbonItem, key);
}
/// <summary>
/// 基于通用库封装的RibbonCommandItem设置其快捷键.
/// </summary>
/// <param name="commandItem">RibbonCommandItem.</param>
/// <param name="key">快捷键字符串.</param>
/// <returns></returns>
private static bool SetAdShortCut(Autodesk.Windows.RibbonItem commandItem, string key)
{
if (commandItem == null || string.IsNullOrEmpty(key))
return false;
Autodesk.Windows.ComponentManager.Ribbon.FindItem(
commandItem.Id,
false,
out var parentPanel,
out var parentTab,
true
);
if (parentTab == null || parentPanel == null)
return false;
var path = string.Format("{0}>{1}", parentTab.Id, parentPanel.Source.Id);
var cmdId = ControlHelper.GetCommandId(commandItem);
if (string.IsNullOrEmpty(cmdId))
{
cmdId = Guid.NewGuid().ToString();
ControlHelper.SetCommandId(commandItem, cmdId);
}
var shortcutItem = new ShortcutItem(commandItem.Text, cmdId, key, path)
{
ShortcutType = StType.RevitAPI
};
UIFrameworkServices.KeyboardShortcutService.applyShortcutChanges(
new Dictionary<string, ShortcutItem>() { { cmdId, shortcutItem } }
);
return true;
}
#endregion
/// <summary>
/// 移除菜单快捷键
/// </summary>

View File

@@ -15,6 +15,7 @@
<Compile Include="$(MSBuildThisFileDirectory)Assist\DocumentAssist.cs" />
<Compile Include="$(MSBuildThisFileDirectory)Assist\HostObjectAssist.cs" />
<Compile Include="$(MSBuildThisFileDirectory)Assist\ApplicationAssist.cs" />
<Compile Include="$(MSBuildThisFileDirectory)Assist\JIGAssist.cs" />
<Compile Include="$(MSBuildThisFileDirectory)Assist\KeyboardShortcutExtension.cs" />
<Compile Include="$(MSBuildThisFileDirectory)Helpers\DuplicateTypeNamesHandler.cs" />
<Compile Include="$(MSBuildThisFileDirectory)Assist\ElementAssist.cs" />

View File

@@ -1,14 +1,14 @@
using System;
using System.Collections.Generic;
using System.Collections.ObjectModel;
using System.ComponentModel;
using System.Linq;
using CommunityToolkit.Mvvm.ComponentModel;
using System.Runtime.CompilerServices;
namespace Wpf.Ui.Extend.Models;
public partial class TreeModel : ObservableObject, IComparable
public partial class TreeModel : INotifyPropertyChanged, IComparable
{
/// <summary>
/// 构造
@@ -16,22 +16,30 @@ public partial class TreeModel : ObservableObject, IComparable
public TreeModel()
{
Children = new ObservableCollection<TreeModel>();
isChecked = false;
Icon = "./Resources/File_16px.png";
IsChecked = false;
//Icon = "./Resources/File_16px.png";
//TitleIcon = FamilyPlugins.Properties.Resources.Folder_32px;
IsExpanded = false;
}
public event PropertyChangedEventHandler PropertyChanged;
protected void SetProperty<T>(ref T prop, T value, [CallerMemberName] string propertyName = null)
{
if (EqualityComparer<T>.Default.Equals(prop, value) == false)
{
prop = value;
OnPropertyChanged(propertyName);
}
}
public virtual void OnPropertyChanged(string propertyName)
{
PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(propertyName));
}
/// <summary>
/// 选中状态
/// </summary>
[ObservableProperty]
private bool? isChecked;
/// <summary>
/// 折叠状态
/// </summary>
[ObservableProperty]
private bool isExpanded;
/// <summary>
@@ -72,6 +80,22 @@ public partial class TreeModel : ObservableObject, IComparable
/// 父项
/// </summary>
public TreeModel Parent { get; set; }
/// <summary>
/// 选中状态
/// </summary>
public bool? IsChecked
{
get => isChecked;
set => SetProperty(ref isChecked, value);
}
/// <summary>
/// 折叠状态
/// </summary>
public bool IsExpanded
{
get => isExpanded;
set => SetProperty(ref isExpanded, value);
}
/// <summary>
/// 排序

View File

@@ -13,7 +13,6 @@
<AppendRuntimeIdentifierToOutputPath>False</AppendRuntimeIdentifierToOutputPath>
</PropertyGroup>
<ItemGroup>
<PackageReference Include="CommunityToolkit.Mvvm" Version="8.3.2" />
<PackageReference Include="Microsoft.CSharp" Version="4.7.0" />
<PackageReference Include="System.Runtime" Version="4.3.1" />
<PackageReference Include="WPF-UI" Version="4.0.0-rc.2" />