Xamarin - Erstellen der App-GUI
Textvorschau
TextView ist eine sehr wichtige Komponente der Android-Widgets. Es wird hauptsächlich zum Anzeigen von Texten auf einem Android-Bildschirm verwendet.
Um eine Textansicht zu erstellen, öffnen Sie einfach main.axml und fügen Sie den folgenden Code zwischen den linearen Layout-Tags ein.
<TextView
android:text = "Hello I am a text View"
android:layout_width = "match_parent"
android:layout_height = "wrap_content"
android:id = "@+id/textview1" />
Taste
Eine Schaltfläche ist ein Steuerelement, mit dem ein Ereignis ausgelöst wird, wenn darauf geklickt wird. Unter deinemMain.axml Geben Sie den folgenden Code ein, um eine Schaltfläche zu erstellen.
<Button
android:id = "@+id/MyButton"
android:layout_width = "fill_parent"
android:layout_height = "wrap_content"
android:text = "@string/Hello" />
Öffnen Resources\Values\Strings.xml und geben Sie die folgende Codezeile zwischen das <resources> -Tag ein.
<string name="Hello">Click Me!</string>
Der obige Code gibt den Wert der von uns erstellten Schaltfläche an. Als nächstes öffnen wirMainActivity.csund erstellen Sie die Aktion, die ausgeführt werden soll, wenn Sie auf die Schaltfläche klicken. Geben Sie den folgenden Code unter einbase.OnCreate (Bündel-) Methode.
Button button = FindViewById<Button>(Resource.Id.MyButton);
button.Click += delegate { button.Text = "You clicked me"; };
Der obige Code zeigt "Sie haben mich angeklickt" an, wenn ein Benutzer auf die Schaltfläche klickt.
FindViewById<< -->Diese Methode ermittelt die ID einer Ansicht, die identifiziert wurde. Es sucht nach der ID in der XML-Layoutdatei.
Kontrollkästchen
Ein Kontrollkästchen wird verwendet, wenn mehrere Optionen aus einer Gruppe von Optionen ausgewählt werden sollen. In diesem Beispiel erstellen wir ein Kontrollkästchen, das bei Auswahl eine Meldung anzeigt, dass es aktiviert wurde, andernfalls wird es deaktiviert angezeigt.
Zunächst öffnen wir Main.axml Datei in unserem Projekt und geben Sie die folgende Codezeile ein, um ein Kontrollkästchen zu erstellen.
<?xml version = "1.0" encoding = "utf-8"?>
<LinearLayout xmlns:android = "http://schemas.android.com/apk/res/android"
android:orientation = "vertical"
android:background = "#d3d3d3"
android:layout_width = "fill_parent"
android:layout_height = "fill_parent">
<CheckBox
android:text = "CheckBox"
android:padding = "25dp"
android:layout_width = "300dp"
android:layout_height = "wrap_content"
android:id = "@+id/checkBox1"
android:textColor = "@android:color/black"
android:background = "@android:color/holo_blue_dark" />
</LinearLayout>
Als nächstes gehen Sie zu MainActivity.cs um den Funktionscode hinzuzufügen.
CheckBox checkMe = FindViewById<CheckBox>(Resource.Id.checkBox1);
checkMe.CheckedChange += (object sender, CompoundButton.CheckedChangeEventArgs e) => {
CheckBox check = (CheckBox)sender;
if(check.Checked) {
check.Text = "Checkbox has been checked";
} else {
check.Text = "Checkbox has not been checked";
}
};
Aus dem obigen Code finden wir zuerst das Kontrollkästchen mit findViewById. Als Nächstes erstellen wir eine Handlermethode für unser Kontrollkästchen und erstellen in unserem Handler eine if else-Anweisung, die abhängig vom ausgewählten Ergebnis eine Nachricht anzeigt.
CompoundButton.CheckedChangeEventArgs → Diese Methode löst ein Ereignis aus, wenn sich der Status des Kontrollkästchens ändert.
Fortschrittsanzeige
Ein Fortschrittsbalken ist ein Steuerelement, mit dem der Fortschritt einer Operation angezeigt wird. Fügen Sie zum Hinzufügen eines Fortschrittsbalkens die folgende Codezeile hinzuMain.axml Datei.
<ProgressBar
style="?android:attr/progressBarStyleHorizontal"
android:layout_width = "match_parent"
android:layout_height = "wrap_content"
android:id = "@+id/progressBar1" />
Als nächstes gehen Sie zu MainActivity.cs und legen Sie den Wert des Fortschrittsbalkens fest.
ProgressBar pb = FindViewById<ProgressBar>(Resource.Id.progressBar1);
pb.Progress = 35;
Im obigen Code haben wir einen Fortschrittsbalken mit dem Wert 35 erstellt.
Radio Knöpfe
Dies ist ein Android-Widget, mit dem eine Person aus einer Reihe von Optionen eine auswählen kann. In diesem Abschnitt erstellen wir eine Funkgruppe mit einer Liste von Fahrzeugen, die ein markiertes Optionsfeld abruft.
Zuerst fügen wir eine Radiogruppe und eine hinzu textview wie im folgenden Code gezeigt -
<?xml version = "1.0" encoding = "utf-8"?>
<LinearLayout xmlns:android = "http://schemas.android.com/apk/res/android"
android:orientation = "vertical"
android:background = "@android:color/darker_gray"
android:layout_width = "fill_parent"
android:layout_height = "fill_parent">
<TextView
android:text = "What is your favourite Car"
android:layout_width = "match_parent"
android:layout_height = "wrap_content"
android:id = "@+id/textView1"
android:textColor = "@android:color/black" />
<RadioGroup
android:layout_width = "match_parent"
android:layout_height = "wrap_content"
android:id = "@+id/radioGroup1"
android:backgroundTint = "#a52a2aff"
android:background = "@android:color/holo_green_dark">
<RadioButton
android:layout_width = "wrap_content"
android:layout_height = "wrap_content"
android:text = "Ferrari"
android:id = "@+id/radioFerrari" />
<RadioButton
android:layout_width = "wrap_content"
android:layout_height = "wrap_content"
android:text = "Mercedes"
android:id = "@+id/radioMercedes" />
<RadioButton
android:layout_width = "wrap_content"
android:layout_height = "wrap_content"
android:text = "Lamborghini"
android:id = "@+id/radioLamborghini" />
<RadioButton
android:text = "Audi"
android:layout_width = "match_parent"
android:layout_height = "wrap_content"
android:id = "@+id/radioAudi" />
</RadioGroup>
</LinearLayout>
Um eine Aktion auszuführen, fügen wir beim Klicken auf ein Optionsfeld eine Aktivität hinzu. Gehe zuMainActivity.cs und erstellen Sie einen neuen Ereignishandler wie unten gezeigt.
private void onClickRadioButton(object sender, EventArgs e) {
RadioButton cars = (RadioButton)sender;
Toast.MakeText(this, cars.Text, ToastLength.Short).Show
();
}
Toast.MakeText() →Dies ist eine Ansichtsmethode, mit der eine Nachricht / Ausgabe in einem kleinen Popup angezeigt wird. Am Ende desOnCreate() Methode gleich danach SetContentView()Fügen Sie den folgenden Code hinzu. Dadurch werden alle Optionsfelder erfasst und dem von uns erstellten Ereignishandler hinzugefügt.
RadioButton radio_Ferrari = FindViewById<RadioButton>
(Resource.Id.radioFerrari);
RadioButton radio_Mercedes = FindViewById<RadioButton>
(Resource.Id.radioMercedes);
RadioButton radio_Lambo = FindViewById<RadioButton>
(Resource.Id.radioLamborghini);
RadioButton radio_Audi = FindViewById<RadioButton>
(Resource.Id.radioAudi);
radio_Ferrari.Click += onClickRadioButton;
radio_Mercedes.Click += onClickRadioButton;
radio_Lambo.Click += onClickRadioButton;
radio_Audi.Click += onClickRadioButton;
Führen Sie nun Ihre Anwendung aus. Es sollte den folgenden Bildschirm als Ausgabe anzeigen -
Schaltflächen umschalten
Die Umschalttaste wird verwendet, um zwischen zwei Zuständen zu wechseln, z. B. kann zwischen EIN und AUS umgeschaltet werden. ÖffnenResources\layout\Main.axml und fügen Sie die folgenden Codezeilen hinzu, um eine Umschalttaste zu erstellen.
<?xml version = "1.0" encoding = "utf-8"?>
<LinearLayout xmlns:android = "http://schemas.android.com/apk/res/android"
android:orientation = "vertical"
android:background = "#d3d3d3"
android:layout_width = "fill_parent"
android:layout_height = "fill_parent">
<ToggleButton
android:id = "@+id/togglebutton"
android:layout_width = "wrap_content"
android:layout_height = "wrap_content"
android:textOn = "Torch ON"
android:textOff = "Torch OFF"
android:textColor = "@android:color/black" />
</LinearLayout>
Wir können der Umschaltleiste Aktionen hinzufügen, wenn darauf geklickt wird. ÖffnenMainActivity.cs und fügen Sie die folgenden Codezeilen nach dem hinzu OnCreate() Methodenklasse.
ToggleButton togglebutton = FindViewById<ToggleButton> (Resource.Id.togglebutton);
togglebutton.Click += (o, e) => {
if (togglebutton.Checked)
Toast.MakeText(this, "Torch is ON", ToastLength.Short).Show ();
else
Toast.MakeText(this, "Torch is OFF",
ToastLength.Short).Show();
};
Wenn Sie die App ausführen, sollte nun die folgende Ausgabe angezeigt werden:
Bewertungsleiste
Eine Bewertungsleiste ist ein Formularelement, das aus Sternen besteht, mit denen App-Benutzer Dinge bewerten können, die Sie für sie bereitgestellt haben. In deinerMain.axml Datei, erstellen Sie eine neue Bewertungsleiste mit 5 Sternen.
<?xml version = "1.0" encoding = "utf-8"?>
<LinearLayout xmlns:android = "http://schemas.android.com/apk/res/android"
android:orientation = "vertical"
android:background = "#d3d3d3"
android:layout_width = "fill_parent"
android:layout_height = "fill_parent">
<RatingBar
android:layout_width = "wrap_content"
android:layout_height = "wrap_content"
android:id = "@+id/ratingBar1"
android:numStars = "5"
android:stepSize = "1.0" />
</LinearLayout>
Beim Ausführen der App sollte die folgende Ausgabe angezeigt werden:
Textansicht zur automatischen Vervollständigung
Dies ist eine Textansicht, in der vollständige Vorschläge angezeigt werden, während ein Benutzer tippt. Wir werden eine automatische Vervollständigung der Textansicht erstellen, die eine Liste der Namen von Personen und eine Schaltfläche enthält, die uns beim Klicken den ausgewählten Namen anzeigt.
Öffnen Main.axml und schreiben Sie den folgenden Code.
<?xml version = "1.0" encoding = "utf-8"?>
<LinearLayout xmlns:android = "http://schemas.android.com/apk/res/android"
android:orientation = "vertical"
android:layout_width = "fill_parent"
android:background = "#d3d3d3"
android:layout_height = "fill_parent">
<TextView
android:text = "Enter Name"
android:textAppearance = "?android:attr/textAppearanceMedium"
android:layout_width = "fill_parent"
android:layout_height = "wrap_content"
android:id = "@+id/textView1"
android:padding = "5dp"
android:textColor = "@android:color/black" />
<AutoCompleteTextView
android:layout_width = "fill_parent"
android:layout_height = "wrap_content"
android:id = "@+id/autoComplete1"
android:textColor = "@android:color/black" />
<Button
android:text = "Submit"
android:layout_width = "fill_parent"
android:layout_height = "wrap_content"
android:id = "@+id/btn_Submit"
android:background="@android:color/holo_green_dark" />
</LinearLayout>
Der obige Code generiert eine Textansicht zum Eingeben. AutoCompleteTextViewzum Anzeigen von Vorschlägen und eine Schaltfläche zum Anzeigen der in der Textansicht eingegebenen Namen. Gehe zuMainActivity.cs um die Funktionalität hinzuzufügen.
Erstellen Sie eine neue Ereignishandlermethode wie unten gezeigt.
protected void ClickedBtnSubmit(object sender, System.EventArgs e){
if (autoComplete1.Text != ""){
Toast.MakeText(this, "The Name Entered ="
+ autoComplete1.Text, ToastLength.Short).Show();
} else {
Toast.MakeText(this, "Enter a Name!", ToastLength.Short).Show();
}
}
Der erstellte Handler prüft, ob die Textansicht zur automatischen Vervollständigung leer ist. Wenn es nicht leer ist, wird der ausgewählte Text für die automatische Vervollständigung angezeigt. Geben Sie den folgenden Code in das Feld einOnCreate() Klasse.
autoComplete1 = FindViewById<AutoCompleteTextView>(Resource.Id.autoComplete1);
btn_Submit = FindViewById<Button>(Resource.Id.btn_Submit);
var names = new string[] { "John", "Peter", "Jane", "Britney" };
ArrayAdapter adapter = new ArrayAdapter<string>(this,
Android.Resource.Layout.SimpleSpinnerItem, names);
autoComplete1.Adapter = adapter;
btn_Submit.Click += ClickedBtnSubmit;
ArrayAdapter - Dies ist ein Sammlungshandler, der Datenelemente aus einer Listensammlung liest und als Ansicht zurückgibt oder auf dem Bildschirm anzeigt.
Wenn Sie die Anwendung ausführen, sollte nun die folgende Ausgabe angezeigt werden.