Как получить доступ к элементам управления в панели навигации WPF Frame?

Я добавил StackPanel на панель навигации фрейма. Я щелкнул правой кнопкой мыши на своем фрейме, затем "Редактировать шаблон" и "Редактировать текущий", затем я добавил мою названную StackPanel и несколько кнопок рядом с кнопками навигации. Большой! Это сработало.

<Frame  x:Name="MainContent" Content="{Binding CurrentContent, UpdateSourceTrigger=PropertyChanged}" ScrollViewer.VerticalScrollBarVisibility="Visible" 
                    ScrollViewer.CanContentScroll="True" NavigationUIVisibility="Visible" Style="{DynamicResource FrameStyle1}">
                    <Frame.Resources>
                        <!-- Something -->
 <ControlTemplate x:Key="FrameNavChromeTemplateKey" TargetType="{x:Type Frame}">
                            <Border BorderBrush="{TemplateBinding BorderBrush}" BorderThickness="{TemplateBinding BorderThickness}" Background="{TemplateBinding Background}" Padding="{TemplateBinding Padding}">
                                <DockPanel>
                                    <Grid Background="{StaticResource NavigationWindowNavigationChromeBackground}" DockPanel.Dock="Top" Height="22">
                                        <Grid.ColumnDefinitions>
                                            <ColumnDefinition Width="Auto"/>
                                            <ColumnDefinition Width="Auto"/>
                                            <ColumnDefinition Width="16"/>
                                            <ColumnDefinition Width="*"/>
                                        </Grid.ColumnDefinitions>
                                        <Menu x:Name="NavMenu" Grid.ColumnSpan="3" Height="16" Margin="1,0,0,0" Style="{StaticResource NavigationWindowMenu}" VerticalAlignment="Center">
                                            <MenuItem ItemContainerStyle="{StaticResource NavigationWindowNavigationButtonJournalEntryStyle}" Padding="0,2,4,0" Style="{StaticResource NavigationWindowMenuItem}">
                                                <MenuItem.ItemsSource>
                                                    <MultiBinding Converter="{StaticResource JournalEntryUnifiedViewConverter}">
                                                        <Binding Path="BackStack" RelativeSource="{RelativeSource TemplatedParent}"/>
                                                        <Binding Path="ForwardStack" RelativeSource="{RelativeSource TemplatedParent}"/>
                                                    </MultiBinding>
                                                </MenuItem.ItemsSource>
                                            </MenuItem>
                                        </Menu>
                                        <Path Grid.ColumnSpan="3" Grid.Column="0" Data="M22.5767,21.035 Q27,19.37 31.424,21.035 A12.5,12.5,0,0,0,53.5,13 A12.5,12.5,0,0,0,37.765,0.926 Q27,4.93 16.235,0.926 A12.5,12.5,0,0,0,0.5,13 A12.5,12.5,0,0,0,22.5767,21.035 z" HorizontalAlignment="Left" IsHitTestVisible="false" Margin="2,0,0,0" SnapsToDevicePixels="false" StrokeThickness="1" VerticalAlignment="Center">
                                            <Path.Fill>
                                                <LinearGradientBrush EndPoint="0,1" StartPoint="0,0">
                                                    <LinearGradientBrush.GradientStops>
                                                        <GradientStopCollection>
                                                            <GradientStop Color="#A0C2CCE7" Offset="0"/>
                                                            <GradientStop Color="#60FFFFFF" Offset="1"/>
                                                        </GradientStopCollection>
                                                    </LinearGradientBrush.GradientStops>
                                                </LinearGradientBrush>
                                            </Path.Fill>
                                            <Path.LayoutTransform>
                                                <ScaleTransform ScaleY="0.667" ScaleX="0.667"/>
                                            </Path.LayoutTransform>
                                            <Path.Stroke>
                                                <LinearGradientBrush EndPoint="0,1" StartPoint="0,0">
                                                    <LinearGradientBrush.GradientStops>
                                                        <GradientStopCollection>
                                                            <GradientStop Color="#FFB7C2E3" Offset="0.2"/>
                                                            <GradientStop Color="#A0FFFFFF" Offset="0.9"/>
                                                        </GradientStopCollection>
                                                    </LinearGradientBrush.GradientStops>
                                                </LinearGradientBrush>
                                            </Path.Stroke>
                                        </Path>
                                        <Button Grid.Column="0" Margin="3,0,1,0" Style="{StaticResource NavigationWindowBackButtonStyle}">
                                            <Button.LayoutTransform>
                                                <ScaleTransform ScaleY="0.667" ScaleX="0.667"/>
                                            </Button.LayoutTransform>
                                        </Button>
                                        <Button Grid.Column="1" Margin="1,0,0,0" Style="{StaticResource NavigationWindowForwardButtonStyle}">
                                            <Button.LayoutTransform>
                                                <ScaleTransform ScaleY="0.667" ScaleX="0.667"/>
                                            </Button.LayoutTransform>
                                        </Button>
                                        <StackPanel Orientation="Horizontal" Name="CUSTOMNAVBAR" Grid.Column="3" Margin="5,0,10,0">
                                            <Button></Button>
                                            <Button></Button>
                                        </StackPanel>
                                    </Grid>
                                    <ContentPresenter x:Name="PART_FrameCP"/>
                                </DockPanel>
                            </Border>
                            <ControlTemplate.Triggers>
                                <MultiTrigger>
                                    <MultiTrigger.Conditions>
                                        <Condition Property="CanGoForward" Value="false"/>
                                        <Condition Property="CanGoBack" Value="false"/>
                                    </MultiTrigger.Conditions>
                                    <Setter Property="IsEnabled" TargetName="NavMenu" Value="false"/>
                                </MultiTrigger>
                            </ControlTemplate.Triggers>
                        </ControlTemplate>
                        <!-- Something -->

 </Frame.Resources>
                </Frame>

Но я понятия не имею, как получить доступ к этой панели.. Я пытался:

        var x = (StackPanel)MainContent.Template.FindName("CUSTOMNAVBAR", MainContent);
        var y = (StackPanel)FindName("CUSTOMNAVBAR");
        var k = (StackPanel)MainContent.FindResource("CUSTOMNAVBAR");
        var i = (StackPanel)MainContent.Resources.FindName("CUSTOMNAVBAR");
        var z = (StackPanel)FindResource("CUSTOMNAVBAR");

И он продолжает возвращать ноль или выбрасывать исключение... Пожалуйста, помогите

2 ответа

Решение

Это должно работать:

var x = (StackPanel)MainContent.Template.FindName("CUSTOMNAVBAR", MainContent);

Но убедитесь, что вы запускаете код, когда окно уже загружено, например, помещая код в некоторые Loaded обработчик события. Или вы можете попробовать позвонить ApplyTemplate() Метод первый:

MainContent.ApplyTemplate();
var x = (StackPanel)MainContent.Template.FindName("CUSTOMNAVBAR", MainContent);

Для доступа к элементам кода необходимо установить директиву x:Name. Вы, кажется, используете имя сейчас. Желательно использовать привязку данных для получения / установки значений элементов управления WPF, например:

<StackPanel Orientation="Vertical">
                        <Label x:Name="PhotoFileName" Content="{Binding Imageinfo}">

(так далее)

Другие вопросы по тегам