長方形でいっぱいのラップパネルがあります。長方形の上にマウスを置くと、拡大されることをシミュレートするためにサイズが大きくなります(ストーリーボードアニメーションを使用)。
それはすべて正常に機能しますが、問題は、行の最後の長方形の上にマウスを置くと、倍率によって次の行にジャンプすることです(現在の行に収まらないほど大きくなったため)。このシナリオを防ぐための洗練された解決策があると確信していますが、私には理解できません。どんな助けでも大歓迎です。
すべてを実行するXAMLは次のとおりです。
<Window x:Class="WpfApplication1.Window1"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
Title="Window1" Height="300" Width="300">
<Grid>
<ListBox Name="lstBox"
Width="200"
ScrollViewer.HorizontalScrollBarVisibility="Disabled"
ScrollViewer.VerticalScrollBarVisibility="Disabled">
<ListBox.ItemsPanel>
<ItemsPanelTemplate>
<WrapPanel></WrapPanel>
</ItemsPanelTemplate>
</ListBox.ItemsPanel>
<ListBox.Resources>
<Style TargetType="{x:Type ListBoxItem}">
<Setter Property="HorizontalAlignment" Value="Center" />
<Setter Property="FontSize" Value="12" />
<Setter Property="LayoutTransform">
<Setter.Value>
<ScaleTransform
ScaleY="{Binding RelativeSource={RelativeSource self},
Path=ScaleX}" />
</Setter.Value>
</Setter>
<Style.Triggers>
<EventTrigger RoutedEvent="Button.MouseEnter">
<BeginStoryboard>
<Storyboard>
<DoubleAnimation
Storyboard.TargetProperty="LayoutTransform.ScaleX"
To="2" Duration="0:0:0.25" />
</Storyboard>
</BeginStoryboard>
</EventTrigger>
<EventTrigger RoutedEvent="Button.MouseLeave">
<BeginStoryboard>
<Storyboard>
<DoubleAnimation
Storyboard.TargetProperty="LayoutTransform.ScaleX"
To="1" Duration="0:0:.5" />
</Storyboard>
</BeginStoryboard>
</EventTrigger>
</Style.Triggers>
</Style>
</ListBox.Resources>
<ListBoxItem>
<Rectangle Fill="Red" Width="30" Height="20"></Rectangle>
</ListBoxItem>
<ListBoxItem>
<Rectangle Fill="Red" Width="30" Height="20"></Rectangle>
</ListBoxItem>
<ListBoxItem>
<Rectangle Fill="Red" Width="30" Height="20"></Rectangle>
</ListBoxItem>
<ListBoxItem>
<Rectangle Fill="Red" Width="30" Height="20"></Rectangle>
</ListBoxItem>
<ListBoxItem>
<Rectangle Fill="Red" Width="30" Height="20"></Rectangle>
</ListBoxItem>
<ListBoxItem>
<Rectangle Fill="Red" Width="30" Height="20"></Rectangle>
</ListBoxItem>
<ListBoxItem>
<Rectangle Fill="Red" Width="30" Height="20"></Rectangle>
</ListBoxItem>
<ListBoxItem>
<Rectangle Fill="Red" Width="30" Height="20"></Rectangle>
</ListBoxItem>
<ListBoxItem>
<Rectangle Fill="Red" Width="30" Height="20"></Rectangle>
</ListBoxItem>
</ListBox>
</Grid>