wpf повернуть и перевести проблему преобразования в текстовом блоке - PullRequest
1 голос
/ 25 августа 2009

У меня есть список строк, которые я привязываю к элементу управления элементами.

Строки отображаются в текстовых блоках, которые я объявил в шаблоне itemscontrol. Я повернул текстовые блоки 270 так, чтобы текст находился сбоку - я также перевел текстовые блоки вниз по ширине, чтобы они были вверху страницы.

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

Может кто-нибудь указать мне правильное направление, пожалуйста?

<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="354" Width="632"
        DataContext="{Binding RelativeSource={RelativeSource Self}}" >
<Window.Resources>
    <TransformGroup x:Key="Rotate">
        <RotateTransform Angle="270" />
        <TranslateTransform Y="200" />
    </TransformGroup>
</Window.Resources>
<StackPanel Orientation="Vertical">
    <ItemsControl ItemsSource="{Binding MyStrings}" HorizontalAlignment="Left"  >
        <ItemsControl.ItemsPanel>
            <ItemsPanelTemplate>
                <StackPanel Orientation="Horizontal"/>
            </ItemsPanelTemplate>
        </ItemsControl.ItemsPanel>
        <ItemsControl.ItemTemplate>
            <DataTemplate>
                <Border BorderThickness="1" BorderBrush="Black" Width="200" Height="20" RenderTransform="{StaticResource Rotate}" >
                    <TextBlock Text="{Binding }"  >
                    </TextBlock>
                </Border>
            </DataTemplate>
        </ItemsControl.ItemTemplate>
    </ItemsControl>
</StackPanel>
</Window>

и код всего лишь ...

с использованием System.Collections.Generic; используя System.Windows;

namespace WpfApplication1
{
/// <summary>
/// Interaction logic for Window1.xaml
/// </summary>
public partial class Window1 : Window
{
    public Window1()
    {
        MyStrings = new List<string> {"monkey", "turtle", "rabbit"};
        InitializeComponent();
    }

    public List<string> MyStrings { get; set; }

}
}

1 Ответ

5 голосов
/ 25 августа 2009

Используйте LayoutTransform вместо RenderTransform. Это обеспечит, что логика расположения учитывает преобразованное расположение элементов.

<Border BorderThickness="1" BorderBrush="Black" Width="200" Height="20" LayoutTransform="{StaticResource Rotate}">
...