我正在使用 Helix 显示一个简单的对象,如下所示
<h:HelixViewport3D >
<h:DefaultLights/>
<h:Teapot/>
</h:HelixViewport3D>
如何在茶壶鼠标悬停时显示工具提示?
谢谢
我正在使用 Helix 显示一个简单的对象,如下所示
<h:HelixViewport3D >
<h:DefaultLights/>
<h:Teapot/>
</h:HelixViewport3D>
如何在茶壶鼠标悬停时显示工具提示?
谢谢
我会使用这样的东西:
class ToolTipHelper
{
private readonly ToolTip _toolTip;
private readonly Timer _timer;
/// <summary>
/// Creates an instance
/// </summary>
public ToolTipHelper()
{
_toolTip = new ToolTip();
_timer = new Timer { AutoReset = false};
_timer.Elapsed += ShowToolTip;
}
/// <summary>
/// Gets or sets the text for the tooltip.
/// </summary>
public object ToolTipContent { get{ return _toolTip.Content; } set{ _toolTip.Content = value; } }
/// <summary>
/// To be called when the mouse enters the ui area.
/// </summary>
public void OnMouseEnter(object sender, MouseEventArgs e)
{
_timer.Interval = ToolTipService.GetInitialShowDelay(Application.Current.MainWindow);
_timer.Start();
}
private void ShowToolTip(object sender, ElapsedEventArgs e)
{
_timer.Stop();
if (_toolTip != null)
_toolTip.Dispatcher.Invoke(new Action(() => { _toolTip.IsOpen = true; }));
}
/// <summary>
/// To be called when the mouse leaves the ui area.
/// </summary>
public void OnMouseLeave(object sender, MouseEventArgs e)
{
_timer.Stop();
if (_toolTip != null)
_toolTip.IsOpen = false;
}
然后Teapot
像这样修改:
class Teapot
{
private readonly _tooltipHelper = new ToolTipHelper{ ToolTipContent = "MyToolTip" }; // keep the ToolTipHelper during the life of your Teapot but replace the Content whenever you want
private ModelUIElement3D _uiModel; // this has to be created and have its Model set to the suitable GeometryModel3D. You may want to replace an existing ModelVisual3D by this.
public Teapot(/*...*/)
{
_uiModel.MouseEnter += tooltipHelper.OnMouseEnter;
_uiModel.MouseLeave += tooltipHelper.OnMouseLeave;
//...
}
// ...
}
如果您愿意,修改它以在 Xaml 中定义工具提示的内容应该不难。