Показать «всплывающее окно», когда Mouser Over Listbox Item

StackOverflow https://stackoverflow.com/questions/4726771

Вопрос

Я связываю наблюдаемую коллекцию в ListBox. У меня есть Data Tempate на элементе ListBox. Он согласен с одним элементом управления изображением и SOM TextBlock.

Если бы мышь на некотором элементе Listbox, я бы хотел достичь такого поведения:

  • Показать всплывающее окно/подсказка (некоторые «прямоугольник» с элементами управления) и свяжите значения из текущего элемента Listbox.
  • А в Textbox в шаблоне данных элемента у меня есть стиль, я хотел бы изменить цвет текста в TextBlock, например, с черного на зеленый.

Стиль здесь:

        <Style x:Key="FriedNickStyle" TargetType="TextBlock">
            <Setter Property="Margin" Value="2,2,2,2"/>
            <Setter Property="FontSize" Value="13"/>
            <Setter Property="FontWeight" Value="Medium"/>
            <Setter Property="Foreground" Value="Black"/>
        </Style>

SORY для моего английского, у меня есть проблема с тем, как описать это поведение правильно. Я пробую много вещей, но любой из них не работает хорошо.

Вот мой стиль:

     <DataTemplate x:Key="FriendListBoxItemTemplate">
                <Grid Name="RootLayout">
                    <Grid.ColumnDefinitions>
                        <ColumnDefinition Width="0.3*"></ColumnDefinition>
                        <ColumnDefinition Width="*"></ColumnDefinition>
                    </Grid.ColumnDefinitions>
                    <Grid.RowDefinitions>
                        <RowDefinition Height="60"></RowDefinition>
                    </Grid.RowDefinitions>
                    <Image Margin="4,4,4,2" Grid.Column="0">
                        <Image.Source >
                            <MultiBinding Converter="{StaticResource avatarConverter}">
                                <Binding Path="ProfilePhoto"></Binding>
                                <Binding Path="StatusInfo.IsLogged"></Binding>
                            </MultiBinding>
                        </Image.Source>
                    </Image>
                    <Grid  Grid.Column="1">
                        <Grid.ColumnDefinitions>
                            <ColumnDefinition Width="*"></ColumnDefinition>
                        </Grid.ColumnDefinitions>
                        <Grid.RowDefinitions>
                            <RowDefinition Height="*"></RowDefinition>
                        </Grid.RowDefinitions>
                    <TextBlock 
                                       Text="{Binding Path=Nick}" 
                                       Style="{StaticResource FriedNickStyle}"
                                       Grid.Column="0" Grid.Row="0">
                    </TextBlock>
                    </Grid>
                </Grid>
                <DataTemplate.Triggers>
                    <Trigger Property="IsMouseOver" Value="True">
                        <!--SHOW SOME POP UP WINDOW and bind properties from ITEM (VALUE)-->
<!--Change color of textBlock-->
                    </Trigger>
                </DataTemplate.Triggers>
            </DataTemplate>

Спасибо всем, кто мне помогает.

Это было полезно?

Решение

Ну, я нашел это туристический, Эта статья, по MSDN и другой Вопрос о переполнении стекаАнкет В основном, вот как:

<Popup Margin="10,10,0,13"
    Name="Popup1"
    HorizontalAlignment="Left"
    VerticalAlignment="Top"
    Width="194"
    Height="200"
    IsOpen="True">                      // change this to open it

   <TextBlock Name="McTextBlock" Background="LightBlue" >
        This is popup text
   </TextBlock>

Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top