web-dev-qa-db-ja.com

PushAsyncはAndroidではグローバルにサポートされていません。NavigationPageを使用してください-Xamarin.Forms

ボタンクリックイベントに配線された_Xamarin.Forms.ContentPage_に次のメソッドがあります

_public class LoginPage : ContentPage
{
    private Button _loginButton = null;
    private Entry _PasswordInput = null;
    private Entry _UsernameInput = null;

    public LoginPage()
    {
        _UsernameInput = new Entry { Placeholder = "Username" };
        _PasswordInput = new Entry { Placeholder = "Password", IsPassword = true };

        _loginButton = new Button
        {
            Text = "Login",
            BorderRadius = 5
        }

        _loginButton.Clicked += LogIn;

        Content = new StackLayout 
        {
            VerticalOptions = LayoutOptions.Center,
            Children = 
            {
                 _UsernameInput, _PasswordInput, _loginButton, 
            },
            Spacing = 15
        };
    }

    public async void LogIn(object sender, EventArgs eventsArgs)
    {
        //do authenticate stuff here
        SSO.MyAuthentication client = new SSO.MyAuthentication();

        bool isAuthenticated = client.Authenticate(_UsernameInput.Text, _PasswordInput.Text);

        if(isAuthenticated)
        {
             //Push home page to top of navigation stack
             Navigation.PushAsync(new HomePage());
        }
    }
}
_

コードNavigation.PushAsync(new HomePage());の次の行で、デバッグ中に次の例外が発生します。

PushAsyncはAndroidではグローバルにサポートされていません。NavigationPageを使用してください

_Xamarin.Forms.NavigationPage_オブジェクトを使用してこの問題を解決するにはどうすればよいですか?

50

あなたは"PushAsync"を呼び出しています:

public partial class MainPage : ContentPage
{
    public MainPage()
    {
        InitializeComponent();
    }

    private void btnCourseList_Clicked(object sender, EventArgs e)
    {
        Navigation.PushAsync(new PageB());
    }
}

ただし、通常はApp.csクラスで行われるNavigationPageを開始しなかったか、少なくとも"PushAsync"を呼び出す前に開始する必要があります。

MainPage = new NavigationPage(new PageA());
98
Reader Man San

App.xaml.csファイルで、

交換

 MainPage = new <namespace>.MainPage();

 MainPage = new NavigationPage(new <namespace>.MainPage());

次に使用

 await Navigation.PushAsync(new NavigationPage(new MainPage2()));
26
Amar Mathur

LoginPageをNavigationPageで囲む必要があります。これによりエラーが修正されますが、ナビゲーションスタックにLoginPageが含まれたままになります。

別の方法として、HomePageをアプリケーションのルートにし、その上にLoginPageをモーダルに表示することもできます。ユーザーが正常にログインした場合にのみ、HomePageを表示できるようにLoginPageモーダルを閉じます。

13
Jason

PushModalAsyncでpushAsyncを変更するだけです:)

public async void LogIn(object sender, EventArgs eventsArgs)
{
    //do authenticate stuff here
    SSO.MyAuthentication client = new SSO.MyAuthentication();

    bool isAuthenticated = client.Authenticate(_UsernameInput.Text, _PasswordInput.Text);

    if(isAuthenticated)
    {
         //Push home page to top of navigation stack
         //Navigation.PushAsync(new HomePage());
           Navigation.PushModalAsync(new HomePage());
    }
}
5
T M

解決した私はそのようにした...最初に「メインアプリページ」で設定を行い、次に「コンテンツページ」で他のページに移動します。

enter image description here

0
Ayaat Shifa

Rg.Plugins.PopupとZXin.Net.Mobile Scannerの混合に問題がありました。

ポップアップ内でスキャナーを呼び出すと、この同じエラーがトリガーされました。 PushModalAsyncはエラーを解決しましたが、ポップアップがスキャンを超えていたため、スキャナーがオンになるまでポップアップを非表示にする簡単な解決策でした。

    private async void FrmQrCode_Tapped(object sender, EventArgs e)
    {
        ZXingScannerPage scanPage = new ZXingScannerPage();
        scanPage.OnScanResult += (result) =>
        {
            scanPage.IsScanning = false;
            ZXing.BarcodeFormat barcodeFormat = result.BarcodeFormat;
            string type = barcodeFormat.ToString();
            Device.BeginInvokeOnMainThread(() =>
            {
                Navigation.PopModalAsync();

                this.IsVisible = true;

                Token = result.Text.Trim();
            });
        };
        this.IsVisible = false;
        await Navigation.PushModalAsync(scanPage);
    }
0
Faruk A Feres