Custom tooltip for listbox item in WPF

后端 未结 3 1249
遥遥无期
遥遥无期 2021-01-22 23:31

I\'ve got a ListBox that displays an ObservableCollection of Talent objects. When the user hovers over each item in the ListBox, I\'d like to display in the ToolTip several piec

相关标签:
3条回答
  • 2021-01-23 00:08

    I don't know whether I've experience the same issue as the OP, but the source of trouble for me was the following implicit style:

    <Style TargetType="{x:Type ToolTip}">
       <Setter Property="ContentTemplate">
           <Setter.Value>
               <DataTemplate>
                   <TextBlock TextWrapping="Wrap" Text="{Binding}" MaxWidth="600"/>
               </DataTemplate>
           </Setter.Value>
       </Setter>
    </Style>
    

    The purpose of this style was to eliminate long-winded tooltips from exceeding viewable screen area, but it only works on standard, inline tooltips. Attempting to create a custom, elaborate tooltip resulted in the "System.Windows.Controls.StackPanel" that the OP reported. Removing this implicit style immediately resolved the issue... however also removes the nice 600 DIP width restriction.

    0 讨论(0)
  • 2021-01-23 00:14

    Have you tried this?

    <TextBlock Text="{Binding Path=tName}">
      <ToolTipService.ToolTip>
        <StackPanel>
          <TextBlock Text="{Binding Path=Description}" />
        </StackPanel>
      </ToolTipService.ToolTip>
    </TextBlock>
    
    0 讨论(0)
  • 2021-01-23 00:16

    After a quick test your code seems to work fine.

    My test:

    xaml:

     <Window x:Class="WpfApplication4.MainWindow"
                xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
                xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
                xmlns:local="clr-namespace:WpfApplication4"
                xmlns:Controls="clr-namespace:Liz.Common"
               Title="MainWindow" Height="300" Width="400" Name="UI" >
    
     <Window.Resources>
        <DataTemplate x:Key="removableTalentListTemplate">
                <StackPanel>
                    <TextBlock FontSize="13" Text="{Binding Path=tName}" VerticalAlignment="Center" Width="175" Height="18" Grid.Column="0" >
                        <TextBlock.ToolTip>
                            <ToolTip Background="Blue">
                                <StackPanel>
                                    <TextBlock Text="{Binding Path=Description}" Foreground="White" />
                                </StackPanel>
                            </ToolTip>
                        </TextBlock.ToolTip>
                    </TextBlock>
                </StackPanel>
            </DataTemplate>
         </Window.Resources>
    
            <Grid>
                <ListBox ItemTemplate="{StaticResource removableTalentListTemplate}" ItemsSource="{Binding ElementName=UI, Path=Models}" />
            </Grid>
        </Window>
    

    Code:

    public partial class MainWindow : Window
    {
        private ObservableCollection<MyModel> _models = new ObservableCollection<MyModel>();
    
        public MainWindow()
        {
            InitializeComponent();
            Models.Add(new MyModel { tName = "Test", Description = "Hello" });
        }
    
        public ObservableCollection<MyModel> Models
        {
            get { return _models; }
            set { _models = value; }
        }
    }
    
    public  class MyModel : INotifyPropertyChanged
    {
        private string _tName;
        private string _description;
    
        public string tName 
        {
            get { return _tName; }
            set { _tName = value; NotifyPropertyChanged("tName"); } 
        }
    
        public string Description
        {
            get { return _description; }
            set { _description = value; NotifyPropertyChanged("Description"); }
        }
    
        public event PropertyChangedEventHandler PropertyChanged;
        private void NotifyPropertyChanged(string property)
        {
            if (PropertyChanged != null)
            {
                PropertyChanged(this, new PropertyChangedEventArgs(property));
            }
        }
    }
    

    result: enter image description here

    0 讨论(0)
提交回复
热议问题