私はあなたがここからアバロンコントロールを使おうとしていると仮定しています:アバロンコントロール
コントロールテンプレートのつまみにツールチップを追加し、PART_LeftToolTipと呼びました。
<ControlTemplate TargetType="{x:Type Controls:RangeSlider}">
<StackPanel Orientation="Horizontal" Name="PART_RangeSliderContainer">
<RepeatButton Name="PART_LeftEdge"/>
<Thumb Name="PART_LeftThumb" Cursor="SizeWE">
<Thumb.ToolTip>
<ToolTip Name="PART_LeftToolTip" />
</Thumb.ToolTip>
</Thumb>
<Thumb Name="PART_MiddleThumb" Cursor="ScrollWE" MinWidth="1"/>
<Thumb Name="PART_RightThumb" Cursor="SizeWE">
<Thumb.ToolTip>
<ToolTip Name="PART_RightToolTip" />
</Thumb.ToolTip>
</Thumb>
<RepeatButton Name="PART_RightEdge"/>
</StackPanel>
</ControlTemplate>
それらをテンプレートパーツとしてRangeSliderコントロールに追加しました
TemplatePart(Name = "PART_LeftToolTip", Type = typeof(ToolTip)),
TemplatePart(Name = "PART_RightToolTip", Type = typeof(ToolTip))]
public sealed class RangeSlider : Control
OnApplyTemplateメソッドで、次のことを行いました
_leftPreviewToolTip = EnforceInstance<ToolTip>("PART_LeftToolTip");
_rightPreviewToolTip = EnforceInstance<ToolTip>("PART_RightToolTip");
InitializeVisualElementsメソッド内に、以下を追加しました
private void InitializeVisualElementsContainer()
{
// ** same as before ** //
_leftPreviewToolTip.PlacementTarget = _leftThumb;
_rightPreviewToolTip.PlacementTarget = _rightThumb;
}
ここで、楽しい部分については、基本的に、親指を動かしたときにこのツールチップを表示します。左のツールチップでは、左手の親指を動かしたとき、または中央の親指を動かしたときに表示する必要があります。ShowLeftTooltipというメソッドを作成し、LeftThumbDragDeltaとCenterThumbDragDeltaからそれぞれ呼び出しました。
private void ShowLeftToolTip()
{
_leftPreviewToolTip.IsOpen = AutoToolTip;
// This is a little trick to cause the ToolTip to update its position next to the Thumb
_leftPreviewToolTip.HorizontalOffset = _leftPreviewToolTip.HorizontalOffset == 0.0 ? 0.001 : 0.0;
}
ツールチップを移動するためのそのヒントは、私が考えたものではありません。どこかの別の投稿から入手しました。
適切なツールチップを実装するための演習として、読者に任せます。
ツールチップのスタイルを設定して、柔軟な表示を可能にすることができます。空白にならないように、ツールチップにデータコンテキストとして何かを与えることを忘れないでください。