Как перезагрузить страницу в методе OnAppearing? - PullRequest
1 голос
/ 02 июля 2019

Я на самом деле делаю xamarin и создаю пользовательскую панель навигации, которую я хочу использовать на многих страницах. Я добавляю свою панель навигации, как это в моем PageA.xaml:

<NavigationPage.TitleView > <cvNavBar:CustomNavigationBar Title="{Binding Title}" Voyage="{Binding Voyage}" SeeCariste="{Binding SeeCariste}"/> </NavigationPage.TitleView>

Я сделал то же самое в моем PageB.xaml

Когда я перехожу с моей страницы A на мою страницу B, на моих 2 страницах появляется хорошая панель навигации: enter image description here Но когда я перехожу со страницы PageB на страницу PageA, панель «сломалась»: enter image description here

Моей первой идеей было перезагрузить страницу PageA, когда я вернусь, используя метод OnAppearing в моей странице PageA. Поэтому я спрашиваю вас, возможно ли это, или у вас есть другие идеи?

Спасибо!

Редактировать: My CustomNavigationBar.xaml

<?xml version="1.0" encoding="UTF-8"?>
<ContentView xmlns="http://xamarin.com/schemas/2014/forms" 
         xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
         xmlns:b="clr-namespace:Prism.Behaviors;assembly=Prism.Forms"

x:Class="LogiStock.UI.ContentViews.UI.NavigationBar.CustomNavigationBar"
         x:Name="CView" Padding="5">

<ContentView.Content>
    <!-- Conteneur de la NavigationBar -->
    <StackLayout Orientation="Horizontal">
        <!-- Titre de la page -->
        <StackLayout Orientation="Horizontal" 
HorizontalOptions="StartAndExpand" VerticalOptions="Center">
            <Label Text="{Binding Title}" LineBreakMode="TailTruncation" 
TextColor="White" FontSize="{Binding FontSizeXXLarge}"/>
        </StackLayout>

        <!-- Test ContentView pour contenu éventuel -->
        <ContentView Content="{Binding Source={x:Reference 
CView},Path=AdditionalContent}"
                     VerticalOptions="Center">
        </ContentView>


        <StackLayout Orientation="Horizontal" HorizontalOptions="End">
            <!-- Icône Settings -->
            <Image Source="{OnPlatform Android='settings', 
UWP='Assets/settings.png'}"
                   IsVisible="{Binding Source={x:Reference CView}, 
Path=SettingsVisible}">
                <Image.GestureRecognizers>
                    <TapGestureRecognizer Command="{Binding Source= 
{x:Reference CView},Path=Parent.BindingContext.UneCommand}"/>
                </Image.GestureRecognizers>
            </Image>



            <!--Icône Transporteur-->
            <Image Source="{OnPlatform Android='chargement', 
UWP='Assets/chargement_small.png'}" 
                   IsVisible="{Binding Source={x:Reference CView}, 
Path=NotificationsVisible}"
                   Margin="3"
                   VerticalOptions="Center"
                   HorizontalOptions="End">
                <Image.GestureRecognizers>
                    <TapGestureRecognizer Command="{Binding Source= 
{x:Reference CView},Path=Parent.BindingContext.LoginUserCommand}"/>
                </Image.GestureRecognizers>
            </Image>
            <!--Vignette-->
            <Frame Padding="4,1" 
                   Style="{StaticResource Key=frameVignette}"
                   HasShadow="False" 
                   BackgroundColor="Red" 
                   VerticalOptions="Start"
                   HorizontalOptions="Start"
                   Margin="-30,0,0,0">
                <Label Text="{Binding Voyage}"
                       TextColor="White"
                       FontSize="{Binding FontSizeXXSmall}"
                       FontAttributes="Bold"
                       HorizontalOptions="Center"
                       HorizontalTextAlignment="Center"/>
            </Frame>
            <!--Choix Cariste
            <Picker IsVisible="{Binding SeeCariste} " ItemsSource=" 
{Binding Caristes}" SelectedItem="{Binding SelectedCariste}" 
SelectedIndex="{Binding SelectedCaristeIndex}"
                ItemDisplayBinding="{Binding Code, Mode=TwoWay}" 
HorizontalOptions="End" WidthRequest="{OnPlatform Android=150, UWP=250}" 
TextColor="White" FontSize="{Binding FontSizeMedium}">
                <Picker.Behaviors>
                    <b:EventToCommandBehavior 
EventName="SelectedIndexChanged" Command="{Binding 
CaristeChangedCommand}"/>
                </Picker.Behaviors>
            </Picker>-->



        </StackLayout>
    </StackLayout>
</ContentView.Content>
</ContentView>

И код позади:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

using Xamarin.Forms;
using Xamarin.Forms.Xaml;

namespace LogiStock.UI.ContentViews.UI.NavigationBar
{
[XamlCompilation(XamlCompilationOptions.Compile)]
public partial class CustomNavigationBar : ContentView
{
    /// <summary>
    /// Title représente le titre de la page.
    /// </summary>

    public string Title
    {
        get { return (string)GetValue(TitleProperty); }
        set { SetValue(TitleProperty, value); }
    }
    public string Voyage
    {
        get { return (string)GetValue(VoyageProperty); }
        set { SetValue(VoyageProperty, value); }
    }
    public bool SeeCariste
    {
        get { return (bool)GetValue(SeeCaristeProperty); }
        set { SetValue(SeeCaristeProperty, value); }
    }

    public bool SettingsVisible
    {
        get { return (bool)GetValue(SettingsVisibleProperty); }
        set { SetValue(SettingsVisibleProperty, value); }
    }

    public bool NotificationsVisible
    {
        get { return (bool)GetValue(NotificationsVisibleProperty); }
        set { SetValue(NotificationsVisibleProperty, value); }
    }

    public ContentView AdditionalContent
    {
        get { return (ContentView)GetValue(AdditionalContentProperty); }
        set { SetValue(AdditionalContentProperty, value); }
    }

    public static BindableProperty TitleProperty = BindableProperty
        .Create("Title",
        typeof(string),
        typeof(CustomNavigationBar),
        string.Empty,
        BindingMode.OneWay
        , propertyChanged: TitlePropertyChanged
        );

    public static BindableProperty VoyageProperty = BindableProperty
        .Create("Voyage",
        typeof(string),
        typeof(CustomNavigationBar),
        string.Empty,
        BindingMode.OneWay
        , propertyChanged: VoyagePropertyChanged
        );

    public static BindableProperty SeeCaristeProperty = BindableProperty
        .Create("SeeCariste",
        typeof(bool),
        typeof(CustomNavigationBar),
        false,
        BindingMode.OneWay
        , propertyChanged: SeeCaristeChanged
        );

    public static BindableProperty AdditionalContentProperty = 
BindableProperty
        .Create("AdditionalContent",
        typeof(ContentView),
        typeof(CustomNavigationBar),
        new ContentView(),
        BindingMode.OneWay
        , propertyChanged: AdditionalContentPropertyChanged
        );

    public static BindableProperty SettingsVisibleProperty = 
BindableProperty
        .Create("SettingsVisible",
        typeof(bool),
        typeof(CustomNavigationBar),
        false,
        BindingMode.OneWay
        , propertyChanged: SettingsVisiblePropertyChanged
        );

    public static BindableProperty NotificationsVisibleProperty = 
BindableProperty
        .Create("NotificationsVisible",
        typeof(bool),
        typeof(CustomNavigationBar),
        true,
        BindingMode.OneWay
        , propertyChanged: NotificationsVisiblePropertyChanged
        );

    private static void NotificationsVisiblePropertyChanged(BindableObject 
bindable, object oldValue, object newValue)
    {
        var control = (CustomNavigationBar)bindable;
        control.NotificationsVisible = (bool)newValue;
    }

    private static void SettingsVisiblePropertyChanged(BindableObject 
bindable, object oldValue, object newValue)
    {
        var control = (CustomNavigationBar)bindable;
        control.SettingsVisible = (bool)newValue;
    }

    private static void TitlePropertyChanged(BindableObject bindable, object 
oldValue, object newValue)
    {
        var control = (CustomNavigationBar)bindable;
        control.Title = newValue.ToString();
    }

    private static void VoyagePropertyChanged(BindableObject bindable, 
object oldValue, object newValue)
    {
        var control = (CustomNavigationBar)bindable;
        control.Voyage = newValue.ToString();
    }
    private static void SeeCaristeChanged(BindableObject bindable, object 
oldValue, object newValue)
    {
        var control = (CustomNavigationBar)bindable;
        control.SettingsVisible = (bool)newValue;
    }

    private static void AdditionalContentPropertyChanged(BindableObject 
bindable, object oldValue, object newValue)
    {
        //if (newValue == null)
        //    return;

        var control = (CustomNavigationBar)bindable;
        control.AdditionalContent = (ContentView)newValue;

        //CustomNavigationBar cnb = new CustomNavigationBar();
        //cnb.cvContenu = control.AdditionalContent;
    }

    public CustomNavigationBar()
    {
        InitializeComponent();
    }



}
}

1 Ответ

0 голосов
/ 03 июля 2019

Итак, я решил свою проблему, выведя мою метку (вы можете увидеть ее в моем CustomNavigationBar) из моего фрейма!Теперь все идет хорошо

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...