merge frame part of DispUtil to DispFrameUtil.
This commit is contained in:
parent
688762ab70
commit
c1f3fefdc0
@ -11,8 +11,8 @@ using System.Collections.Generic;
|
|||||||
using Hi.Geom;
|
using Hi.Geom;
|
||||||
using Microsoft.Win32; // Add this for SystemEvents
|
using Microsoft.Win32; // Add this for SystemEvents
|
||||||
|
|
||||||
namespace Hi.WpfPlus.Disp
|
namespace Hi.WpfPlus.Disp;
|
||||||
{
|
|
||||||
#region WPF Rendering Canvas
|
#region WPF Rendering Canvas
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Provides a WPF rendering canvas for 3D visualization of HiAPI components.
|
/// Provides a WPF rendering canvas for 3D visualization of HiAPI components.
|
||||||
@ -471,4 +471,3 @@ namespace Hi.WpfPlus.Disp
|
|||||||
#endregion
|
#endregion
|
||||||
}
|
}
|
||||||
#endregion
|
#endregion
|
||||||
}
|
|
||||||
|
|||||||
@ -3,8 +3,8 @@ using System;
|
|||||||
using System.Windows;
|
using System.Windows;
|
||||||
using System.Windows.Media;
|
using System.Windows.Media;
|
||||||
|
|
||||||
namespace Hi.WpfPlus.Disp
|
namespace Hi.WpfPlus.Disp;
|
||||||
{
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Window for 3D rendering.
|
/// Window for 3D rendering.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
@ -52,4 +52,3 @@ namespace Hi.WpfPlus.Disp
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|||||||
60
Disp/WpfDisp.cs
Normal file
60
Disp/WpfDisp.cs
Normal file
@ -0,0 +1,60 @@
|
|||||||
|
using Google.Protobuf.WellKnownTypes;
|
||||||
|
using Hi.Disp;
|
||||||
|
using Hi.Geom;
|
||||||
|
using System.Collections.Concurrent;
|
||||||
|
using System.Windows;
|
||||||
|
|
||||||
|
namespace Hi.WpfPlus.Disp;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Registers WPF as the display framework for <see cref="DispFrameUtil"/>,
|
||||||
|
/// supporting multiple windows identified by key.
|
||||||
|
/// </summary>
|
||||||
|
/// <remarks>
|
||||||
|
/// <para>
|
||||||
|
/// Usage pattern: call <see cref="DispFrameUtil.Call"/> to queue display content,
|
||||||
|
/// then call <see cref="Run"/> to start the WPF application and show windows.
|
||||||
|
/// </para>
|
||||||
|
/// <para>
|
||||||
|
/// Each unique key creates a separate <see cref="RenderingWindow"/>.
|
||||||
|
/// Calling <see cref="DispFrameUtil.Call"/> with the same key updates the existing window.
|
||||||
|
/// </para>
|
||||||
|
/// <example>
|
||||||
|
/// <code>
|
||||||
|
/// // Queue display content (before or after Run)
|
||||||
|
/// DispFrameUtil.CallDispFrame("Window1", displayee1);
|
||||||
|
/// DispFrameUtil.CallDispFrame("Window2", displayee2);
|
||||||
|
/// // Start the WPF application (blocks until all windows are closed)
|
||||||
|
/// DispFrameWpf.Run();
|
||||||
|
/// </code>
|
||||||
|
/// </example>
|
||||||
|
/// </remarks>
|
||||||
|
public static class WpfDisp
|
||||||
|
{
|
||||||
|
static readonly ConcurrentDictionary<string, RenderingWindow> KeyToWindowDictionary = new();
|
||||||
|
|
||||||
|
static WpfDisp()
|
||||||
|
{
|
||||||
|
DispFrameUtil.UpdateByDispEngineConfigFunc = ApplyConfig;
|
||||||
|
}
|
||||||
|
public static void Init() { }
|
||||||
|
|
||||||
|
static void ApplyConfig(string key, DispEngineConfig config)
|
||||||
|
{
|
||||||
|
if (!KeyToWindowDictionary.TryGetValue(key, out var window))
|
||||||
|
{
|
||||||
|
window = new RenderingWindow() { Title = key };
|
||||||
|
window.Closed += (s, e) => KeyToWindowDictionary.TryRemove(key, out _);
|
||||||
|
KeyToWindowDictionary[key] = window;
|
||||||
|
window.Show();
|
||||||
|
}
|
||||||
|
|
||||||
|
var dispEngine = window.GetDispEngine();
|
||||||
|
if (config.Displayee != null)
|
||||||
|
dispEngine.Displayee = config.Displayee;
|
||||||
|
if (config.SketchView == null)
|
||||||
|
config.SketchView = config.Displayee?.GetBox3d()?.FrontView;
|
||||||
|
if (config.SketchView != null)
|
||||||
|
dispEngine.SketchView = config.SketchView;
|
||||||
|
}
|
||||||
|
}
|
||||||
Loading…
x
Reference in New Issue
Block a user