Масштабирование элемента в Listbox / SurfaceListbox WPF - PullRequest
0 голосов
/ 09 марта 2011

Я работаю над SurfaceListbox, но я думаю, что логика применима и к обычному списку WPF.

У меня есть Surfacelistbox с включенной горизонтальной прокруткой.Он содержит около 20 предметов.Поле listlist будет размещено в центре экрана.Теперь, когда пользователь прокручивает список, элементы перемещаются горизонтально и в зависимости от размера каждого элемента в списке, я видел, как правило, 3 элемента видны в любой момент времени на экране.

Теперь я хочу, чтобы пользователь прекратил прокрутку, когда 3 элемента были видны, и я хочу увеличить центральный элемент, т.е. в основном увеличить его, чтобы выделить его.

Любые указателио том, как реализовать такую ​​функциональность в WPF было бы здорово.Так как пользователь не делает выбор при прокрутке, я не смог использовать событие selectionchanged, чтобы узнать, какой из них является центральным элементом.

Ответы [ 2 ]

0 голосов
/ 02 июня 2011
0 голосов
/ 27 марта 2011

Поместите SurfaceListBox в Grid и привяжите ScaleTransform к ползунку с диапазоном от 1 до 5 с центром в Grid, используя RenderTransformOrigin = "0.5,0.5".

Для ItemsSource установлено значение ObservableCollection;Я включаю некоторые определения ниже для полноты, чтобы помочь другим следовать.Я могу предоставить больше кода, если необходимо.

Вот представление:

<Window x:Class="SurfaceControls.MainWindow"
    Icon="/Images/logo.gif"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    Title="Surface Toolkit Controls" Height="500" Width="600" 
    xmlns:my="http://schemas.microsoft.com/surface/2008" >
  <Window.Resources>
    <DataTemplate x:Key="EquipmentItemStyle">
        <StackPanel Orientation="Vertical">
            <TextBlock Text="{Binding Path=Id}"/>
            <TextBlock Text="{Binding Path=EquipmentName}"/>
            <TextBlock Text="{Binding Path=EquipmentType}"/>
        </StackPanel>
    </DataTemplate>
  </Window.Resources>
  <Grid>
    <Grid.RowDefinitions>
        <RowDefinition/>
        <RowDefinition Height="Auto"/>
    </Grid.RowDefinitions>
    <Grid RenderTransformOrigin="0.5,0.5"  Grid.Row="0">
        <Grid.RenderTransform>
            <TransformGroup>
                <ScaleTransform 
                    ScaleY="{Binding Path=Value, ElementName=slider}" 
                    ScaleX="{Binding Path=Value, ElementName=slider}"/>
            </TransformGroup>
        </Grid.RenderTransform>
        <my:SurfaceListBox 
                ItemsSource="{Binding Path=Equipment, Mode=TwoWay}" 
                SelectedItem="{Binding Path=SelectedEquipment, Mode=TwoWay}"
                ItemTemplate="{StaticResource ResourceKey=EquipmentItemStyle}" >
            <ListBox.ItemsPanel>
                <ItemsPanelTemplate>
                    <StackPanel Orientation="Horizontal"
                                VerticalAlignment="Stretch"
                                HorizontalAlignment="Center"/>
                </ItemsPanelTemplate>
            </ListBox.ItemsPanel>
        </my:SurfaceListBox>
    </Grid>
    <StackPanel Grid.Row="1" Orientation="Horizontal">
        <my:SurfaceSlider Ticks="5" 
                                Width="100" 
                                Minimum="1"
                                Interval="1"
                                Maximum="5"
                                x:Name="slider"
                                VerticalAlignment="Center"
                                Margin="4,4,4,4"/>
    </StackPanel>
  </Grid>
</Window>

Вот эта коллекция, связанная списком ListBox:

private ObservableCollection<Equipment> _equipment = new ObservableCollection<Equipment>();
public ObservableCollection<Equipment> Equipment
{
  get
  {
    return _equipment;
  }
  set
  {
    _equipment = value;
  }
}

И определениемодель:

public class Equipment
{
  public int Id { get; set; }
  public string EquipmentName { get; set; }
  public string EquipmentType { get; set; }
}
...