У меня есть Аккордеон, и высота его содержимого может быть динамически изменена. Я хотел бы видеть, как Аккордеон динамически реагирует на рост дочернего элемента, но у меня возникают проблемы с этим.
<lt:Accordion Name="MyAccordion"
SelectionMode="ZeroOrOne"
HorizontalAlignment="Stretch">
<lt:AccordionItem Name="MyAccordionItem"
Header="MyAccordion"
IsSelected="True"
HorizontalContentAlignment="Stretch"
VerticalAlignment="Stretch">
<StackPanel>
<Button Content="Grow" Click="Grow"/>
<Button Content="Shrink" Click="Shrink"/>
<TextBox Name="GrowTextBox"
Text="GrowTextBox"
Height="400"
Background="Green"
SizeChanged="GrowTextBox_SizeChanged"/>
</StackPanel>
</lt:AccordionItem>
</lt:Accordion>
private void Grow(object sender, System.Windows.RoutedEventArgs e)
{
GrowTextBox.Height += 100;
}
private void Shrink(object sender, System.Windows.RoutedEventArgs e)
{
GrowTextBox.Height -= 100;
}
private void GrowTextBox_SizeChanged(object sender, System.Windows.SizeChangedEventArgs e)
{
MyAccordion.UpdateLayout();
MyAccordionItem.UpdateLayout();
}
Имейте в виду, что если я сверну, а затем снова открою гармошку, она приобретет форму именно так, как я хочу, но я бы хотел, чтобы это изменение размера происходило сразу же после изменения размера ребенка.
Я слабо попытался исправить это, добавив обработчик события SizeChanged, который вызывает UpdateLayout () для Accordion и AccordionItem, но это не имеет никакого визуального эффекта. Я не могу понять, где происходит правильное изменение размера внутри элемента управления Accordion. У кого-нибудь есть идея?