Xamarin: Wartedialog Daten laden

Version vom 18. Dezember 2020, 09:42 Uhr von Deko (Diskussion | Beiträge) (Links und Quellen)
(Unterschied) ← Nächstältere Version | Aktuelle Version (Unterschied) | Nächstjüngere Version → (Unterschied)

Wartedialog für Xamarin App

Sie haben eine mobile App entwickelt, die ihre Daten aus dem Internet, z.B. von einem Webservice, abruft. Es dauert ein bisschen, bis die Daten komplett geladen werden und der Benutzer Ihrer App muss diese ein paar Sekunden vor dem leeren Bildschirm sitzen bleiben. Das möchten Sie ändern und den Ladeprozess mit einem Wartedialog klar andeuten.

Viewmodel vorbereiten

Angenommen, Sie haben im ViewModel Ihr Datenobjekt:

private ObservableCollection<Customer> _customers;
public ObservableCollection<Customer> MyCustomerList
        {
            get
            {
                return _customers;
            }
            set
            {
                if (_customers!= value)
                {
                    _customers = value;
                    RaisePropertyChanged("MyCustomerList");
                }
            }
        }

Nun bereiten Sie bitte in Ihrem Viewmodel ein Flag IsLoaded vor:

private bool isLoaded;
public bool IsLoaded
        {
            get
            {
                return isLoaded;
            }
            private set
            {
                 if (isLoaded != value)
                 {
                    isLoaded = value;
                    RaisePropertyChanged("IsLoaded");
                 }
            }
        }

Setzen Sie dieses Flag vor und nach dem Laden der eigentlichen Daten:

public async void LoadData(int countryId)
        {
            IsLoaded = false;

            MyCustomerList = await DataManager.GetCostumersByLand (countryId);

            IsLoaded = true;
        }

Wartedialog für Xamarin.Android

Zuerst nehmen Sie bitte in das Layout Ihrer Xamarin.Android-App ein ProgressBar mit auf. Dieses sollte mittels eines FrameLayouts mit dem eigentlichen Content zusammengefasst werden.

<FrameLayout
        android:layout_width="fill_parent"
        android:layout_height="match_parent"
        <LinearLayout
            android:id="@+id/LoadLayout"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:orientation="vertical"
            android:visibility="invisible"
            android:gravity="center_horizontal|center_vertical">
            <ProgressBar
                android:layout_height="wrap_content"
                android:layout_width="wrap_content"
                android:id="@+id/ProgressBar1"
                android:indeterminateOnly="true"
                android:keepScreenOn="true"
                android:layout_marginTop="10dp"
                android:gravity="center_horizontal|center_vertical" />
        </LinearLayout>
        <ListView
            android:id="@+id/CustomersListView"
            android:layout_width="match_parent"
            android:layout_height="match_parent" />
</FrameLayout>

In der C#-Activity-Klasse Initialisieren Sie nun das Binding:

private Binding<ObservableCollection<Customer>, ObservableCollection<Customer>> bindingCustomerList;
private Binding<bool, bool> bindingIsLoaded;

protected override void OnStart()
        {
            base.OnStart();

            InitializeBindings();

            ViewModel.LoadData();
        }


protected override void OnStop()
        {
            base.OnStop();

            // Bindings detachen, sonst bleiben diese am Viewmodel hängen und 
            // Binding funktioniert fehlerhaft
            if (bindingCustomerList != null)
            {
                bindingCustomerList.Detach();
                bindingCustomerList = null;
            }

            if (bindingIsLoaded != null)
            {
                bindingIsLoaded.Detach();
                bindingIsLoaded = null;
            }
        }       

private void InitializeBindings()
        {
            // Bei Änderung der Daten im ViewModel UI aktualisieren
            bindingCustomerList = this.SetBinding(
                () => ViewModel.MyCustomerList).WhenSourceChanges(()
                =>
                {
                    myAdapter.DataSource = ViewModel.MyCustomerList;
                    CustomersListView.Adapter = myAdapter;
                    myAdapter.NotifyDataSetChanged();
                });

            // Sobald die Daten geladen werden, werden entsprechende Controls angezeigt
            bindingIsLoaded = this.SetBinding(() => ViewModel.IsLoaded).WhenSourceChanges(
                () => {
                    SetAktivContent();
                });
        }

Die Steuerung über sichtbare Objekte findet in der Methode SetActivContent statt:

private void SetActivContent(bool isloaded)
        {
            if (isloaded)
            {
                // Daten anzeigen
                this.CustomersListView.Visibility = ViewStates.Visible;
                this.LoadLayout.Visibility = ViewStates.Gone;
            }
            else
            {
                // Wartedialog anzeigen
                this.CustomersListView.Visibility = ViewStates.Gone;
                this.LoadLayout.Visibility = ViewStates.Visible;
            }
        }

Und sieht dann die Wartemaske in Xamarin.Android-App aus:

Wartemaske Android.jpg







Wartedialog für Xamarin.iOS

Bei Xamarin.iOS können Sie die gleiche Vorgehensweise benutzen, nur noch heißt da das entspre-chende Control für Wartedialog „UIActivityIndicatorView“ und sieht so aus:

Wartemaske iOS.png










Und die entsprechende Methode SetActivContent sieht dann wie folgt aus:

private void SetActivContent ()
        {
             if (ViewModel.IsLoaded == false)
             {
                    // Wartedialog anzeigen
                    this.ActivityIndicator1.Hidden = false;
                    this.ActivityIndicator1.StartAnimating();
		             this.CustomerTableView.Hidden = true;
             }
             else
             {
                    // Daten sind da
                    this.ActivityIndicator1.Hidden = true;
		             this.CustomerTableView.Hidden = false;
              }
         }

Weitere Informationen

Mehr Informationen zu unseren Softwarelösungen und Services finden Sie auf
www.max-it.de/Softwarelösungen

Links und Quellen

https://dotnet.microsoft.com/apps/xamarin

Kontakt

Wenn Sie Fragen oder Anmerkungen zu diesem Artikel haben, melden Sie sich bitte bei uns:
techcorner@max-it.de.

Über m.a.x. Informationstechnologie AG:
Als etabliertes Münchner Systemhaus zeichnen wir uns seit 1989 als verlässlicher IT-Partner mittelständischer und großer Unternehmen aus. Unser Portfolio reicht von IT- Services über individuelle Softwareentwicklung bis hin zur ERP-Beratung.

Tags

Xamarin, Android, iOS, Daten laden, ProgressBar, ActivityIndivator, Wartedialog, Wartemaske