Xamarin - Guide rapide
Xamarin repose sur le .NET Framework. Il permet de créer des applications qui s'exécutent facilement sur plusieurs plates-formes. Dans ce didacticiel, nous expliquerons comment vous pouvez utiliser Xamarin pour fournir des applications natives iOS, Android et Windows.
Commençons le didacticiel par une discussion sur l'installation de Xamarin sur les systèmes Windows et Mac.
Configuration requise
les fenêtres
Un ordinateur avec au moins 2 Go de RAM et exécutant Windows 7 ou supérieur (Windows 8-10 est fortement recommandé)
Visual Studio 2012 Professional ou supérieur
Xamarin pour Visual Studio
Mac
- Un ordinateur Mac exécutant OS X Yosemite (10.10) ou supérieur
- Kit de développement logiciel (SDK) Xamarin iOS
- IDE Xcode (7+) d'Apple et SDK iOS
- Studio Xamarin
Installation sous Windows
Téléchargez le programme d'installation Xamarin à partir de https://www.xamarin.com/download Avant d'exécuter le programme d'installation de Xamarin, assurez-vous d'avoir installé le SDK Android et le SDK Java sur votre ordinateur.
Exécutez le programme d'installation téléchargé pour commencer le processus d'installation -
L'écran du contrat de licence Xamarin s'affiche. Clique leNext bouton pour accepter l'accord.
Le programme d'installation recherchera tous les composants manquants et vous invitera à les télécharger et à les installer.
Une fois l'installation de Xamarin terminée, cliquez sur l'icône Close pour quitter et vous préparer à utiliser Xamarin.
Installation sur Mac
Téléchargez le programme d'installation de Xamarin Studio sur votre système Mac.
Exécutez le programme d'installation de Xamarin que vous avez téléchargé et suivez les étapes indiquées dans l'assistant d'installation.
Une fois l'installation terminée, vous pouvez commencer à utiliser Xamarin sur votre système.
Dans ce chapitre, nous verrons comment créer une petite application Android à l'aide de Xamarin.
Bonjour Xamarin! Application
Tout d'abord, démarrez une nouvelle instance de Visual Studio et accédez à File → New → Project.
Dans la boîte de dialogue Menu qui apparaît, accédez à Templates → Visual C# → Android → Blank App (Android).
Donnez un nom approprié à votre application. Dans notre cas, nous l'appelons“helloWorld”et enregistrez-le à l'emplacement par défaut fourni. Ensuite, cliquez sur le bouton OK pour le nouveau“helloXamarin” projet à charger.
Sur le solution, ouvert Resources → layout → Main.axmlfichier. Passez du mode Création et accédez auSource et tapez les lignes de code suivantes pour créer votre application.
<?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">
<TextView
android:text = "@string/HelloXamarin"
android:textAppearance = "?android:attr/textAppearanceLarge"
android:layout_width = "match_parent"
android:layout_height = "wrap_content"
android:id = "@+id/textView2"
android:textColor = "@android:color/black" />
</LinearLayout>
Dans le code ci-dessus, nous avons créé un nouvel Android textview. Ensuite, ouvrez les valeurs du dossier et double-cliquez surStrings.xmlpour l'ouvrir. Ici, nous allons stocker des informations et des valeurs sur lebutton créé ci-dessus.
<?xml version = "1.0" encoding = "utf-8"?>
<resources>
<string name = "HelloXamarin">Hello World, I am Xamarin!</string>
<string name = "ApplicationName">helloWorld</string>
</resources>
Ouvert MainActivity.cs et remplacez le code existant par les lignes de code suivantes.
using System;
using Android.App;
using Android.Content;
using Android.Runtime;
using Android.Views;
using Android.Widget;
using Android.OS;
namespace HelloXamarin {
public class MainActivity : Activity {
protected override void OnCreate(Bundle bundle) {
base.OnCreate(bundle);
SetContentView(Resource.Layout.Main);
}
}
}
Enregistrez l'application. Générez, puis exécutez-le pour afficher l'application créée dans un émulateur Android.
Si vous n'avez pas d'émulateur Android, suivez les étapes indiquées dans la section suivante pour en créer un.
Configurer un émulateur Android
Dans votre menu Visual Studio, accédez à Tools → Android → Android Emulator Manager. Dans la fenêtre contextuelle qui apparaît, cliquez sur le boutonCreatebouton. Il affichera l'écran suivant.
Sur l'écran ci-dessus, fournissez le AVD nametu veux. Sélectionner undevicequi convient à votre écran, par exemple un écran Nexus 4 ”. Sélectionnez votretarget platform. Il est toujours conseillé de tester sur une plate-forme cible minimale, par exemple, API 10 Android 2.3 (Gingerbread) afin de garantir que votre application fonctionne sur toutes les plates-formes Android.
Remplissez le reste des champs et cliquez sur le bouton OK. Votre émulateur est maintenant prêt. Vous pouvez le sélectionner dans la liste des appareils virtuels Android existants, puis cliquer surStart pour le lancer.
Modification de l'application HelloXamarin
Dans cette section, nous modifierons notre projet et créerons un bouton qui affichera du texte au clic. Ouvertmain.axml et passer à source view. Après notretextview que nous avons créé, nous ajouterons un bouton comme indiqué ci-dessous.
<Button
android:id = "@+id/MyButton"
android:layout_width = "fill_parent"
android:layout_height = "wrap_content"
android:text = "@string/ButtonClick" />
Après avoir ajouté un bouton, notre code complet ressemblera à ceci -
<?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:layout_height = "fill_parent">
<TextView
android:text = "@string/HelloXamarin"
android:textAppearance = "?android:attr/textAppearanceLarge"
android:layout_width = "match_parent"
android:layout_height = "wrap_content"
android:id = "@+id/textView2" />
<Button
android:id = "@+id/MyButton"
android:layout_width = "fill_parent"
android:layout_height = "wrap_content"
android:text = "@string/ButtonClick" />
</LinearLayout>
Ensuite, nous enregistrons nos valeurs de bouton dans le strings.xml fichier.
<string name = "ButtonClick">Click Me!</string>
Après avoir ajouté notre bouton dans le strings.xml fichier, nous allons ouvrir MainActivity.cs fichier pour ajouter une action à notre bouton lorsque l'utilisateur clique dessus, comme indiqué dans le code suivant.
using System;
using Android.App;
using Android.Content;
using Android.Runtime;
using Android.Views;
using Android.Widget;
using Android.OS;
namespace HelloXamarin {
[Activity(Label = "HelloXamarin", MainLauncher = true, Icon = "@drawable/icon")]
public class MainActivity : Activity {
protected override void OnCreate(Bundle bundle) {
base.OnCreate(bundle);
SetContentView(Resource.Layout.Main);
Button button = FindViewById<Button>(Resource.Id.MyButton);
button.Click += delegate { button.Text = "Hello world I am your first App"; };
}
}
}
Ensuite, créez et exécutez votre application.
Après avoir cliqué sur le bouton, vous obtiendrez la sortie suivante -
Toutes les applications Android ont un manifest file communément appelé AndroidManifest.xml. Le fichier manifeste contient tout ce qui concerne la plate-forme Android dont une application a besoin pour fonctionner correctement.
Ici, nous avons répertorié certaines des fonctions importantes d'un fichier manifeste -
Il déclare le minimum API level requis par l'application.
Il déclare les autorisations requises par l'application, par exemple, caméra, emplacement, etc.
Il donne des autorisations aux fonctionnalités matérielles et logicielles utilisées ou requises par l'application.
Il répertorie les bibliothèques auxquelles l'application doit être liée.
La capture d'écran suivante montre un fichier Manifest.
Application name - Il fait référence au titre de votre application
Package name - C'est un nom unique utilisé pour identifier votre application.
Application Icon - C'est l'icône affichée sur l'écran d'accueil Android de votre application.
Version Number - Il s'agit d'un numéro unique utilisé pour indiquer qu'une version de votre application est plus récente qu'une autre.
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
android:versionCode="1" >
Version Name- Il s'agit d'une chaîne de version conviviale pour votre application que les utilisateurs verront dans les paramètres de votre application et sur Google PlayStore. Le code suivant montre un exemple de nom de version.
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
android:versionName="1.0.0">
Minimum Android Version - C'est la plate-forme de la version Android la plus basse prise en charge par votre application.
<uses-sdk android:minSdkVersion="16" />
Dans l'exemple ci-dessus, notre version minimale d'Android est le niveau d'API 16, communément appelé JELLY BEAN.
Target Android Version - Il s'agit de la version Android sur laquelle votre application est compilée.
Lorsqu'un nouveau projet Android est créé, certains fichiers sont ajoutés par défaut au projet. Nous appelons ces fichiers et dossiers de projet par défaut commeAndroid Resources. Jetez un œil à la capture d'écran suivante.
Les ressources Android par défaut incluent les éléments suivants:
AndroidManifest.xml file - Il contient des informations sur vos applications Android, par exemple le nom de l'application, les autorisations, etc.
Resources folder - Les ressources peuvent être des images, des mises en page, des chaînes, etc. qui peuvent être chargées via le système de ressources d'Android.
Resources/drawable folder - Il stocke toutes les images que vous allez utiliser dans votre application.
Resources/layout folder - Il contient tous les fichiers XML Android (.axml) qu'Android utilise pour créer des interfaces utilisateur.
The Resources/values folder- Il contient des fichiers XML pour déclarer des paires clé-valeur pour des chaînes (et d'autres types) dans une application. C'est ainsi que la localisation pour plusieurs langues est normalement configurée sur Android.
Resources.designer.cs - Ce fichier est créé automatiquement lors de la création du projet Android et contient des identifiants uniques qui référencent les ressources Android.
MainActivity.cs file - Il s'agit de la première activité de votre application Android et d'où les principales actions de l'application sont lancées.
Les fichiers de ressources sont accessibles par programme via un unique ID qui est stocké dans le resources.designer.csfichier. L'ID est contenu dans une classe appeléeResource. Toute ressource ajoutée au projet est automatiquement générée dans leresource class.
Le code suivant montre comment créer un projet gridview contenant sept images -
namespace HelloGridView {
[System.CodeDom.Compiler.GeneratedCodeAttribute
("Xamarin.Android.Build.Tas ks",
"1.0.0.0")]
public partial class Resource {
static Resource() {
global::Android.Runtime.ResourceIdManager.UpdateIdValues();
}
public static void UpdateIdValues() {}
public partial class Attribute {
static Attribute() {
global::Android.Runtime.ResourceIdManager.UpdateIdValues();
}
private Attribute() {}
}
public partial class Drawable {
// aapt resource value: 0x7f020000
public const int Icon = 2130837504;
// aapt resource value: 0x7f020001
public const int img1 = 2130837505;
// aapt resource value: 0x7f020002
public const int img2 = 2130837506;
// aapt resource value: 0x7f020003
public const int img3 = 2130837507;
// aapt resource value: 0x7f020004
public const int img4 = 2130837508;
// aapt resource value: 0x7f020005
public const int img5 = 2130837509;
// aapt resource value: 0x7f020006
public const int img6 = 2130837510;
// aapt resource value: 0x7f020007
public const int img7 = 2130837511;
static Drawable() {
global::Android.Runtime.ResourceIdManager.UpdateIdValues();
}
private Drawable() {}
}
public partial class Id {
// aapt resource value: 0x7f050000
public const int gridview = 2131034112;
static Id() {
global::Android.Runtime.ResourceIdManager.UpdateIdValues();
}
private Id() {}
}
public partial class Layout {
// aapt resource value: 0x7f030000
public const int Main = 2130903040;
static Layout() {
global::Android.Runtime.ResourceIdManager.UpdateIdValues();
}
private Layout() {}
}
public partial class String {
// aapt resource value: 0x7f040001
public const int ApplicationName = 2130968577;
// aapt resource value: 0x7f040000
public const int Hello = 2130968576;
static String() {
global::Android.Runtime.ResourceIdManager.UpdateIdValues();
}
private String() {}
}
}
}
À partir du code ci-dessus, les sept images sont référencées dans une classe appelée drawable. Ces images sont ajoutées par programme. Si un utilisateur ajoute une autre image au projet, elle sera également ajoutée audrawableclasse. legridviewcontenu dans le projet est également ajouté et stocké dans une classe seule. Chaque élément contenu dans leresources folder est automatiquement généré et stocké dans une classe.
Lorsqu'un utilisateur navigue dans une application Android, une série d'événements se produit. Par exemple, lorsqu'un utilisateur lance une application, par exemple l'application Facebook, elle démarre et devient visible au premier plan pour l'utilisateur,onCreate() → onStart() → onResume().
Si une autre activité commence, par exemple, un appel téléphonique arrive, l'application Facebook passera en arrière-plan et l'appel passera au premier plan. Nous avons maintenant deux processus en cours d'exécution.
onPause() --- > onStop()
Lorsque l'appel téléphonique se termine, l'application Facebook revient au premier plan. Trois méthodes sont appelées.
onRestart() --- > onStart() --- > onResume()
Il existe 7 processus de cycle de vie dans une activité Android. Ils comprennent -
onCreate - Il est appelé lors de la création de l'activité.
onStart - Il est appelé au démarrage de l'activité et devient visible par l'utilisateur.
onResume- Il est appelé lorsque l'activité commence à interagir avec l'utilisateur. L'entrée utilisateur a lieu à ce stade.
onPause - Il est appelé lorsque l'activité s'exécute en arrière-plan mais n'a pas encore été supprimée.
onStop - Il est appelé lorsque l'activité n'est plus visible par l'utilisateur.
onRestart- Il est appelé après l'arrêt de l'activité, avant de recommencer. Il est normalement appelé lorsqu'un utilisateur revient à une activité précédente qui avait été arrêtée.
onDestroy - Il s'agit du dernier appel avant que l'activité ne soit supprimée de la mémoire.
L'illustration suivante montre le cycle de vie de l'activité Android -
Sous Android, par défaut, aucune application n'est autorisée à effectuer des opérations qui auraient un effet sur l'utilisateur ou le système d'exploitation. Pour qu'une application exécute une tâche, elle doit déclarer les autorisations. L'application ne peut pas exécuter la tâche tant que l'autorisation n'est pas accordée par le système Android. Ce mécanisme d'autorisations empêche les applications de faire ce qu'elles souhaitent sans le consentement de l'utilisateur.
Les autorisations doivent être enregistrées dans AndroidManifest.xmlfichier. Pour ajouter des autorisations, nous double-cliquons sur les propriétés, puis allons dans Android ManRequired permissionsapparaîtra. Cochez les autorisations appropriées que vous souhaitez ajouter.
Camera - Il donne la permission d'accéder à la caméra de l'appareil.
<uses-permission android:name="android.permission.CAMERA" />
Internet - Il donne accès aux ressources du réseau.
<uses-permission android:name="android.permission.INTERNET" />
ReadContacts - Il permet d'accéder à la lecture des contacts sur votre appareil.
<uses-permission android:name="android.permission.READ_CONTACTS" />
ReadExternalStorage - Il permet d'accéder à la lecture et au stockage des données sur un stockage externe.
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
Calendars- Il permet à une application d'accéder au calendrier sur l'appareil de l'utilisateur et aux événements. Cette autorisation peut être dangereuse, car elle donne à une application la possibilité d'envoyer des e-mails aux invités à l'insu du propriétaire. La syntaxe pour ajouter cette autorisation est la suivante:
<uses-permission android:name="android.permission-group.CALENADAR" />
SMS- Une application avec cette autorisation a la possibilité d'utiliser les services de messagerie des appareils. Il comprend la lecture, l'écriture et l'édition de messages SMS et MMS. Sa syntaxe est la suivante.
<uses-permission android:name="android.permission-group.SMS" />
Location - Une application disposant de cette autorisation peut accéder à l'emplacement de l'appareil à l'aide du réseau GPS.
<uses-permission android:name="android.permission-group.LOCATION" />
Bluetooth - Une application disposant de cette autorisation peut échanger des fichiers de données avec d'autres appareils compatibles Bluetooth sans fil.
<uses-permission android:name="android.permission.BLUETOOTH" />
Affichage
TextView est un composant très important des widgets Android. Il est principalement utilisé pour afficher des textes sur un écran Android.
Pour créer une vue de texte, ouvrez simplement main.axml et ajoutez le code suivant entre les balises de disposition linéaire.
<TextView
android:text = "Hello I am a text View"
android:layout_width = "match_parent"
android:layout_height = "wrap_content"
android:id = "@+id/textview1" />
Bouton
Un bouton est un contrôle utilisé pour déclencher un événement lorsque l'utilisateur clique dessus. Sous votreMain.axml fichier, tapez le code suivant pour créer un bouton.
<Button
android:id = "@+id/MyButton"
android:layout_width = "fill_parent"
android:layout_height = "wrap_content"
android:text = "@string/Hello" />
Ouvert Resources\Values\Strings.xml et tapez la ligne de code suivante entre la balise <resources>.
<string name="Hello">Click Me!</string>
Le code ci-dessus fournit la valeur du bouton que nous avons créé. Ensuite, nous ouvronsMainActivity.cset créez l'action à exécuter lorsque le bouton est cliqué. Tapez le code suivant sousbase.OnCreate (bundle) méthode.
Button button = FindViewById<Button>(Resource.Id.MyButton);
button.Click += delegate { button.Text = "You clicked me"; };
Le code ci-dessus affiche «Vous m'avez cliqué» lorsqu'un utilisateur clique sur le bouton.
FindViewById<< -->Cette méthode recherche l'ID d'une vue qui a été identifiée. Il recherche l'ID dans le fichier de mise en page .axml.
Case à cocher
Une case à cocher est utilisée lorsque l'on veut sélectionner plus d'une option dans un groupe d'options. Dans cet exemple, nous allons créer une case à cocher qui, lorsqu'elle est sélectionnée, affiche un message indiquant qu'elle a été cochée, sinon elle s'affiche non cochée.
Pour commencer, nous ouvrons Main.axml fichier dans notre projet et tapez la ligne de code suivante pour créer une case à cocher.
<?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>
Ensuite, allez à MainActivity.cs pour ajouter le code de fonctionnalité.
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";
}
};
À partir du code ci-dessus, nous trouvons d'abord la case à cocher en utilisant findViewById. Ensuite, nous créons une méthode de gestionnaire pour notre case à cocher et dans notre gestionnaire, nous créons une instruction if else qui affiche un message en fonction du résultat sélectionné.
CompoundButton.CheckedChangeEventArgs → Cette méthode déclenche un événement lorsque l'état de la case à cocher change.
Barre de progression
Une barre de progression est un contrôle utilisé pour afficher la progression d'une opération. Pour ajouter une barre de progression, ajoutez la ligne de code suivante dansMain.axml fichier.
<ProgressBar
style="?android:attr/progressBarStyleHorizontal"
android:layout_width = "match_parent"
android:layout_height = "wrap_content"
android:id = "@+id/progressBar1" />
Ensuite, allez à MainActivity.cs et définissez la valeur de la barre de progression.
ProgressBar pb = FindViewById<ProgressBar>(Resource.Id.progressBar1);
pb.Progress = 35;
Dans le code ci-dessus, nous avons créé une barre de progression avec une valeur de 35.
Boutons radio
Il s'agit d'un widget Android qui permet à une personne d'en choisir un parmi un ensemble d'options. Dans cette section, nous allons créer un groupe radio contenant une liste de voitures qui récupérera un bouton radio coché.
Tout d'abord, nous ajoutons un groupe radio et un textview comme indiqué dans le code suivant -
<?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>
Pour effectuer une action, lorsqu'un bouton radio est cliqué, nous ajoutons une activité. Aller àMainActivity.cs et créez un nouveau gestionnaire d'événements comme indiqué ci-dessous.
private void onClickRadioButton(object sender, EventArgs e) {
RadioButton cars = (RadioButton)sender;
Toast.MakeText(this, cars.Text, ToastLength.Short).Show
();
}
Toast.MakeText() →Il s'agit d'une méthode d'affichage utilisée pour afficher un message / une sortie dans une petite fenêtre contextuelle. Au bas de laOnCreate() méthode juste après SetContentView(), ajoutez le morceau de code suivant. Cela capturera chacun des boutons radio et les ajoutera au gestionnaire d'événements que nous avons créé.
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;
Maintenant, exécutez votre application. Il devrait afficher l'écran suivant comme sortie -
Boutons à bascule
Les boutons à bascule sont utilisés pour alterner entre deux états, par exemple, il peut basculer entre ON et OFF. OuvertResources\layout\Main.axml et ajoutez les lignes de code suivantes pour créer un bouton bascule.
<?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>
Nous pouvons ajouter des actions à la barre de bascule lorsque vous cliquez dessus. OuvertMainActivity.cs et ajoutez les lignes de code suivantes après le OnCreate() classe de méthode.
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();
};
Maintenant, lorsque vous exécutez l'application, elle devrait afficher la sortie suivante -
Barre des notes
Une barre de notation est un élément de formulaire composé d'étoiles que les utilisateurs de l'application peuvent utiliser pour évaluer les éléments que vous leur avez fournis. Dans tonMain.axml fichier, créez une nouvelle barre de notation avec 5 étoiles.
<?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>
Lors de l'exécution de l'application, elle devrait afficher la sortie suivante -
Affichage de texte à saisie semi-automatique
Ceci est une vue de texte qui montre des suggestions complètes pendant qu'un utilisateur tape. Nous allons créer une vue de texte à saisie semi-automatique contenant une liste de noms de personnes et un bouton qui, en cliquant, nous montrera le nom sélectionné.
Ouvert Main.axml et écrivez le code suivant.
<?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>
Le code ci-dessus génère un TextView pour la saisie, AutoCompleteTextViewpour afficher les suggestions et un bouton pour afficher les noms saisis à partir de TextView. Aller àMainActivity.cs pour ajouter la fonctionnalité.
Créez une nouvelle méthode de gestionnaire d'événements comme indiqué ci-dessous.
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();
}
}
Le gestionnaire créé vérifie si la vue de texte à saisie semi-automatique est vide. S'il n'est pas vide, il affiche le texte de saisie semi-automatique sélectionné. Tapez le code suivant dans leOnCreate() classe.
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 - Il s'agit d'un gestionnaire de collection qui lit les éléments de données d'une collection de listes et les renvoie sous forme de vue ou les affiche à l'écran.
Désormais, lorsque vous exécutez l'application, elle doit afficher la sortie suivante.
Menus contextuels
Un menu contextuel fait référence à un menu associé à une vue; il est également appeléshortcut menu. Voyons comment ajouter un menu contextuel à une application Android.
Créez un nouveau projet et appelez-le popUpMenu App. OuvertMain.axml et créez un bouton qui servira à afficher le menu contextuel.
<?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">
<Button
android:id = "@+id/popupButton"
android:layout_width = "fill_parent"
android:layout_height = "wrap_content"
android:text = "Show popup menu"
android:background = "@android:color/holo_green_dark"
android:textColor = "@android:color/black" />
</LinearLayout>
Créez un nouveau dossier sous le Resources dossier et appelez-le Menu. Dans le dossier Menu, ajoutez un nouveau fichier xml appelépopMenu.xml.
En dessous de popMenu.xml, ajoutez les éléments de menu suivants.
<?xml version = "1.0" encoding="utf-8"?>
<menu xmlns:android = "http://schemas.android.com/apk/res/android">
<item
android:id = "@+id/file_settings"
android:icon = "@drawable/img_settings"
android:title = "Settings"
android:showAsAction = "ifRoom">
<item
android:id = "@+id/new_game1"
android:icon = "@drawable/imgNew"
android:title = "New File Settings"/>
<item
android:id = "@+id/help"
android:icon = "@drawable/img_help"
android:title = "Help" />
<item
android:id = "@+id/about_app"
android:icon = "@drawable/img_help"
android:title = "About app"/>
</item>
</menu>
Après avoir ajouté les éléments de menu, accédez à mainActivity.cs pour afficher le menu contextuel en cliquant sur le bouton.
protected override void OnCreate(Bundle bundle) {
base.OnCreate(bundle);
SetContentView(Resource.Layout.Main);
Button showPopupMenu = FindViewById<Button>(Resource.Id.popupButton);
showPopupMenu.Click += (s, arg) => {
PopupMenu menu = new PopupMenu(this, showPopupMenu);
menu.Inflate(Resource.Menu.popMenu);
menu.Show();
};
}
Maintenant, créez et exécutez votre application. Il devrait produire la sortie suivante -
Menu d'options
Le menu Options est une collection de menus qui sont principaux pour une application et sont principalement utilisés pour stocker les paramètres, la recherche, etc. Ici, nous allons créer un menu pour les paramètres avec trois éléments à l'intérieur, à savoir, New File Settings, Help, and About App.
Pour créer un menu d'options, nous devons créer un nouveau fichier de mise en page XML dans le dossier des ressources. Tout d'abord, nous allons ajouter un nouveau fichier XML. Faites un clic droit sur leLayout folder, ensuite aller à Add → New item → Visual C# → XML File.
Choisissez un nom approprié pour le layout file. Dans notre exemple, nous appellerons notre fichiermyMenu.xml.
À l'intérieur myMenu.xml, nous allons créer un nouveau menu et ajouter des éléments à l'intérieur. Le code suivant montre comment procéder.
<?xml version = "1.0" encoding = "utf-8"?>
<menu xmlns:android = "http://schemas.android.com/apk/res/android">
<item
android:id = "@+id/file_settings"
android:icon = "@drawable/img_settings"
android:title = "Settings"
android:showAsAction = "ifRoom">
<menu>
<item
android:id = "@+id/new_game1"
android:icon = "@drawable/imgNew"
android:title = "New File Settings" />
<item
android:id = "@+id/help"
android:icon = "@drawable/img_help"
android:title = "Help" />
<item
android:id = "@+id/about_app"
android:icon = "@drawable/img_help"
android:title = "About app"/>
</menu>
</item>
</menu>
Ensuite, nous naviguons vers MainActivity.cs et créez une classe de remplacement pour onOptionsMenu().
public override bool OnCreateOptionsMenu(IMenu menu) {
MenuInflater.Inflate(Resource.Menu.myMenu, menu);
return base.OnPrepareOptionsMenu(menu);
}
Ensuite, nous créons une action pour répondre au settings menulorsqu'il est sélectionné. Pour ce faire, nous créons une autre classe de remplacement pour leOnOptionsItemSelected() menu.
public override bool OnOptionsItemSelected(IMenuItem item) {
if (item.ItemId == Resource.Id.file_settings) {
// do something here...
return true;
}
return base.OnOptionsItemSelected(item);
}
Notre code complet final ressemblera à ceci -
namespace optionsMenuApp {
[Activity(Label = "options Menu", MainLauncher = true, Icon = "@drawable/icon")]
public class MainActivity : Activity {
public override bool OnCreateOptionsMenu(IMenu menu) {
MenuInflater.Inflate(Resource.Menu.myMenu, menu);
return base.OnPrepareOptionsMenu(menu);
}
public override bool OnOptionsItemSelected(IMenuItem item) {
if (item.ItemId == Resource.Id.file_settings) {
// do something here...
return true;
}
return base.OnOptionsItemSelected(item);
}
}
}
Maintenant, créez et exécutez votre application. Il devrait produire la sortie suivante -
Disposition linéaire
Dans une mise en page linéaire, le contenu est disposé de manière horizontale ou verticale.
Disposition linéaire ─ Horizontal
Le contenu de cette mise en page est organisé horizontalement. Pour cette démo, nous allons créer 3 boutons et les disposer horizontalement dans une disposition linéaire.
<?xml version = "1.0" encoding = "utf-8"?>
<LinearLayout xmlns:android = "http://schemas.android.com/apk/res/android"
android:orientation = "horizontal"
android:layout_width = "fill_parent"
android:layout_height = "fill_parent"
android:background = "#d3d3d3"
android:minWidth="25px"
android:minHeight="25px">
<Button
android:id="@+id/MyButton1"
android:layout_width="wrap_content"
android:layout_margin="10dp"
android:layout_height="wrap_content"
android:text="Button 1"
android:background="@android:color/holo_green_dark" />
<Button
android:id="@+id/MyButton2"
android:layout_width="wrap_content"
android:layout_margin="10dp"
android:layout_height="wrap_content"
android:text="Button 2"
android:background="@android:color/holo_green_dark" />
<Button
android:id="@+id/MyButton3"
android:layout_width="wrap_content"
android:layout_margin="10dp"
android:layout_height="wrap_content"
android:text="Button 3"
android:background="@android:color/holo_green_dark" />
</LinearLayout>
La sortie résultante est comme indiqué ci-dessous -
Disposition linéaire ─ verticale
Ce type de disposition place la vue enfant de manière verticale.
<?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:layout_height = "fill_parent"
android:background = "#d3d3d3"
android:minWidth = "25px"
android:minHeight = "25px">
<Button
android:id = "@+id/MyButton1"
android:layout_width = "fill_parent"
android:layout_margin = "10dp"
android:layout_height = "wrap_content"
android:text = "Button 1"
android:background = "@android:color/holo_green_dark" />
<Button
android:id = "@+id/MyButton2"
android:layout_width = "fill_parent"
android:layout_margin = "10dp"
android:layout_height = "wrap_content"
android:text = "Button 2"
android:background = "@android:color/holo_green_dark" />
<Button
android:id = "@+id/MyButton3"
android:layout_width = "fill_parent"
android:layout_margin = "10dp"
android:layout_height = "wrap_content"
android:text="Button 3"
android:background = "@android:color/holo_green_dark" />
</LinearLayout>
Sa sortie résultante est la suivante -
Disposition relative
Dans cette vue, la position de la vue enfant est relative à son parent ou à sa vue sœur. Dans l'exemple suivant, nous allons créer 3 vues EditText et un bouton, puis les aligner de manière relative.
Créez un nouveau projet et appelez-le relative layout app. Ouvertmain.axml et ajoutez le code suivant.
<?xml version = "1.0" encoding = "utf-8"?>
<RelativeLayout xmlns:android = "http://schemas.android.com/apk/res/android"
android:layout_width = "match_parent"
android:layout_height = "match_parent"
android:paddingLeft = "16dp"
android:background = "#d3d3d3"
android:paddingRight = "16dp">
<EditText
android:id = "@+id/name"
android:layout_width = "match_parent"
android:layout_height = "wrap_content"
android:hint = "First Name"
android:textColorHint = "@android:color/background_dark"
android:textColor = "@android:color/background_dark" />
<EditText
android:id = "@+id/lastName"
android:layout_width = "0dp"
android:layout_height = "wrap_content"
android:hint = "Last Name"
android:layout_below = "@id/name"
android:textColorHint = "@android:color/background_dark"
android:textColor = "@android:color/background_dark"
android:layout_alignParentLeft = "true"
android:layout_toLeftOf = "@+id/age" />
<EditText
android:id = "@id/age"
android:layout_width = "80dp"
android:layout_height = "wrap_content"
android:layout_below = "@id/name"
android:hint = "Age"
android:textColorHint = "@android:color/background_dark"
android:textColor = "@android:color/background_dark"
android:layout_alignParentRight = "true" />
<Button
android:layout_width = "85dp"
android:layout_height = "wrap_content"
android:layout_below = "@id/age"
android:layout_alignParentRight = "true"
android:text = "Submit"
android:background = "@android:color/holo_green_dark" />
</RelativeLayout>
Les paramètres importants que nous avons utilisés dans ce code sont -
android:layout_below - Il aligne l'élément de vue enfant sous son parent.
android:layout_alignParentLeft - Il aligne l'élément parent vers la gauche.
android:layout_toLeftOf - Cette propriété aligne un élément à gauche d'un autre élément.
android:layout_alignParentRight - Il aligne le parent vers la droite.
Lorsque vous construisez et exécutez l'application maintenant, cela produirait l'écran de sortie suivant -
Disposition du cadre
La disposition du cadre est utilisée pour afficher un seul élément. Il est difficile d'organiser plusieurs éléments dans cette mise en page sans qu'ils se chevauchent.
Démarrez un nouveau projet et appelez-le frameLayoutApp. Créez une nouvelle disposition de cadre comme indiqué ci-dessous.
<?xml version = "1.0" encoding = "utf-8"?>
<FrameLayout xmlns:android = "http://schemas.android.com/apk/res/android"
android:layout_width = "fill_parent"
android:layout_height = "fill_parent">
<ImageView
android:id = "@+id/ImageView1"
android:scaleType = "matrix"
android:layout_height = "fill_parent"
android:layout_width = "fill_parent"
android:src = "@drawable/img1" />
<TextView
android:layout_width = "fill_parent"
android:layout_height = "wrap_content"
android:textSize = "50dp"
android:textColor = "#000"
android:text = "This is a Lake" />
<TextView
android:gravity = "right"
android:layout_width = "fill_parent"
android:layout_height = "wrap_content"
android:textSize = "50dp"
android:text = "A very Deep Lake"
android:layout_gravity = "bottom"
android:textColor = "#fff" />
</FrameLayout>
Le code ci-dessus crée un imageViewqui remplit tout l'écran. Deux vues de texte flottent alors au-dessus duimageView.
Maintenant, créez et exécutez votre application. Il affichera la sortie suivante -
Disposition de la table
Dans cette disposition, la vue est organisée en rows et columns. Voyons voir comment ça fonctionne.
<?xml version = "1.0" encoding = "utf-8"?>
<TableLayout xmlns:android = "http://schemas.android.com/apk/res/android"
android:layout_width = "fill_parent"
android:background = "#d3d3d3"
android:layout_height = "fill_parent"
android:stretchColumns = "1">
<TableRow>
<TextView
android:text = "First Name:"
android:layout_width = "wrap_content"
android:layout_height = "wrap_content"
android:textColor = "@android:color/black" />
<EditText
android:width = "100px"
android:layout_width = "fill_parent"
android:layout_height = "30dp"
android:textColor = "@android:color/black" />
</TableRow>
<TableRow>
<TextView
android:text = "Last Name:"
android:layout_width = "wrap_content"
android:layout_height = "wrap_content"
android:textColor = "@android:color/black" />
<EditText
android:width = "50px"
android:layout_width = "fill_parent"
android:layout_height = "30dp"
android:textColor = "@android:color/black" />
</TableRow>
<TableRow>
<TextView
android:text = "Residence:"
android:layout_width = "wrap_content"
android:layout_height = "wrap_content"
android:textColor = "@android:color/black" />
<EditText
android:width = "100px"
android:layout_width = "fill_parent"
android:layout_height = "30dp"
android:textColor = "@android:color/black" />
</TableRow>
<TableRow>
<TextView
android:text = "Occupation:"
android:layout_width = "wrap_content"
android:layout_height = "wrap_content"
android:textColor = "@android:color/black" />
<EditText
android:width = "100px"
android:layout_width = "fill_parent"
android:layout_height = "30dp"
android:textColor = "@android:color/black" />
</TableRow>
<TableRow>
<Button
android:text = "Cancel"
android:layout_width = "wrap_content"
android:layout_margin = "10dp"
android:layout_height = "wrap_content"
android:background = "@android:color/holo_green_dark" />
<Button
android:text = "Submit"
android:width = "100px"
android:layout_margin = "10dp"
android:layout_width = "wrap_content"
android:layout_height = "wrap_content"
android:background = "@android:color/holo_green_dark" />
</TableRow>
</TableLayout>
Le code ci-dessus crée un formulaire de saisie de données simple organisé en utilisant tables et rows.
Sélecteur de date
Ceci est un widget utilisé pour afficher la date. Dans cet exemple, nous allons créer un sélecteur de date qui affiche la date définie sur une vue texte.
Tout d'abord, créez un nouveau projet et appelez-le datePickerExample. OuvertMain.axml et créez un datepicker, textview, et un button.
<?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:layout_height = "fill_parent">
<DatePicker
android:layout_width = "match_parent"
android:layout_height = "wrap_content"
android:id = "@+id/datePicker1" />
<TextView
android:text = "Current Date"
android:textAppearance = "?android:attr/textAppearanceLarge"
android:layout_width = "match_parent"
android:layout_height = "wrap_content"
android:id = "@+id/txtShowDate" />
<Button
android:text = "Select Date"
android:layout_width = "match_parent"
android:layout_height = "wrap_content"
android:id = "@+id/btnSetDate" />
</LinearLayout>
Ensuite, allez à Mainactivity.cs. Nous créons d'abord une instance privée d'une vue de texte dans lemainActivity:Activity classe.
L'instance sera utilisée pour stocker la date sélectionnée ou la date par défaut.
private TextView showCurrentDate;
Ensuite, ajoutez le code suivant après setContentView() méthode.
DatePicker pickDate = FindViewById<DatePicker>(Resource.Id.datePicker1);
showCurrentDate = FindViewById<TextView>(Resource.Id.txtShowDate);
setCurrentDate();
Button button = FindViewById<Button>(Resource.Id.btnSetDate);
button.Click += delegate {
showCurrentDate.Text = String.Format("{0}/{1}/{2}",
pickDate.Month, pickDate.DayOfMonth, pickDate.Year);
};
Dans le code ci-dessus, nous avons référencé notre sélecteur de date, notre vue de texte et notre bouton en les trouvant à partir de notre main.axml fichier utilisant FindViewById classe.
Après le référencement, nous définissons l'événement de clic sur le bouton qui est responsable du passage de la date sélectionnée du sélecteur de date à la vue de texte.
Ensuite, nous créons le setCurrentDate()méthode pour afficher la date actuelle par défaut dans notre vue de texte. Le code suivant explique comment procéder.
private void setCurrentDate() {
string TodaysDate = string.Format("{0}",
DateTime.Now.ToString("M/d/yyyy").PadLeft(2, '0'));
showCurrentDate.Text = TodaysDate;
}
DateTime.Now.ToString() class lie l'heure d'aujourd'hui à un objet chaîne.
Maintenant, créez et exécutez l'application. Il devrait afficher la sortie suivante -
Sélecteur de temps
Time Picker est un widget utilisé pour afficher l'heure ainsi que pour permettre à un utilisateur de choisir et de définir l'heure. Nous allons créer une application de sélection de l'heure de base qui affiche l'heure et permet également à un utilisateur de modifier l'heure.
Aller à main.axml et ajoutez un nouveau bouton, une vue de texte et un sélecteur de temps, comme indiqué dans le code suivant.
<?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">
<TimePicker
android:layout_width = "match_parent"
android:layout_height = "wrap_content"
android:id = "@+id/timePicker1" />
<TextView
android:text = "Time"
android:textAppearance = "?android:attr/textAppearanceLarge"
android:layout_width = "match_parent"
android:layout_height = "wrap_content"
android:id = "@+id/txt_showTime"
android:textColor = "@android:color/black" />
<Button
android:text = "Set Time"
android:layout_width = "200dp"
android:layout_height = "wrap_content"
android:id = "@+id/btnSetTime"
android:textColor = "@android:color/black"
android:background = "@android:color/holo_green_dark" />
</LinearLayout>
Aller à MainActivity.cs pour ajouter la fonctionnalité d'affichage d'une date fixe sur la vue de texte que nous avons créée.
public class MainActivity : Activity {
private TextView showCurrentTime;
protected override void OnCreate(Bundle bundle) {
base.OnCreate(bundle);
SetContentView(Resource.Layout.Main);
TimePicker Tpicker = FindViewById<TimePicker>(Resource.Id.timePicker1);
showCurrentTime = FindViewById<TextView>(Resource.Id.txt_showTime);
setCurrentTime();
Button button = FindViewById<Button>(Resource.Id.btnSetTime);
button.Click += delegate {
showCurrentTime.Text = String.Format("{0}:{1}",
Tpicker.CurrentHour, Tpicker.CurrentMinute);
};
}
private void setCurrentTime() {
string time = string.Format("{0}",
DateTime.Now.ToString("HH:mm").PadLeft(2, '0'));
showCurrentTime.Text = time;
}
}
Dans le code ci-dessus, nous avons d'abord référencé le timepicker,set time et la vue de texte pour afficher l'heure à travers le FindViewById<>classe. Nous avons ensuite créé un événement de clic pour le bouton de réglage de l'heure qui, sur clic, règle l'heure sur l'heure sélectionnée par une personne. Par défaut, il affiche l'heure actuelle du système.
le setCurrentTime() la classe de méthode initialise la txt_showTime textview pour afficher l'heure actuelle.
Maintenant, créez et exécutez votre application. Il devrait afficher la sortie suivante -
Fileur
Un spinner est un widget utilisé pour sélectionner une option dans un ensemble. C'est l'équivalent d'une liste déroulante / combo. Tout d'abord, créez un nouveau projet et appelez-leSpinner App Tutorial.
Ouvert Main.axml sous le layout folder et créez un nouveau spinner.
<?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:layout_height = "fill_parent">
<Spinner
android:layout_width = "match_parent"
android:layout_height = "wrap_content"
android:id = "@+id/spinner1"
android:prompt = "@string/daysOfWeek" />
</LinearLayout>
Ouvert Strings.xml fichier situé sous values folder et ajoutez le code suivant pour créer le spinner items.
<resources>
<string name = "daysOfWeek">Choose a planet</string>
<string-array name = "days_array">
<item>Sunday</item>
<item>Monday</item>
<item>Tuesday</item>
<item>Wednesday</item>
<item>Thursday</item>
<item>Friday</item>
<item>Saturday</item>
<item>Sunday</item>
</string-array>
</resources>
Ensuite, ouvrez MainActivity.cs pour ajouter la fonctionnalité d'affichage du jour de la semaine sélectionné.
protected override void OnCreate(Bundle bundle) {
base.OnCreate(bundle);
// Set our view from the "main" layout resource
SetContentView(Resource.Layout.Main);
Spinner spinnerDays = FindViewById<Spinner>(Resource.Id.spinner1);
spinnerDays.ItemSelected += new EventHandler
<AdapterView.ItemSelectedEventArgs>(SelectedDay);
var adapter = ArrayAdapter.CreateFromResource(this,
Resource.Array.days_array, Android.Resource.Layout.SimpleSpinnerItem);
adapter.SetDropDownViewResource(Android.Resource.Layout.SimpleSpinnerDropD ownItem);
spinnerDays.Adapter = adapter;
}
private void SelectedDay(object sender, AdapterView.ItemSelectedEventArgs e) {
Spinner spinner = (Spinner)sender;
string toast = string.Format("The selected
day is {0}", spinner.GetItemAtPosition(e.Position));
Toast.MakeText(this, toast, ToastLength.Long).Show();
}
Maintenant, créez et exécutez l'application. Il devrait afficher la sortie suivante -
Dans le code ci-dessus, nous avons référencé le spinner que nous avons créé dans notre main.axml fichier via le FindViewById<>classe. Nous avons ensuite créé un nouveauarrayAdapter() que nous avons utilisé pour lier nos éléments de tableau à partir du strings.xml classe.
Enfin, nous avons créé la méthode SelectedDay() que nous avons utilisé pour afficher le jour sélectionné de la semaine.
Boîte de dialogue d'alerte
Dans cette section, nous allons créer un bouton qui sur cliqué affiche une boîte de dialogue d'alerte. La boîte de dialogue contient deux boutons, c'est-à-direDelete et Cancel boutons.
Tout d'abord, allez à main.axml et créez un nouveau bouton dans la disposition linéaire comme indiqué dans le code suivant.
<?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">
<Button
android:id="@+id/MyButton"
android:layout_width = "fill_parent"
android:layout_height = "wrap_content"
android:text = "Click to Delete"
android:textColor = "@android:color/background_dark"
android:background = "@android:color/holo_green_dark" />
</LinearLayout>
Ensuite, ouvrez MainActivity.cs pour créer la boîte de dialogue d'alerte et ajouter ses fonctionnalités.
protected override void OnCreate(Bundle bundle) {
base.OnCreate(bundle);
SetContentView(Resource.Layout.Main);
Button button = FindViewById<Button>(Resource.Id.MyButton);
button.Click += delegate {
AlertDialog.Builder alertDiag = new AlertDialog.Builder(this);
alertDiag.SetTitle("Confirm delete");
alertDiag.SetMessage("Once deleted the move cannot be undone");
alertDiag.SetPositiveButton("Delete", (senderAlert, args) => {
Toast.MakeText(this, "Deleted", ToastLength.Short).Show();
});
alertDiag.SetNegativeButton("Cancel", (senderAlert, args) => {
alertDiag.Dispose();
});
Dialog diag = alertDiag.Create();
diag.Show();
};
}
Une fois terminé, créez et exécutez votre application pour afficher le résultat.
Dans le code ci-dessus, nous avons créé une boîte de dialogue d'alerte appelée alertDiag, avec les deux boutons suivants -
setPositiveButton - Il contient le Delete action du bouton qui sur cliqué affiche un message de confirmation Deleted.
setNegativeButton - Il contient un Cancel bouton qui, lorsqu'il est cliqué, ferme simplement la boîte de dialogue d'alerte.
Une galerie est un type d'affichage utilisé pour afficher des éléments dans une liste déroulante horizontale. L'élément sélectionné est alors affiché au centre. Dans cet exemple, vous allez créer une galerie contenant des images qui peuvent défiler horizontalement. Une image lorsque vous cliquez dessus affichera un numéro pour l'image sélectionnée.
Tout d'abord, créez un nouveau projet et donnez-lui un nom, par exemple, Tutoriel de l'application Galerie. Avant de commencer à coder, collez 7 images dans leresource /drawable folder. Aller versmain.axml en dessous de resources folder et une galerie entre les balises de disposition linéaire.
<?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:layout_height="fill_parent"
android:background="#d3d3d3">
<Gallery
android:id="@+id/gallery"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:padding="10dp" />
</LinearLayout>
Créez une nouvelle classe appelée ImageAdapter. Cette classe va être utilisée pour lier les images à la galerie que nous avons créée ci-dessus.
La première étape consiste à ajouter une classe qui contient un contexte cont que nous utilisons pour stocker les champs.
public class ImageAdapter : BaseAdapter {
Context cont;
public ImageAdapter(Context ct) {
cont = ct;
}
}
Ensuite, nous comptons la liste des tableaux qui contient notre image et renvoie sa taille.
public override int Count {
get {
return imageArraylist.Length;
}
}
Dans l'étape suivante, nous obtenons la position de l'élément. Le code suivant montre comment procéder.
public override Java.Lang.Object GetItem(int position) {
return null;
}
public override long GetItemId(int position) {
return 0;
}
Dans l'étape suivante, nous créons un imageview pour les éléments référencés par l'adaptateur.
public override View GetView(int position,View convertView, ViewGroup parent) {
ImageView img = new ImageView(cont);
img.SetImageResource(imageArraylist[position]);
img.SetScaleType(ImageView.ScaleType.FitXy);
img.LayoutParameters = new Gallery.LayoutParams(200, 100);
return img;
}
Dans la dernière étape, nous créons une référence aux images que nous avons ajoutées dans le resources.drawabledossier. Pour ce faire, nous créons un tableau pour contenir la collection d'images. Le code suivant explique comment procéder.
int[] imageArraylist = {
Resource.Drawable.img1,
Resource.Drawable.img2,
Resource.Drawable.img3,
Resource.Drawable.img4,
Resource.Drawable.img5,
Resource.Drawable.img6,
};
}
Ensuite, nous allons à mainActivity.cs et insérez le code suivant sous la méthode OnCreate ().
Gallery myGallery = (Gallery)FindViewById<Gallery>(Resource.Id.gallery);
myGallery.Adapter = new ImageAdapter(this);
myGallery.ItemClick += delegate(object sender, AdapterView.ItemClickEventArgs args) {
Toast.MakeText(this,
args.Position.ToString(), ToastLength.Short).Show();
}
Enfin, créez et exécutez votre application pour afficher la sortie.
ListViews
Un Listview est un élément d'interface utilisateur qui affiche des listes d'éléments qui peuvent être défilés.
Lier des données à des vues de liste
Dans cet exemple, vous allez créer un listView qui affiche les jours de la semaine. Pour commencer, créons un nouveau fichier XML et nommez-lelistViewTemplate.xml.
Dans listViewTemplate.xml, nous ajoutons une nouvelle vue de texte comme indiqué ci-dessous.
<?xml version = "1.0" encoding = "utf-8" ?>
<TextView xmlns:android = "http://schemas.android.com/apk/res/android"
android:id = "@+id/textItem"
android:textSize ="20sp"
android:layout_width = "fill_parent"
android:layout_height = "wrap_content"/>
Ensuite, allez à Main.axml et créez une nouvelle vue de liste dans la disposition linéaire.
<ListView
android:minWidth="25px"
android:minHeight="25px"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:id="@+id/listView1" />
Ouvert MainActivity.cset tapez le code suivant pour lier les données à la liste que nous avons créée. Le code doit être écrit dans leOnCreate() méthode.
SetContentView(Resource.Layout.Main);
var listView = FindViewById<ListView>(Resource.Id.listView1);
var data = new string[] {
"Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday"
};
listView.Adapter = new ArrayAdapter(this, Resource.Layout.ListViewTemplate, data);
Var data = new string[] contient simplement nos articles sous forme de tableau.
L'adaptateur Array renvoie les éléments de notre collection sous forme de vue. Par défaut, l'adaptateur Array utilise un textView par défaut pour afficher chaque élément. Dans le code ci-dessus, nous avons créé notre propre vue de texte dansListViewTemplate.xml et l'a référencé en utilisant le constructeur ci-dessous.
ArrayAdapter(this, Resource.Layout.ListViewTemplate, data);
Enfin, créez et exécutez votre application pour afficher la sortie.
GridViews
Un gridView est un groupe de vues qui permet aux applications de disposer le contenu d'une manière bidimensionnelle, grille défilante.
Pour ajouter un GridView, créez un nouveau projet et appelez-le gridViewApp. Aller àMain.axml et ajoutez une grille comme indiqué ci-dessous.
<?xml version = "1.0" encoding="utf-8"?>
<GridView xmlns:android = "http://schemas.android.com/apk/res/android"
android:id = "@+id/gridview"
android:layout_width = "fill_parent"
android:layout_height = "fill_parent"
android:columnWidth = "90dp"
android:numColumns = "auto_fit"
android:verticalSpacing = "10dp"
android:horizontalSpacing = "10dp"
android:stretchMode = "columnWidth"
android:gravity = "center" />
Ensuite, créez une nouvelle classe et nommez-la ImageAdpter.cs. Cette classe contiendra les classes d'adaptateur pour tous les éléments qui seront affichés dans la grille.
À l'intérieur ImageAdapter, ajoutez le code suivant -
public class ImageAdapter : BaseAdapter {
Context context;
public ImageAdapter(Context ch) {
context = ch;
}
public override int Count {
get {
return cars.Length;
}
}
public override long GetItemId(int position) {
return 0;
}
public override Java.Lang.Object GetItem(int position) {
return null;
}
public override View GetView(int position,
View convertView, ViewGroup parent) {
ImageView imageView;
if (convertView == null) {
imageView = new ImageView(context);
imageView.LayoutParameters = new GridView.LayoutParams(100, 100);
imageView.SetScaleType(ImageView.ScaleType.CenterCrop);
imageView.SetPadding(8, 8, 8, 8);
} else {
imageView = (ImageView)convertView;
}
imageView.SetImageResource(cars[position]);
return imageView;
}
int[] cars = {
Resource.Drawable.img1, Resource.Drawable.img2,
Resource.Drawable.img3, Resource.Drawable.img4,
Resource.Drawable.img5, Resource.Drawable.img6,
};
}
Dans le code ci-dessus, nous avons simplement lié nos images de voiture aux adaptateurs d'image. Ensuite, ouvrezMainActivity.cs et ajoutez le code suivant après setContentView().
var gridview = FindViewById<GridView>(Resource.Id.gridview);
gridview.Adapter = new ImageAdapter(this);
gridview.ItemClick += delegate(object sender,
AdapterView.ItemClickEventArgs args) {
Toast.MakeText(this,
args.Position.ToString(), ToastLength.Short).Show();
};
Le code ci-dessus trouve le gridView dans main.axml et le lie au imageAdapter classe. Gridview.ItemClick crée un onClick événement qui renvoie la position de l'image sélectionnée lorsqu'un utilisateur clique sur une image.
Maintenant, créez et exécutez votre application pour afficher la sortie.
Dans ce chapitre, nous allons créer un système de connexion qui permet à un utilisateur de s'inscrire. Ensuite, nous amènerons l'utilisateur enregistré à l'écran d'accueil de notre application après une connexion réussie.
Tout d'abord, créez un nouveau projet et appelez-le Login System. Sur votre nouveau projet, accédez àmain.axml et ajoutez deux boutons et une barre de progression comme indiqué ci-dessous.
<?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:layout_height = "fill_parent"
android:background = "@android:color/background_light"
android:weightSum = "100"
android:minWidth = "25px"
android:minHeight = "25px">
<TextView
android:text = "Login App"
android:textAppearance = "?android:attr/textAppearanceMedium"
android:layout_width = "match_parent"
android:layout_weight = "20"
android:layout_height = "0dp"
android:textColor = "#368DEB"
android:id = "@+id/txtCreatAccount"
android:gravity = "center"
android:textStyle = "bold"
android:textSize = "25sp" />
<Button
android:text = "Sign In"
android:layout_width = "match_parent"
android:layout_weight = "15"
android:layout_height = "0dp"
android:background = "@drawable/btnSignInStyle"
android:id = "@+id/btnSignIn"
android:layout_marginLeft = "20dp"
android:layout_marginRight = "20dp"
android:textSize = "15sp" />
<Button
android:text = "Sign Up"
android:layout_width = "match_parent"
android:layout_weight = "15"
android:layout_height = "0dp"
android:background = "@drawable/btnSignUpStyle"
android:id = "@+id/btnSignUp"
android:layout_marginLeft = "20dp"
android:layout_marginRight = "20dp"
android:textSize = "15sp" />
<RelativeLayout
android:layout_width = "match_parent"
android:layout_height = "0dp"
android:layout_weight = "50"
android:minWidth = "25px"
android:minHeight = "25px">
<ProgressBar
android:layout_width = "wrap_content"
android:layout_height = "wrap_content"
android:id = "@+id/progressBar1"
android:background = "@drawable/progressBarStyle"
android:layout_centerInParent="true"
android:indeterminate = "true"
xmlns:tools = "
http://schemas.android.com/tools"
tools:visibility = "invisible" />
</RelativeLayout>
</LinearLayout>
Après avoir créé l'interface utilisateur, il est important de styliser les boutons pour les rendre plus attrayants. Pour ce faire, créez un nouveau fichier XML sousdrawable folder et nommez le fichier comme btnSignInStyle.xml.
Dans le fichier XML, ajoutez les lignes de code suivantes -
<selector xmlns:android = "http://schemas.android.com/apk/res/android">
<item android:state_pressed = "false">
<layer-list>
<item android:right = "5dp" android:top = "5dp">
<shape>
<corners android:radius = "2dp"/>
<solid android:color = "#D6D6D6"/>
</shape>
</item>
<item android:left = "2dp" android:bottom = "2dp">
<shape>
<corners android:radius = "4dp"/>
<gradient android:angle = "270"
android:endColor = "#486EA9" android:startColor = "#486EA9"/>
<stroke android:width = "1dp" android:color = "#BABABA"/>
<padding android:bottom = "10dp"
android:right = "10dp" android:left = "10dp" android:top = "10dp"/>
</shape>
</item>
</layer-list>
</item>
<item android:state_pressed = "true">
<layer-list>
<item android:right = "5dp" android:top = "5dp">
<shape>
<corners android:radius = "2dp"/>
<solid android:color = "#D6D6D6"/>
</shape>
</item>
<item android:left = "2dp" android:bottom = "2dp">
<shape>
<corners android:radius = "4dp"/>
<gradient android:angle = "270"
android:endColor = "#79C791" android:startColor = "#486EA9"/>
<stroke android:radius = "4dp" android:color = "#BABABA"/>
<padding android:bottom = "10dp"
android:right = "10dp" android:left = "10dp" android:top = "10dp"/>
</shape>
</item>
</layer-list>
</item>
</selector>
Le code ci-dessus définit les couleurs du bouton au chargement et au clic, il définit également le rayon de la bordure du bouton.
Ensuite, nous créons un style XML similaire à celui ci-dessus pour le signupbouton. Pour ce faire, créez un autre XML sousdrawable dossier et appelez-le btnSignUpStyle.xml. Il héritera de tout debtnSignInStyle.xml. La seule différence sera la couleur de début et de fin du dégradé des boutons.
Changer la startColor et endColor dans btnSignUpStyle.xml à
<gradient android:angle="270"
android:endColor="#008000" android:startColor="#008000"/>
Aller à layout folderet créez un nouveau fichier AXML et appelez-le registerDailog.axml. Ce fichier contiendra les détails d'inscription pour les nouveaux utilisateurs dans notre application. La page contiendra troisEditTextset un bouton pour soumettre les données. Ajoutez le code suivant dans votre code de mise en page linéaire.
<EditText
android:layout_width = "match_parent"
android:layout_marginBottom = "10dp"
android:layout_marginTop = "25dp"
android:layout_marginRight = "25dp"
android:layout_marginLeft = "25dp"
android:layout_height = "35dp"
android:paddingLeft = "10dp"
android:id = "@+id/txtUsername"
android:hint = "Username"
android:textColor = "#000" />
<EditText
android:layout_width = "match_parent"
android:layout_height = "35dp"
android:id = "@+id/txtEmail"
android:layout_marginBottom = "10dp"
android:layout_marginTop = "25dp"
android:layout_marginRight = "25dp"
android:layout_marginLeft = "25dp"
android:paddingLeft = "10dp"
android:textColor = "#000"
android:hint = "Email" />
<EditText
android:layout_width = "match_parent"
android:layout_height = "35dp"
android:layout_marginBottom = "10dp"
android:layout_marginTop = "25dp"
android:layout_marginRight = "25dp"
android:layout_marginLeft = "25dp"
android:paddingLeft = "10dp"
android:textColor = "#000"
android:id = "@+id/txtPassword"
android:hint = "Password" />
<Button
android:text = "Sign Up"
android:layout_width = "match_parent"
android:layout_height = "wrap_content"
android:id = "@+id/btnSave"
android:textSize = "20dp"
android:textColor = "#fff"
android:textStyle = "bold"
android:height = "70dp"
android:background = "@drawable/btnSignUpStyle"
android:paddingLeft = "5dp"
android:paddingRight = "5dp"
android:paddingTop = "5dp"
android:paddingBottom = "5dp"
android:layout_marginLeft = "25dp"
android:layout_marginRight = "25dp"
android:layout_centerHorizontal = "true" />
Ensuite, ajoutez une nouvelle classe appelée signUpDialog.cs. Cette classe contiendra le code requis pour créer une boîte de dialogue. L'exemple suivant montre le code.
public class OnSignUpEvent:EventArgs {
private string myUserName;
private string myEmail;
private string myPassword;
public string UserName {
get {
return myUserName;
}
set{
myUserName = value;
}
}
public string Email {
get {
return myEmail;
}
set {
myEmail = value;
}
}
public string Password {
get {
return myPassword;
}
set {
myPassword = value;
}
}
public OnSignUpEvent(string username, string
email, string password):base() {
UserName = username;
Email = email;
Password = password;
}
class SignUpDialog:DialogFragment {
private EditText txtUsername;
private EditText txtEmail;
private EditText txtPassword;
private Button btnSaveSignUp;
public event EventHandler<OnSignUpEvent> onSignUpComplete;
public override View OnCreateView(LayoutInflater inflater,
ViewGroup container, Bundle savedInstanceState) {
base.OnCreateView(inflater, container, savedInstanceState);
var view = inflater.Inflate(Resource.Layout.registerDialog, container, false);
txtUsername = view.FindViewById<EditText>(Resource.Id.txtUsername);
txtEmail = view.FindViewById<EditText>(Resource.Id.txtEmail);
txtPassword = view.FindViewById<EditText>(Resource.Id.txtPassword);
btnSaveSignUp = view.FindViewById<Button>(Resource.Id.btnSave);
btnSaveSignUp.Click += btnSaveSignUp_Click;
return view;
}
void btnSaveSignUp_Click(object sender, EventArgs e) {
onSignUpComplete.Invoke(this, new OnSignUpEvent(txtUsername.Text,
txtEmail.Text, txtPassword.Text));
this.Dismiss();
}
}
}
Dans le code ci-dessus, nous avons utilisé le get et setPropriétés. leget renvoie une variable, tandis que la setaffecte une valeur à la variable retournée. Voici un exemple -
public string Color {
get {
return color;
}
set {
color = value;
}
}
Dans notre exemple précédent, nous avons créé une méthode qui remplace une vue. À l'intérieur de la méthode, nous avons créé unvar appelé view qui faisait référence à un registerDialog.axml contenu dans le dossier de mise en page.
Ensuite, allez à mainActivity.cs pour créer le fragment de dialogue.
private Button signUp;
private Button submitNewUser;
private EditText txtUsername;
private EditText txtEmail;
private EditText txtPassword;
protected override void OnCreate(Bundle bundle) {
base.OnCreate(bundle);
SetContentView(Resource.Layout.Main);
signUp = FindViewById<Button>(Resource.Id.btnSignUp);
submitNewUser = FindViewById<Button>(Resource.Id.btnSave);
txtUsername = FindViewById<EditText>(Resource.Id.txtUsername);
txtEmail = FindViewById<EditText>(Resource.Id.txtEmail);
txtPassword = FindViewById<EditText>(Resource.Id.txtPassword);
signUp.Click += (object sender, EventArgs args) => {
FragmentTransaction transFrag = FragmentManager.BeginTransaction();
SignUpDialog diagSignUp = new SignUpDialog();
diagSignUp.Show(transFrag, "Fragment Dialog");
diagSignUp.onSignUpComplete += diagSignUp_onSignUpComplete;
};
}
void diagSignUp_onSignUpComplete(object sender, OnSignUpEvent e) {
StartActivity(typeof(Activity2));
}
Le code ci-dessus contient un événement de clic de bouton qui, lorsqu'il est cliqué, charge la boîte de dialogue d'inscription. À l'intérieur du clic du bouton, nous avons créé unSignUpDialog classe qui charge le registerDialog.axml fichier.
Nous avons ensuite utilisé FragmentTransaction transFrag = FragmentManager.BeginTransaction(); pour montrer notre registerDialog page en tant que fragment de dialogue Android.
Nous allons en ajouter un autre .axml fichier appelé home.axml. Cette mise en page sera l'écran de destination une fois qu'un utilisateur se connecte avec succès au système. À l'intérieur de cette mise en page, nous allons ajouter une vue de texte comme indiqué dans le code suivant.
<TextView
android:text = "You have been succesfully registered. Welcome!"
android:textAppearance = "?android:attr/textAppearanceLarge"
android:layout_width = "match_parent"
android:layout_height = "wrap_content"
android:id = "@+id/textView1" />
Ensuite, nous créons une activité finale appelée Activity2.cs. Dans cette activité, nous allons trouver lehome.axml en utilisant findViewById.
Enfin, créez et exécutez votre application. Il affichera les écrans suivants comme sortie.
Une fois le processus de création de votre application terminé, il est important d'utiliser cette application sur un appareil Android physique ou d'autoriser d'autres personnes à télécharger votre application et à l'installer sur leurs appareils.
Libération de votre application
Avant de publier votre application, il est important de la convertir dans un format lisible par un système Android. Ce type de format est appelé unapk file. Pour créer unapk file.
Ouvrez votre projet.
Aller à Build Menu et sélectionnez Configuration Manager
Sur Configuration Manager, définissez Active Solution Configuration pour libérer l'application.
Ensuite, cliquez sur le Build Menu à nouveau et sélectionnez Export Android Package(.apk).
Une fois terminé, le apk le fichier sera stocké dans votre dossier de projet /bin/Release.
Publication de votre application
Il existe 3 façons de publier une application -
Pièce jointe en ligne
Cela implique de télécharger votre apkdéposer en ligne en pièce jointe. Ensuite, les utilisateurs disposant d'appareils Android peuvent télécharger et installer directement votre application sur leurs appareils.
Google PlayStore
PlayStore est le plus grand marché pour les applications Android. Pour télécharger votre application sur le PlayStore, vous devez disposer d'un compte développeur avec Google. Le compte développeur est créé une fois et coûte 25 $ pour obtenir une licence.
Installation manuelle
L'installation manuelle implique l'installation du .apkfichier généré directement sur un périphérique physique. Copiez le fichier dans la mémoire physique de votre appareil Android ou sur une carte SD, puis exécutez le fichier à partir de votre appareil.
Android, par défaut, bloque l'installation des applications qui ne proviennent pas de PlayStore. Pour installer votre application, vous devez l'activer pour accepter l'installation de l'application à partir duSettings. Pour ce faire, allez àSettings sur votre appareil, recherchez Security puis cochez "Autoriser l'installation d'applications à partir de sources inconnues".