본문 바로가기
.NET C#

ToolTipService 컨트롤

by 태디 2008. 7. 18.
728x90

ToolTipService 컨트롤을 이용하여 3개의 Rectangle에 각각 ToolTip를 표시하는 Demo입니다. 

사용자 삽입 이미지

ToolTipService 형식

Silverlight에서 지원하는 컨트롤의 대부분에서 하위 엘리먼트로 지원되는 클래스입니다.  Silverlight의 컨트롤안에 아래코드와 같은 형식으로 ToolTipService를 엘리먼트(Element)로 집어넣을 수 있습니다. 그리고 <TextBlock ></TextBlock>에 ToolTip을 출력하게 합니다.

<Rectangle HorizontalAlignment="Stretch" Margin="154,28,155,26" VerticalAlignment="Stretch"
                   Fill="#FF4289B4" Stroke="#FF000000" x:Name="Rect2">
            <ToolTipService.ToolTip>
                <ToolTip>
                    <ToolTip.Content>
                        <TextBlock x:Name="Rect2_ToolTip"></TextBlock>
                    </ToolTip.Content>
                </ToolTip>
            </ToolTipService.ToolTip>
</Rectangle>


xaml code

<UserControl x:Class="SilverlightToolTipService.Page"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    Width="400" Height="145">
    <Grid x:Name="LayoutRoot" Background="White">
        <Rectangle HorizontalAlignment="Left" Margin="36,28,0,26" VerticalAlignment="Stretch"
                   Width="91" Fill="#FF4289B4" Stroke="#FF000000" x:Name="Rect1">
            <ToolTipService.ToolTip>
                <ToolTip>
                    <ToolTip.Content>
                        <TextBlock x:Name="Rect1_ToolTip"></TextBlock>  
                    </ToolTip.Content>
                </ToolTip>
            </ToolTipService.ToolTip>
        </Rectangle>
        <Rectangle HorizontalAlignment="Stretch" Margin="154,28,155,26" VerticalAlignment="Stretch"
                   Fill="#FF4289B4" Stroke="#FF000000" x:Name="Rect2">
            <ToolTipService.ToolTip>
                <ToolTip>
                    <ToolTip.Content>
                        <TextBlock x:Name="Rect2_ToolTip"></TextBlock>
                    </ToolTip.Content>
                </ToolTip>
            </ToolTipService.ToolTip>
        </Rectangle>
        <Rectangle HorizontalAlignment="Right" Margin="0,28,37,26" VerticalAlignment="Stretch"
                   Width="91" Fill="#FF4289B4" Stroke="#FF000000" x:Name="Rect3">
            <ToolTipService.ToolTip>
                <ToolTip>
                    <ToolTip.Content>
                        <TextBlock x:Name="Rect3_ToolTip"></TextBlock>
                    </ToolTip.Content>
                </ToolTip>
            </ToolTipService.ToolTip>
        </Rectangle>
    </Grid>
</UserControl>
 


cs code

using System;
using System.Windows.Controls;
namespace SilverlightToolTipService
{
    public partial class Page : UserControl
    {
        public Page()
        {
            InitializeComponent();
 
            Rect1_ToolTip.Loaded += new RoutedEventHandler(Rect_ToolTip);
            Rect2_ToolTip.Loaded += new RoutedEventHandler(Rect_ToolTip);
            Rect3_ToolTip.Loaded += new RoutedEventHandler(Rect_ToolTip);
        }
 
        void Rect_ToolTip(object sender, RoutedEventArgs e)
        {
            TextBlock obj = sender as TextBlock;
 
            switch (obj.Name)
            {
                case "Rect1_ToolTip": obj.Text = "No.1 Rectangle ToolTipService";
                    break;
                case "Rect2_ToolTip": obj.Text = "No.2 Rectangle ToolTipService";
                    break;
                case "Rect3_ToolTip": obj.Text = "No.3 Rectangle ToolTipService";
                    break;
            }
        }
    }
}
 

Rect_ToolTip 이벤트는 선택된 사격형의 object 값 sender를 체크하여 TextBlock에 ToolTip를 출력합니다.

참고

댓글