Поэтому я изменил ориентацию расширителя, чтобы выровнять его по вертикали, а не по горизонтали, но в закрытом состоянии текст заголовка расширителя выравнивается по горизонтали. Пожалуйста, скажите мне, что есть способ легко исправить это без наложения выражений и т. Д.
<Expander Header="My Header">
Я надеялся на что-то вроде AlignHeaderText
по вертикали, но не вижу для этого вариантов? Есть ли у кого-нибудь другой способ "показать" мне?
Итак, взяв у наставника Х.Б., при условии, я придумал следующее:
<StackPanel Orientation="Horizontal" Margin="0,0,342,0" Width="318">
<StackPanel.Triggers>
<EventTrigger RoutedEvent="Expander.Expanded" SourceName="expander1">
<EventTrigger.Actions>
<BeginStoryboard>
<Storyboard>
<DoubleAnimation From="0" To="1.2" Duration="0:0:0.45" Storyboard.TargetName="content" Storyboard.TargetProperty="(FrameworkElement.LayoutTransform).(ScaleTransform.ScaleX)"/>
</Storyboard>
</BeginStoryboard>
</EventTrigger.Actions>
</EventTrigger>
</StackPanel.Triggers>
<Expander ExpandDirection="Right" Name="expander1" OpacityMask="#6C806969" Background="#FF807171">
<Expander.LayoutTransform>
<RotateTransform Angle="90"></RotateTransform>
</Expander.LayoutTransform>
<Expander.Header>
<TextBlock
Text="HEADER"
Width="{Binding
RelativeSource={RelativeSource
Mode=FindAncestor,
AncestorType={x:Type Expander}},
Path=ActualWidth}"
/>
</Expander.Header>
<Grid x:Name="content" Background="#FF807171" Width="178">
<Grid.LayoutTransform>
<ScaleTransform ScaleX="0" ScaleY="1"/>
</Grid.LayoutTransform>
</Grid>
</Expander>
К сожалению, это происходит с расширителем:
Он помещает текст вверху, а кнопку посередине, я надеялся на кнопку вверху, а текст после кнопки?
Если я изменю Path=ActualWidth
на Height
, кнопка переместится вверх, но текст заголовка останется слева от кнопки, а не под ней?