iOS - Guide rapide

Aperçu général

iOS, qui s'appelait auparavant iPhone OS, est un système d'exploitation mobile développé par Apple Inc. Sa première version date de 2007, qui comprenait iPhone et iPod Touch. L'iPad (1ère génération) est sorti en avril 2010 et l'iPad Mini est sorti en novembre 2012.

Les appareils iOS évoluent assez fréquemment et par expérience, nous constatons qu'au moins une version d'iPhone et d'iPad est lancée chaque année. Maintenant, nous avons lancé l'iphone5 qui a ses prédécesseurs à partir d'iPhone, iPhone 3gs, iPhone 4, iPhone 4s. De même, l' iPad a évolué à partir d' iPad (1 ère génération) pour iPad (4 e génération) et une version iPad Mini supplémentaire.

Le SDK iOS a évolué de 1.0 à 6.0. iOS 6.0, le dernier SDK est la seule version officiellement prise en charge dans Xcode 4.5 et supérieur. Nous avons une riche documentation Apple et nous pouvons trouver quelles méthodes et bibliothèques peuvent être utilisées en fonction de notre cible de déploiement. Dans la version actuelle de Xcode, nous pourrons choisir entre les cibles de déploiement d'iOS 4.3, 5.0 et 6.0.

La puissance d'iOS peut être ressentie avec certaines des fonctionnalités suivantes fournies dans le cadre de l'appareil.

  • Maps
  • Siri
  • Facebook et Twitter
  • Multi-Touch
  • Accelerometer
  • GPS
  • Processeur haut de gamme
  • Camera
  • Safari
  • API puissantes
  • Centre de jeu
  • Achat dans l'application
  • Reminders
  • Large gamme de gestes

Le nombre d'utilisateurs utilisant iPhone / iPad a beaucoup augmenté. Cela permet aux développeurs de gagner de l'argent en créant des applications pour iPhone et iPad dans l'App Store d'Apple.

Pour certains nouveaux utilisateurs d'iOS, Apple a conçu un magasin d'applications où l'utilisateur peut acheter des applications développées pour ses appareils iOS. Un développeur peut créer des applications gratuites et payantes sur l'App Store. Pour développer des applications et les distribuer au magasin, le développeur devra s'inscrire auprès du programme développeur iOS qui coûte 99 $ par an et un Mac avec Mountain Lion ou plus pour son développement avec le dernier Xcode.

Inscription en tant que développeur Apple

Un identifiant Apple est le plus nécessaire si vous possédez un appareil Apple et que vous êtes développeur, vous en avez certainement besoin. C'est gratuit et donc, aucun problème pour en avoir un. Les avantages d'avoir un compte Apple sont les suivants -

  • Accès aux outils de développement.

  • Vidéos de la Conférence mondiale des développeurs (WWDC).

  • Peut rejoindre les équipes du programme de développement iOS sur invitation.

Pour enregistrer un compte Apple, suivez les étapes ci-dessous -

Step 1 - Cliquez sur le lien https://developer.apple.com/programs/register/ et sélectionnez "Créer un identifiant Apple"

Step 2 - Fournissez les informations nécessaires, qui sont explicites comme indiqué dans la page.

Step 3 - Vérifiez votre compte avec la vérification de votre e-mail et le compte devient actif.

Step 4 - Vous pourrez maintenant télécharger les outils de développement tels que Xcode, qui est fourni avec le simulateur iOS et le SDK iOS, et d'autres ressources de développement.

Programme pour développeurs Apple iOS

La première question qui se poserait à un nouveau développeur est la suivante: pourquoi devrais-je m'inscrire à un programme pour développeurs iOS? La réponse est assez simple; Apple se concentre toujours sur la fourniture d'applications de qualité à son utilisateur. S'il n'y avait pas de frais d'inscription, il pourrait y avoir une possibilité que des applications indésirables soient téléchargées, ce qui pourrait causer des problèmes à l'équipe d'examen des applications d'Apple.

Les avantages de rejoindre le programme pour développeurs iOS sont les suivants:

  • Exécutez les applications que vous développez sur le vrai appareil iOS.

  • Distribuez les applications sur l'App Store.

  • Accédez aux aperçus des développeurs.

Les étapes pour rejoindre le programme pour développeurs iOS sont les suivantes -

Step 1- Pour vous inscrire, cliquez sur le lien - (https://developer.apple.com/programs/ios/).

Step 2 - Cliquez sur S'inscrire maintenant dans la page qui s'affiche.

Step 3 - Vous pouvez soit vous connecter à votre compte Apple existant (si vous en avez un), soit créer un nouvel identifiant Apple.

Step 4- Par la suite, vous devez choisir entre les comptes individuels et d'entreprise. Utilisez le compte d'entreprise s'il y aura plus d'un développeur dans votre équipe. Dans un compte individuel, vous ne pouvez pas ajouter de membres.

Step 5 - Après avoir saisi les informations personnelles (pour ceux qui s'inscrivent nouvellement), vous pouvez acheter et activer le programme en payant à l'aide de votre carte de crédit (mode de paiement accepté uniquement).

Step 6 - Vous aurez maintenant accès aux ressources du développeur en sélectionnant l'option Centre des membres dans la page.

Step 7 - Ici, vous pourrez faire ce qui suit -

  • Créez des profils d'approvisionnement.

  • Gérez votre équipe et vos appareils.

  • Gestion de l'application sur l'App Store via iTunes Connect.

  • Obtenez un forum et une assistance technique.

iOS - Installation de Xcode

Step 1 - Téléchargez la dernière version de Xcode depuis https://developer.apple.com/downloads/

Step 2 - Double-cliquez sur le fichier Xcode dmg.

Step 3 - Vous trouverez un appareil monté et ouvert.

Step 4 - Il y aura deux éléments dans la fenêtre qui s'affiche, à savoir, l'application Xcode et le raccourci du dossier Application.

Step 5 - Faites glisser le Xcode vers l'application et il sera copié dans vos applications.

Step 6 - Désormais, Xcode sera disponible dans le cadre d'autres applications à partir desquelles vous pouvez sélectionner et exécuter.

Vous avez également une autre possibilité de télécharger Xcode à partir du Mac App Store, puis de l'installer en suivant la procédure étape par étape indiquée à l'écran.

Constructeur d'interface

Le constructeur d'interface est l'outil qui permet de créer facilement une interface utilisateur. Vous disposez d'un riche ensemble d'éléments d'interface utilisateur qui sont développés pour être utilisés. Il vous suffit de glisser-déposer dans la vue de votre interface utilisateur. Nous en apprendrons davantage sur l'ajout d'éléments d'interface utilisateur, la création de prises et d'actions pour les éléments d'interface utilisateur dans les pages à venir.

Vous avez une bibliothèque d'objets en bas à droite qui comprend tout l'élément d'interface utilisateur nécessaire. L'interface utilisateur est souvent appeléexibs, qui est son extension de fichier. Chacun des xib est lié à un contrôleur de vue correspondant.

Simulateur iOS

Un simulateur iOS se compose en fait de deux types d'appareils, à savoir l'iPhone et l'iPad avec leurs différentes versions. Les versions iPhone incluent iPhone (normal), iPhone Retina, iPhone 5. iPad a iPad et iPad Retina. Une capture d'écran d'un simulateur iPhone est affichée ci-dessous.

Vous pouvez simuler l'emplacement dans un simulateur iOS pour jouer avec les effets de latitude et de longitude de l'application. Vous pouvez également simuler un avertissement de mémoire et un état en cours d'appel dans le simulateur. Vous pouvez utiliser le simulateur dans la plupart des cas, mais vous ne pouvez pas tester les fonctionnalités de l'appareil comme l'accéléromètre. Ainsi, vous aurez peut-être toujours besoin d'un appareil iOS pour tester minutieusement tous les scénarios d'une application.

Le langage utilisé dans le développement iOS est l'objectif C. C'est un langage orienté objet et par conséquent, ce serait facile pour ceux qui ont une certaine expérience dans les langages de programmation orientés objet.

Interface et mise en œuvre

En Objective C, le fichier où se fait la déclaration de classe s'appelle le interface file et le fichier où la classe est définie est appelé le implementation file.

Un simple fichier d'interface MyClass.h ressemblerait à ce qui suit -

@interface MyClass:NSObject { 
   // class variable declared here
}

// class properties declared here
// class methods and instance methods declared here
@end

Le dossier d'implémentation MyClass.m serait comme suit -

@implementation MyClass
   // class methods defined here
@end

Création d'objets

La création d'objet se fait comme suit -

MyClass  *objectName = [[MyClass alloc]init] ;

Méthodes

La méthode est déclarée en Objectif C comme suit -

-(returnType)methodName:(typeName) variable1 :(typeName)variable2;

Un exemple est présenté ci-dessous.

-(void)calculateAreaForRectangleWithLength:(CGfloat)length 
andBreadth:(CGfloat)breadth;

Vous vous demandez peut-être ce que andBreadthla chaîne est pour; en fait, c'est une chaîne facultative, qui nous aide à lire et à comprendre facilement la méthode, en particulier au moment de l'appel. Pour appeler cette méthode dans la même classe, nous utilisons l'instruction suivante -

[self calculateAreaForRectangleWithLength:30 andBreadth:20];

Comme indiqué ci-dessus, l'utilisation de andBreadth nous aide à comprendre que la largeur est de 20. Self est utilisé pour spécifier qu'il s'agit d'une méthode de classe.

Méthodes de classe

Les méthodes de classe sont accessibles directement sans créer d'objets pour la classe. Ils ne sont associés à aucune variable ni objet. Un exemple est présenté ci-dessous.

+(void)simpleClassMethod;

Il est accessible en utilisant le nom de la classe (supposons que le nom de la classe est MyClass) comme suit -

[MyClass simpleClassMethod];

Méthodes d'instance

Les méthodes d'instance ne sont accessibles qu'après avoir créé un objet pour la classe. La mémoire est allouée aux variables d'instance. Un exemple de méthode d'instance est illustré ci-dessous.

-(void)simpleInstanceMethod;

Il est accessible après avoir créé un objet pour la classe comme suit -

MyClass  *objectName = [[MyClass alloc]init] ;
[objectName simpleInstanceMethod];

Types de données importants dans l'objectif C

Sr.No. Type de données
1

NSString

Il est utilisé pour représenter une chaîne.

2

CGfloat

Il est utilisé pour représenter une valeur en virgule flottante (le flottant normal est également autorisé mais il est préférable d'utiliser CGfloat).

3

NSInteger

Il est utilisé pour représenter un entier.

4

BOOL

Il est utilisé pour représenter booléen (les types BOOL sont OUI ou NON autorisés).

Impression des journaux

NSLog - utilisé pour imprimer une instruction. Il sera imprimé dans les journaux de l'appareil et dans la console de débogage respectivement en mode version et débogage. Par exemple,

NSlog(@"");

Structures de contrôle

La plupart des structures de contrôle sont les mêmes qu'en C et C ++, à l'exception de quelques ajouts comme dans instruction.

Propriétés

Pour qu'une classe externe accède à la classe, des propriétés variables sont utilisées. Par exemple,

@property(nonatomic , strong) NSString *myString;

Accéder aux propriétés

Vous pouvez utiliser l'opérateur point pour accéder aux propriétés. Pour accéder à la propriété ci-dessus, nous ferons ce qui suit.

self.myString = @"Test";

Vous pouvez également utiliser la méthode set comme suit -

[self setMyString:@"Test"];

Catégories

Les catégories sont utilisées pour ajouter des méthodes aux classes existantes. De cette manière, nous pouvons ajouter une méthode aux classes pour lesquelles nous n'avons même pas de fichiers d'implémentation où la classe réelle est définie. Voici un exemple de catégorie pour notre classe -

@interface MyClass(customAdditions)
- (void)sampleCategoryMethod;
@end

@implementation MyClass(categoryAdditions)

-(void)sampleCategoryMethod {
   NSLog(@"Just a test category");
}

Tableaux

NSMutableArray et NSArray sont les classes de tableaux utilisées dans l'objectif C. Comme son nom l'indique, la première est mutable et la seconde est immuable. Un exemple est présenté ci-dessous.

NSMutableArray *aMutableArray = [[NSMutableArray alloc]init];
[anArray addObject:@"firstobject"];
NSArray *aImmutableArray = [[NSArray alloc]
initWithObjects:@"firstObject",nil];

dictionnaire

NSMutableDictionary et NSDictionary sont les classes de dictionnaire utilisées dans l'objectif C. Comme son nom l'indique, le premier est modifiable et le second est immuable. Un exemple est présenté ci-dessous.

NSMutableDictionary *aMutableDictionary = [[NSMutableArray alloc]init];
[aMutableDictionary setObject:@"firstobject" forKey:@"aKey"];
NSDictionary*aImmutableDictionary= [[NSDictionary alloc]initWithObjects:[NSArray arrayWithObjects:
@"firstObject",nil] forKeys:[ NSArray arrayWithObjects:@"aKey"]];

Création de la première application

Nous allons maintenant créer une simple application à vue unique (une application vide) qui fonctionnera sur le simulateur iOS.

Les étapes sont les suivantes.

Step 1 - Ouvrez Xcode et sélectionnez Create a new Xcode project.

Step 2 - Sélectionnez Single View Application.

Step 3 - Saisissez le nom du produit, c'est-à-dire le nom de l'application, le nom de l'organisation, puis l'identifiant de l'entreprise.

Step 4 - Assurez-vous que Use Automatic Reference Countingest sélectionné afin de libérer automatiquement les ressources allouées une fois qu'il est hors de portée. Cliquez sur Suivant.

Step 5 - Sélectionnez le répertoire du projet et sélectionnez créer.

Step 6 - Vous verrez un écran comme suit -

Dans l'écran ci-dessus, vous pourrez sélectionner les orientations prises en charge, les paramètres de construction et de libération. Il existe une cible de déploiement sur le terrain, la version de l'appareil à partir de laquelle nous voulons prendre en charge, permet de sélectionner 4.3, qui est la cible de déploiement minimale autorisée maintenant. Pour l'instant, ils ne sont pas obligatoires et concentrons-nous sur l'exécution de l'application.

Step 7 - Maintenant, sélectionnez le simulateur iPhone dans le menu déroulant près du bouton Exécuter et sélectionnez Exécuter.

Step 8- C'est ça; vous avez exécuté avec succès votre première application. Vous obtiendrez une sortie comme suit -

Modifions maintenant la couleur d'arrière-plan, juste pour commencer avec le constructeur d'interface. Sélectionnez ViewController.xib. Sélectionnez l'option d'arrière-plan sur le côté droit, changez la couleur et exécutez.

Dans le projet ci-dessus, par défaut, la cible de déploiement aurait été définie sur iOS 6.0 et la mise en page automatique sera activée. Pour nous assurer que notre application s'exécute sur les appareils à partir d'iOS 4.3, nous avons déjà modifié la cible de déploiement au début de la création de cette application, mais nous n'avons pas désactivé la mise en page automatique.

Pour désactiver la mise en page automatique, nous devons décocher la case à cocher de la mise en page automatique dans l'inspecteur de fichiers de chaque nib, c'est-à-dire les fichiers xib. Les différentes sections de l'IDE du projet Xcode sont données dans la figure suivante (avec l'aimable autorisation: documentation utilisateur Apple Xcode 4).

L'inspecteur de fichiers se trouve dans la barre de sélection de l'inspecteur comme indiqué ci-dessus et la mise en page automatique peut y être décochée. La disposition automatique peut être utilisée lorsque vous souhaitez cibler uniquement les appareils iOS 6. De plus, vous pourrez utiliser de nombreuses nouvelles fonctionnalités telles que le livret si vous augmentez la cible de déploiement vers iOS 6. Pour l'instant, restons fidèles à iOS 4.3 comme cible de déploiement.

Code de la première application iOS

Vous trouverez cinq fichiers différents qui auraient été générés pour votre application. Ils sont répertoriés comme suit -

  • AppDelegate.h
  • AppDelegate.m
  • ViewController.h
  • ViewController.m
  • ViewController.xib

AppDelegate.h

// Header File that provides all UI related items. 
#import <UIKit/UIKit.h> 

// Forward declaration (Used when class will be defined /imported in future)
@class ViewController;  

// Interface for Appdelegate
@interface AppDelegate : UIResponder <UIApplicationDelegate>

// Property window 
@property (strong, nonatomic) UIWindow *window; 

// Property Viewcontroller

@property (strong, nonatomic) ViewController *viewController;
//this marks end of interface 
@end

Important items in code -

  • AppDelegate hérite de UIResponder qui gère les événements iOS.

  • Implémente les méthodes déléguées de UIApplicationDelegate, qui fournit des événements d'application clés tels que le lancement terminé, sur le point de se terminer, etc.

  • Objet UIWindow pour gérer et coordonner les différentes vues sur l'écran de l'appareil iOS. C'est comme la vue de base sur laquelle toutes les autres vues sont chargées. En général, il n'y a qu'une seule fenêtre pour une application.

  • UIViewController pour gérer le flux d'écran.

AppDelegate.m

// Imports the class Appdelegate's interface
import "AppDelegate.h" 

// Imports the viewcontroller to be loaded
#import "ViewController.h" 

// Class definition starts here
@implementation AppDelegate 


// Method to intimate us that the application launched successfully
- (BOOL)application:(UIApplication *)application 
didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
   self.window = [[UIWindow alloc] initWithFrame:[[UIScreen mainScreen] bounds]];
   
   // Override point for customization after application launch.
   self.viewController = [[ViewController alloc]
   initWithNibName:@"ViewController" bundle:nil];
   self.window.rootViewController = self.viewController;
   [self.window makeKeyAndVisible];
   return YES;
}

- (void)applicationWillResignActive:(UIApplication *)application {
   /* Use this method to release shared resources, save user data,
   invalidate timers, and store enough application state information
   to restore your application to its current state in case it is 
   terminated later. If your application supports background 
   execution, this method is called instead of
   applicationWillTerminate: when the user quits.*/
}

- (void)applicationWillEnterForeground:(UIApplication *)application {
   /* Called as part of the transition from the background to the 
   inactive state. Here you can undo many of the changes made on 
   entering the background.*/
}

- (void)applicationDidBecomeActive:(UIApplication *)application {
   /* Restart any tasks that were paused (or not yet started) while 
   the application was inactive. If the application was previously in 
   the background, optionally refresh the user interface.*/
}

- (void)applicationWillTerminate:(UIApplication *)application {
   /* Called when the application is about to terminate. Save data if 
   appropriate. See also applicationDidEnterBackground:. */
}

- (void)applicationWillTerminate:(UIApplication *)application {
   /* Called when the application is about to terminate. Save data if appropriate.
   See also applicationDidEnterBackground:. */
}
@end

Important items in code -

  • Les délégués UIApplication sont définis ici. Toutes les méthodes définies ci-dessus sont des délégués d'application de l'interface utilisateur et ne contiennent aucune méthode définie par l'utilisateur.

  • L'objet UIWindow est alloué pour contenir l'application allouée.

  • UIViewController est alloué comme contrôleur de vue initial de la fenêtre.

  • Pour rendre la fenêtre visible, la méthode makeKeyAndVisible est appelée.

ViewController.h

#import <UIKit/UIKit.h> 

// Interface for class ViewController
@interface ViewController : UIViewController 

@end

Important items in code -

  • La classe ViewController hérite de UIViewController, qui fournit le modèle de gestion de vue fondamental pour les applications iOS.

ViewController.m

#import "ViewController.h"

// Category, an extension of ViewController class
@interface ViewController ()

@end

@implementation ViewController  

- (void)viewDidLoad {
   [super viewDidLoad];
   // Do any additional setup after loading the view, typically from a nib.
}

- (void)didReceiveMemoryWarning {
   [super didReceiveMemoryWarning];
   // Dispose of any resources that can be recreated.
}
@end

Important items in code -

  • Deux méthodes implémentées ici sont définies dans la classe de base UIViewController.

  • Effectuez la configuration initiale dans viewDidLoad qui est appelée après le chargement de la vue.

  • La méthode didReceiveMemoryWarning est appelée en cas d'avertissement de mémoire.

Les actions et les points de vente dans iOS sont appelés ibActions et ibOutlets respectivement, où ibsignifie constructeur d'interface. Ceux-ci sont liés aux éléments de l'interface utilisateur et nous les explorerons après avoir su visuellement comment les implémenter.

Actions et points de vente - étapes impliquées

Step 1 - Utilisons notre première application iPhone.

Step 2 - Sélectionnez le fichier ViewController.xib dans les fichiers de la section du navigateur.

Step 3 - Vous pouvez maintenant sélectionner les éléments de l'interface utilisateur dans le volet de la bibliothèque dans la partie droite de notre fenêtre, illustrée ci-dessous.

Step 4 - Vous pouvez faire glisser et déposer les éléments de l'interface utilisateur vers notre vue dans notre constructeur d'interface.

Step 5 - Ajoutons une étiquette et un bouton Round Rect à notre vue.

Step 6 - À partir du bouton de sélection de l'éditeur dans la barre d'outils de l'espace de travail situé dans le coin supérieur droit, comme illustré ci-dessous.

Sélectionnez le bouton Assistant éditeur.

Step 7 - Nous verrons deux fenêtres dans notre zone d'édition au centre, l'une est le fichier ViewController.xib et l'autre est ViewController.h.

Step 8 - Maintenant, faites un clic droit sur l'étiquette et sélectionnez, maintenez et faites glisser la nouvelle prise de référence comme indiqué ci-dessous.

Step 9- Déposez le ViewController.h entre les accolades. Dans le cas où il n'y a pas d'accolades dans le fichier, ajoutez le ViewController avant de faire cela. Vous trouverez un pop-up comme indiqué ci-dessous.

Step 10- Tapez le nom du libellé de la prise, ici nous avons utilisé le libellé myTitleLabel. Cliquez sur se connecter et l'ibOutlet sera terminé.

Step 11 - De même, pour ajouter une action, cliquez avec le bouton droit sur le bouton Round rect, sélectionnez Retouche à l'intérieur et faites-le glisser sous les accolades.

Step 12 - Déposez-le et nommez-le setTitleLabel.

Step 13 - Sélectionnez le fichier ViewController.m, vous trouverez une méthode comme indiqué ci-dessous.

-(IBAction) setTitleLabel:(id)sender {
}

Step 14 - Ajoutez une instruction comme indiqué ci-dessous dans la méthode ci-dessus.

[myTitleLabel setText:@"Hello"];

Step 15- Lançons maintenant le programme en sélectionnant le bouton Exécuter. Vous verrez la sortie suivante.

Step 16 - Cliquez maintenant sur le bouton.

Step 17 - L'étiquette que nous avons créée a été modifiée par l'action sur le bouton.

Step 18- De l'exemple ci-dessus, nous pouvons conclure qu'IBOutlet crée une référence à l'UIElement (ici pour l'UILabel). De même, IBAction lie l'UIButton à une méthode, qui est appelée lors de la retouche d'événement à l'intérieur.

Step 19 - Vous pouvez jouer avec les actions en sélectionnant différents événements lors de la création de l'action.

Exemple pour le délégué

Supposons qu'un objet A appelle un objet B pour effectuer une action. Une fois l'action terminée, l'objet A doit savoir que B a terminé la tâche et prendre les mesures nécessaires. Ceci est réalisé avec l'aide des délégués.

Les concepts clés de l'exemple ci-dessus sont:

  • A est un objet délégué de B.

  • B aura une référence de A.

  • A implémentera les méthodes déléguées de B.

  • B informera A via les méthodes déléguées.

Étapes de création d'un délégué

Step 1 - Commencez par créer une application à vue unique.

Step 2 - Sélectionnez ensuite Fichier → Nouveau → Fichier ...

Step 3 - Sélectionnez ensuite Objective C Class et cliquez sur Next.

Step 4 - Donnez un nom à la classe, par exemple, SampleProtocol avec la sous-classe comme NSObject comme indiqué ci-dessous.

Step 5 - Sélectionnez ensuite créer.

Step 6 - Ajoutez un protocole au fichier SampleProtocol.h et le code mis à jour est le suivant -

#import <Foundation/Foundation.h>

// Protocol definition starts here 
@protocol SampleProtocolDelegate <NSObject>
@required
- (void) processCompleted;
@end

// Protocol Definition ends here
@interface SampleProtocol : NSObject {
   // Delegate to respond back
   id <SampleProtocolDelegate> _delegate; 
}
@property (nonatomic,strong) id delegate;

-(void)startSampleProcess; // Instance method
@end

Step 7 - Implémentez la méthode d'instance en mettant à jour le fichier SampleProtocol.m comme indiqué ci-dessous.

#import "SampleProtocol.h"

@implementation SampleProtocol

-(void)startSampleProcess {
   [NSTimer scheduledTimerWithTimeInterval:3.0 target:self.delegate 
	selector:@selector(processCompleted) userInfo:nil repeats:NO];
}
@end

Step 8 - Ajoutez un UILabel dans le ViewController.xib en faisant glisser l'étiquette de la bibliothèque d'objets vers UIView comme indiqué ci-dessous.

Step 9 - Créez un IBOutlet pour l'étiquette et nommez-le myLabel et mettez à jour le code comme suit pour adopter SampleProtocolDelegate dans ViewController.h.

#import <UIKit/UIKit.h>
#import "SampleProtocol.h"

@interface ViewController : UIViewController<SampleProtocolDelegate> {
   IBOutlet UILabel *myLabel;
}
@end

Step 10Implémentez la méthode déléguée, créez un objet pour SampleProtocol et appelez la méthode startSampleProcess. Le fichier ViewController.m mis à jour est le suivant -

#import "ViewController.h"

@interface ViewController ()

@end

@implementation ViewController

- (void)viewDidLoad {
   [super viewDidLoad];
   SampleProtocol *sampleProtocol = [[SampleProtocol alloc]init];
   sampleProtocol.delegate = self;
   [myLabel setText:@"Processing..."];
   [sampleProtocol startSampleProcess];
   // Do any additional setup after loading the view, typically from a nib.
}

- (void)didReceiveMemoryWarning {
   [super didReceiveMemoryWarning];
   // Dispose of any resources that can be recreated.
}

#pragma mark - Sample protocol delegate
-(void)processCompleted {
   [myLabel setText:@"Process Completed"];
}
@end

Step 11Nous verrons une sortie comme suit. Initialement, l'étiquette affiche «traitement ...», qui est mis à jour une fois que la méthode déléguée est appelée par l'objet SampleProtocol.

Quels sont les éléments de l'interface utilisateur?

Les éléments de l'interface utilisateur sont les éléments visuels que nous pouvons voir dans nos applications. Certains de ces éléments répondent aux interactions des utilisateurs tels que les boutons, les champs de texte et d'autres sont informatifs tels que les images, les étiquettes.

Comment ajouter des éléments d'interface utilisateur?

Nous pouvons ajouter des éléments d'interface utilisateur à la fois dans le code et à l'aide du constructeur d'interface. En fonction du besoin, nous pouvons utiliser l'un ou l'autre.

Notre objectif

Nous nous concentrerons davantage sur l'ajout d'éléments d'interface utilisateur via du code dans nos applications. L'utilisation du générateur d'interface est simple et directe, il suffit de faire glisser et déposer les éléments de l'interface utilisateur.

Notre approche

Nous allons créer une application iOS simple et l'utiliser pour expliquer certains des éléments de l'interface utilisateur.

Step 1 - Créez une application basée sur la vue comme nous l'avons fait dans notre première application iOS.

Step 2 - Nous mettrons uniquement à jour les fichiers ViewController.h et ViewController.m.

Step 3 - Ensuite, nous ajoutons une méthode à notre fichier ViewController.m spécifique pour créer l'élément d'interface utilisateur.

Step 4 - Nous appellerons cette méthode dans notre méthode viewDidLoad.

Step 5 - Les lignes de code importantes ont été expliquées dans le code avec un commentaire sur une seule ligne au-dessus de ces lignes.

Liste des éléments de l'interface utilisateur

Les éléments spécifiques à l'interface utilisateur et leurs fonctionnalités associées sont expliqués ci-dessous -

Sr.No. Éléments spécifiques à l'interface utilisateur
1 Champs de texte

C'est un élément d'interface utilisateur qui permet à l'application d'obtenir les entrées de l'utilisateur.

2 Types d'entrée - TextFields

Nous pouvons définir le type d'entrée que l'utilisateur peut donner en utilisant la propriété keyboard de UITextField.

3 Boutons

Il est utilisé pour gérer les actions des utilisateurs.

4 Étiquette

Il est utilisé pour afficher du contenu statique.

5 Barre d'outils

Il est utilisé si nous voulons manipuler quelque chose en fonction de notre vue actuelle.

6 Barre d'état

Il affiche les informations clés de l'appareil.

sept Barre de navigation

Il contient les boutons de navigation d'un contrôleur de navigation, qui est une pile de contrôleurs de vue qui peuvent être poussés et sautés.

8 Barre d'onglets

Il est généralement utilisé pour basculer entre différentes sous-tâches, vues ou modèles dans la même vue.

9 Vue d'image

Il est utilisé pour afficher une image simple ou une séquence d'images.

dix Affichage de défilement

Il est utilisé pour afficher du contenu qui dépasse la zone de l'écran.

11 Vue de tableau

Il est utilisé pour afficher une liste déroulante de données sur plusieurs lignes et sections.

12 Vue partagé

Il est utilisé pour afficher deux volets avec le volet maître contrôlant les informations sur le volet de détail.

13 Affichage

Il est utilisé pour afficher une liste déroulante d'informations textuelles éventuellement modifiables.

14 Afficher la transition

Il explique les différentes transitions de vues entre les vues.

15 Cueilleurs

Il est utilisé pour afficher pour sélectionner une donnée spécifique dans une liste.

16 Commutateurs

Il est utilisé comme désactivation et activation pour les actions.

17 Curseurs

Il est utilisé pour permettre aux utilisateurs de faire des ajustements à une valeur ou à un processus sur une plage de valeurs autorisées.

18 Alertes

Il est utilisé pour donner des informations importantes aux utilisateurs.

19 Icônes

Il s'agit d'une représentation d'image utilisée pour une action ou de quelque chose lié à l'application.

L'accéléromètre est utilisé pour détecter les changements de position de l'appareil dans les trois directions x, y et z. On peut connaître la position actuelle de l'appareil par rapport au sol. Pour tester cet exemple, vous devrez l'exécuter sur undevice et ne fonctionne pas sur le simulateur.

Accéléromètre - étapes impliquées

Step 1 - Créez un simple View based application.

Step 2 - Ajoutez trois étiquettes dans ViewController.xib et créez des ibOutlets en les nommant xlabel, ylabel et zlabel.

Step 3 - Mettez à jour ViewController.h comme suit -

#import <UIKit/UIKit.h>

@interface ViewController : UIViewController<UIAccelerometerDelegate> {
   IBOutlet UILabel *xlabel;
   IBOutlet UILabel *ylabel;
   IBOutlet UILabel *zlabel;
}
@end

Step 4 - Mettre à jour ViewController.m comme suit -

#import "ViewController.h"

@interface ViewController ()
@end

@implementation ViewController

- (void)viewDidLoad {
   [super viewDidLoad];
   [[UIAccelerometer sharedAccelerometer]setDelegate:self];
   //Do any additional setup after loading the view,typically from a nib
}

- (void)didReceiveMemoryWarning {
   [super didReceiveMemoryWarning];
   // Dispose of any resources that can be recreated.
}

- (void)accelerometer:(UIAccelerometer *)accelerometer didAccelerate:
   (UIAcceleration *)acceleration {
   [xlabel setText:[NSString stringWithFormat:@"%f",acceleration.x]];
   [ylabel setText:[NSString stringWithFormat:@"%f",acceleration.y]];
   [zlabel setText:[NSString stringWithFormat:@"%f",acceleration.z]];
}
@end

Production

Lorsque nous exécutons l'application dans iPhone appareil, nous obtiendrons la sortie suivante -

Une application universelle est une application conçue pour l'iPhone et l'iPad dans un seul binaire. Une application universelle permet la réutilisation du code et des mises à jour rapides.

Application universelle - étapes impliquées

Step 1 - Créez un simple View based application.

Step 2 - Changer le nom du fichier ViewController.xib déposer vers ViewController_iPhone.xib comme indiqué ci-dessous dans l'inspecteur de fichiers sur le côté droit.

Step 3 - Sélectionnez Fichier → Nouveau → Fichier ... puis sélectionnez la sous-section "User Interface" et sélectionnez View. Cliquez sur Suivant.

Step 4 - Sélectionnez la famille d'appareils comme iPad et cliquez sur suivant.

Step 5 - Enregistrez le fichier sous ViewController_iPad.xib et sélectionnez Créer.

Step 6 - Ajouter une étiquette au centre de l'écran dans les deux ViewController_iPhone.xib et ViewController_iPad.xib.

Step 7 - Dans ViewController_iPad.xib, sélectionnez le identity inspector et définissez la classe personnalisée comme ViewController.

Step 8 - Mettez à jour l'application: DidFinishLaunching: méthode withOptions dans AppDelegate.m comme suit -

- (BOOL)application:(UIApplication *)application
   didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
   self.window = [[UIWindow alloc] initWithFrame:[[UIScreen 
   mainScreen] bounds]];
   
   // Override point for customization after application launch.
   if (UI_USER_INTERFACE_IDIOM() == UIUserInterfaceIdiomPhone) {
      self.viewController = [[ViewController alloc] 
      initWithNibName:@"ViewController_iPhone" bundle:nil];
   } else {
      self.viewController = [[ViewController alloc] initWithNibName:
      @"ViewController_iPad" bundle:nil];
   }
   self.window.rootViewController = self.viewController;
   [self.window makeKeyAndVisible];
   return YES;
}

Step 9 - Mettre à jour les appareils dans le résumé du projet pour Universal comme indiqué ci-dessous -

Production

Lorsque nous exécutons l'application, nous obtenons la sortie suivante -

Lorsque nous exécutons l'application dans le simulateur iPad, nous obtenons la sortie suivante -

L'appareil photo est l'une des fonctionnalités communes d'un appareil mobile. Il nous est possible de prendre des photos avec l'appareil photo et de l'utiliser dans notre application et c'est assez simple aussi.

Gestion de la caméra - étapes impliquées

Step 1 - Créez un simple View based application.

Step 2 - Ajouter un button dans ViewController.xib et créez IBAction pour le bouton.

Step 3 - Ajouter un image view et créez IBOutlet en le nommant imageView.

Step 4 - Mettre à jour ViewController.h comme suit -

#import <UIKit/UIKit.h>

@interface ViewController : UIViewController<UIImagePickerControllerDelegate> {
   UIImagePickerController *imagePicker;
   IBOutlet UIImageView *imageView;
}

- (IBAction)showCamera:(id)sender;
@end

Step 5 - Mettre à jour ViewController.m comme suit -

#import "ViewController.h"

@interface ViewController ()
@end

@implementation ViewController

- (void)viewDidLoad {
   [super viewDidLoad];
}

- (void)didReceiveMemoryWarning {
   [super didReceiveMemoryWarning];
   // Dispose of any resources that can be recreated.
}

- (IBAction)showCamera:(id)sender {
   imagePicker.allowsEditing = YES;
   
   if ([UIImagePickerController isSourceTypeAvailable:
   UIImagePickerControllerSourceTypeCamera]) {
      imagePicker.sourceType = UIImagePickerControllerSourceTypeCamera;
   } else {
      imagePicker.sourceType = 
      UIImagePickerControllerSourceTypePhotoLibrary;
   }
   [self presentModalViewController:imagePicker animated:YES];
}

-(void)imagePickerController:(UIImagePickerController *)picker 
   didFinishPickingMediaWithInfo:(NSDictionary *)info {
      UIImage *image = [info objectForKey:UIImagePickerControllerEditedImage];
      
      if (image == nil) {
         image = [info objectForKey:UIImagePickerControllerOriginalImage];
      }
   imageView.image = image;
}

-(void)imagePickerControllerDidCancel:(UIImagePickerController *)picker {
   [self dismissModalViewControllerAnimated:YES];
}
@end

Production

Lorsque nous exécutons l'application et cliquons sur le bouton Afficher la caméra, nous obtiendrons la sortie suivante -

Une fois que nous prenons une photo, nous pouvons éditer l'image, c'est-à-dire déplacer et redimensionner comme indiqué ci-dessous -

Nous pouvons facilement localiser l'emplacement actuel de l'utilisateur dans iOS, à condition que l'utilisateur autorise l'application à accéder aux informations à l'aide du cadre de localisation principal.

Gestion de l'emplacement - étapes impliquées

Step 1 - Créez une application simple basée sur la vue.

Step 2 - Sélectionnez votre fichier projet, puis sélectionnez les cibles puis ajoutez CoreLocation.framework comme indiqué ci-dessous -

Step 3 - Ajoutez deux étiquettes dans ViewController.xib et créez des ibOutlets en nommant les étiquettes comme latitudeLabel et longitudeLabel respectivement.

Step 4 - Créez un nouveau fichier en sélectionnant Fichier → Nouveau → Fichier ... → sélectionnez Objective C class et cliquez sur suivant.

Step 5 - Nommez la classe comme LocationHandler avec "sub class of" comme NSObject.

Step 6 - Sélectionnez créer.

Step 7 - Mettre à jour LocationHandler.h comme suit -

#import <Foundation/Foundation.h>
#import <CoreLocation/CoreLocation.h>

@protocol LocationHandlerDelegate <NSObject>

@required
-(void) didUpdateToLocation:(CLLocation*)newLocation 
   fromLocation:(CLLocation*)oldLocation;
@end

@interface LocationHandler : NSObject<CLLocationManagerDelegate> {
   CLLocationManager *locationManager;
}
@property(nonatomic,strong) id<LocationHandlerDelegate> delegate;

+(id)getSharedInstance;
-(void)startUpdating;
-(void) stopUpdating;

@end

Step 8 - Mettre à jour LocationHandler.m comme suit -

#import "LocationHandler.h"
static LocationHandler *DefaultManager = nil;

@interface LocationHandler()

-(void)initiate;

@end

@implementation LocationHandler

+(id)getSharedInstance{
   if (!DefaultManager) {
      DefaultManager = [[self allocWithZone:NULL]init];
      [DefaultManager initiate];
   }
   return DefaultManager;
}

-(void)initiate {
   locationManager = [[CLLocationManager alloc]init];
   locationManager.delegate = self;
}

-(void)startUpdating{
   [locationManager startUpdatingLocation];
}

-(void) stopUpdating {
   [locationManager stopUpdatingLocation];
}

-(void)locationManager:(CLLocationManager *)manager didUpdateToLocation:
   (CLLocation *)newLocation fromLocation:(CLLocation *)oldLocation {
   if ([self.delegate respondsToSelector:@selector
   (didUpdateToLocation:fromLocation:)]) {
      [self.delegate didUpdateToLocation:oldLocation 
      fromLocation:newLocation];
   }
}
@end

Step 9 - Mettre à jour ViewController.h comme suit où nous avons mis en œuvre le LocationHandler delegate et créez deux ibOutlets -

#import <UIKit/UIKit.h>
#import "LocationHandler.h"

@interface ViewController : UIViewController<LocationHandlerDelegate> {
   IBOutlet UILabel *latitudeLabel;
   IBOutlet UILabel *longitudeLabel;
}
@end

Step 10 - Mettre à jour ViewController.m comme suit -

#import "ViewController.h"

@interface ViewController ()
@end

@implementation ViewController

- (void)viewDidLoad {
   [super viewDidLoad];
   [[LocationHandler getSharedInstance]setDelegate:self];
   [[LocationHandler getSharedInstance]startUpdating];
}

- (void)didReceiveMemoryWarning {
   [super didReceiveMemoryWarning];
   // Dispose of any resources that can be recreated.
}

-(void)didUpdateToLocation:(CLLocation *)newLocation 
 fromLocation:(CLLocation *)oldLocation {
   [latitudeLabel setText:[NSString stringWithFormat:
   @"Latitude: %f",newLocation.coordinate.latitude]];
   [longitudeLabel setText:[NSString stringWithFormat:
   @"Longitude: %f",newLocation.coordinate.longitude]];
}
@end

Production

Lorsque nous exécutons l'application, nous obtenons la sortie suivante -

SQLite peut être utilisé dans iOS pour gérer les données. Il utilise des requêtes sqlite, ce qui facilite la tâche de ceux qui connaissent SQL.

Étapes impliquées

Step 1 - Créez un simple View based application.

Step 2 - Sélectionnez votre fichier de projet, puis sélectionnez des cibles puis ajoutez libsqlite3.dylib bibliothèque dans choisir des cadres.

Step 3 - Créez un nouveau fichier en sélectionnant Fichier → Nouveau → Fichier ... → sélectionnez Objective C class et cliquez sur suivant.

Step 4 - Nommez la classe comme DBManager avec "sub class of" comme NSObject.

Step 5 - Sélectionnez créer.

Step 6 - Mettre à jour DBManager.h comme suit -

#import <Foundation/Foundation.h>
#import <sqlite3.h>

@interface DBManager : NSObject {
   NSString *databasePath;
}

+(DBManager*)getSharedInstance;
-(BOOL)createDB;
-(BOOL) saveData:(NSString*)registerNumber name:(NSString*)name 
   department:(NSString*)department year:(NSString*)year;
-(NSArray*) findByRegisterNumber:(NSString*)registerNumber;

@end

Step 7 - Mettre à jour DBManager.m comme suit -

#import "DBManager.h"
static DBManager *sharedInstance = nil;
static sqlite3 *database = nil;
static sqlite3_stmt *statement = nil;

@implementation DBManager

+(DBManager*)getSharedInstance {
   if (!sharedInstance) {
      sharedInstance = [[super allocWithZone:NULL]init];
      [sharedInstance createDB];
   }
   return sharedInstance;
}

-(BOOL)createDB {
   NSString *docsDir;
   NSArray *dirPaths;
   
   // Get the documents directory
   dirPaths = NSSearchPathForDirectoriesInDomains
   (NSDocumentDirectory, NSUserDomainMask, YES);
   docsDir = dirPaths[0];
   
   // Build the path to the database file
   databasePath = [[NSString alloc] initWithString: 
   [docsDir stringByAppendingPathComponent: @"student.db"]];
   BOOL isSuccess = YES;
   NSFileManager *filemgr = [NSFileManager defaultManager];
   
   if ([filemgr fileExistsAtPath: databasePath ] == NO) {
      const char *dbpath = [databasePath UTF8String];
      if (sqlite3_open(dbpath, &database) == SQLITE_OK) {
         char *errMsg;
         const char *sql_stmt =
         "create table if not exists studentsDetail (regno integer 
         primary key, name text, department text, year text)";
         
         if (sqlite3_exec(database, sql_stmt, NULL, NULL, &errMsg) != SQLITE_OK) {
            isSuccess = NO;
            NSLog(@"Failed to create table");
         }
         sqlite3_close(database);
         return  isSuccess;
      } else {
         isSuccess = NO;
         NSLog(@"Failed to open/create database");
      }
   }    
   return isSuccess;
}

- (BOOL) saveData:(NSString*)registerNumber name:(NSString*)name 
   department:(NSString*)department year:(NSString*)year; {
   const char *dbpath = [databasePath UTF8String];
   
   if (sqlite3_open(dbpath, &database) == SQLITE_OK) {
      NSString *insertSQL = [NSString stringWithFormat:@"insert into
      studentsDetail (regno,name, department, year) values
      (\"%d\",\"%@\", \"%@\", \"%@\")",[registerNumber integerValue],
      name, department, year];        
      const char *insert_stmt = [insertSQL UTF8String];
      sqlite3_prepare_v2(database, insert_stmt,-1, &statement, NULL);
      
      if (sqlite3_step(statement) == SQLITE_DONE) {
         return YES;
      } else {
         return NO;
      }
      sqlite3_reset(statement);
   }
   return NO;
}

- (NSArray*) findByRegisterNumber:(NSString*)registerNumber {
   const char *dbpath = [databasePath UTF8String];
   
   if (sqlite3_open(dbpath, &database) == SQLITE_OK) {
      NSString *querySQL = [NSString stringWithFormat:
      @"select name, department, year from studentsDetail where 
      regno=\"%@\"",registerNumber];
      const char *query_stmt = [querySQL UTF8String];
      NSMutableArray *resultArray = [[NSMutableArray alloc]init];
      
      if (sqlite3_prepare_v2(database, query_stmt, -1, &statement, NULL) == SQLITE_OK) {
         if (sqlite3_step(statement) == SQLITE_ROW) {
            NSString *name = [[NSString alloc] initWithUTF8String:
            (const char *) sqlite3_column_text(statement, 0)];
            [resultArray addObject:name];
            
            NSString *department = [[NSString alloc] initWithUTF8String:
            (const char *) sqlite3_column_text(statement, 1)];
            [resultArray addObject:department];
            
            NSString *year = [[NSString alloc]initWithUTF8String:
            (const char *) sqlite3_column_text(statement, 2)];
            [resultArray addObject:year];
            return resultArray;
         } else {
            NSLog(@"Not found");
            return nil;
         }
         sqlite3_reset(statement);
      }
   }
   return nil;
}

Step 8 - Mettre à jour ViewController.xib fichier comme suit -

Step 9 - Créez des IBOutlets pour les champs de texte ci-dessus.

Step 10 - Créez IBAction pour les boutons ci-dessus.

Step 11 - Mettre à jour ViewController.h comme suit -

#import <UIKit/UIKit.h>
#import "DBManager.h"

@interface ViewController : UIViewController<UITextFieldDelegate> {
   IBOutlet UITextField *regNoTextField;
   IBOutlet UITextField *nameTextField;
   IBOutlet UITextField *departmentTextField;
   IBOutlet UITextField *yearTextField;
   IBOutlet UITextField *findByRegisterNumberTextField;
   IBOutlet UIScrollView *myScrollView;
}

-(IBAction)saveData:(id)sender;
-(IBAction)findData:(id)sender;
@end

Step 12 - Mettre à jour ViewController.m comme suit -

#import "ViewController.h"

@interface ViewController ()
@end

@implementation ViewController

- (id)initWithNibName:(NSString *)nibNameOrNil bundle:(NSBundle *)
   nibBundleOrNil {
   self = [super initWithNibName:nibNameOrNil bundle:nibBundleOrNil];
   
   if (self) {
      // Custom initialization
   }
   return self;
}

- (void)viewDidLoad {
   [super viewDidLoad];
   // Do any additional setup after loading the view from its nib.
}

- (void)didReceiveMemoryWarning {
   [super didReceiveMemoryWarning];
   // Dispose of any resources that can be recreated.
}

-(IBAction)saveData:(id)sender {
   BOOL success = NO;
   NSString *alertString = @"Data Insertion failed";
   
   if (regNoTextField.text.length>0 &&nameTextField.text.length>0 &&
      departmentTextField.text.length>0 &&yearTextField.text.length>0 ) {
      success = [[DBManager getSharedInstance]saveData:
      regNoTextField.text name:nameTextField.text department:
      departmentTextField.text year:yearTextField.text];
   } else {
      alertString = @"Enter all fields";
   }     
   
   if (success == NO) {
      UIAlertView *alert = [[UIAlertView alloc]initWithTitle:
      alertString message:nil
      delegate:nil cancelButtonTitle:@"OK" otherButtonTitles:nil];
      [alert show];
   }
}

-(IBAction)findData:(id)sender {
   NSArray *data = [[DBManager getSharedInstance]findByRegisterNumber:
   findByRegisterNumberTextField.text];
   
   if (data == nil) {
      UIAlertView *alert = [[UIAlertView alloc]initWithTitle:
      @"Data not found" message:nil delegate:nil cancelButtonTitle:
      @"OK" otherButtonTitles:nil];
      [alert show];
      regNoTextField.text = @"";
      nameTextField.text =@"";
      departmentTextField.text = @"";
      yearTextField.text =@"";
   } else {
      regNoTextField.text = findByRegisterNumberTextField.text;
      nameTextField.text =[data objectAtIndex:0];
      departmentTextField.text = [data objectAtIndex:1];
      yearTextField.text =[data objectAtIndex:2];
   }
}

#pragma mark - Text field delegate
-(void)textFieldDidBeginEditing:(UITextField *)textField {
   [myScrollView setFrame:CGRectMake(10, 50, 300, 200)];
   [myScrollView setContentSize:CGSizeMake(300, 350)];
}

-(void)textFieldDidEndEditing:(UITextField *)textField {
   [myScrollView setFrame:CGRectMake(10, 50, 300, 350)];

}

-(BOOL) textFieldShouldReturn:(UITextField *)textField {
   [textField resignFirstResponder];
   return YES;
}
@end

Production

Lorsque nous exécutons l'application, nous obtenons la sortie suivante où nous pouvons ajouter et trouver les détails de l'étudiant -

Nous pouvons envoyer des e-mails à l'aide de l'application Email de l'appareil iOS.

Étapes impliquées

Step 1 - Créez un simple View based application.

Step 2 - Sélectionnez votre fichier de projet, puis sélectionnez des cibles puis ajoutez MessageUI.framework.

Step 3 - Ajouter un bouton dans ViewController.xib et créez une action d'envoi d'e-mail.

Step 4 - Mettre à jour ViewController.h comme suit -

#import <UIKit/UIKit.h>
#import <MessageUI/MessageUI.h>

@interface ViewController : UIViewController<MFMailComposeViewControllerDelegate> {
   MFMailComposeViewController *mailComposer;
}

-(IBAction)sendMail:(id)sender;

@end

Step 5 - Mettre à jour ViewController.m comme suit -

#import "ViewController.h"

@interface ViewController ()
@end

@implementation ViewController

- (void)viewDidLoad {
   [super viewDidLoad];
}

- (void)didReceiveMemoryWarning {
   [super didReceiveMemoryWarning];
   // Dispose of any resources that can be recreated.
}

-(void)sendMail:(id)sender {
   mailComposer = [[MFMailComposeViewController alloc]init];
   mailComposer.mailComposeDelegate = self;
   [mailComposer setSubject:@"Test mail"];
   [mailComposer setMessageBody:@"Testing message 
   for the test mail" isHTML:NO];
   [self presentModalViewController:mailComposer animated:YES];
}

#pragma mark - mail compose delegate
-(void)mailComposeController:(MFMailComposeViewController *)controller 
   didFinishWithResult:(MFMailComposeResult)result error:(NSError *)error{
   
   if (result) {
      NSLog(@"Result : %d",result);
   }
   
   if (error) {
      NSLog(@"Error : %@",error);
   }
   
   [self dismissModalViewControllerAnimated:YES];
}
@end

Production

Lorsque nous exécutons l'application, nous obtenons la sortie suivante -

En cliquant sur Envoyer un e-mail, nous obtiendrons la sortie suivante -

L'audio et la vidéo sont assez courants dans les derniers appareils. Il est pris en charge dans iOS avec l'aide deAVFoundation.framework et MediaPlayer.framework respectivement.

Étapes impliquées

Step 1 - Créez un simple View based application.

Step 2 - Sélectionnez votre fichier de projet, sélectionnez des cibles, puis nous devons ajouter AVFoundation.framework et MediaPlayer.framework.

Step 3 - Ajoutez deux boutons dans ViewController.xib et créez une action pour lire respectivement l'audio et la vidéo.

Step 4 - Mettre à jour ViewController.h comme suit -

#import <UIKit/UIKit.h>
#import <AVFoundation/AVFoundation.h>
#import <MediaPlayer/MediaPlayer.h>

@interface ViewController : UIViewController {
   AVAudioPlayer *audioPlayer;
   MPMoviePlayerViewController *moviePlayer;
}
-(IBAction)playAudio:(id)sender;
-(IBAction)playVideo:(id)sender;
@end

Step 5 - Mettre à jour ViewController.m comme suit -

#import "ViewController.h"

@interface ViewController ()
@end

@implementation ViewController

- (void)viewDidLoad {
   [super viewDidLoad];
}

- (void)didReceiveMemoryWarning {
   [super didReceiveMemoryWarning];
   // Dispose of any resources that can be recreated.
}

-(IBAction)playAudio:(id)sender {
   NSString *path = [[NSBundle mainBundle]
   pathForResource:@"audioTest" ofType:@"mp3"];
   audioPlayer = [[AVAudioPlayer alloc]initWithContentsOfURL:
   [NSURL fileURLWithPath:path] error:NULL];
   [audioPlayer play];
}

-(IBAction)playVideo:(id)sender {
   NSString *path = [[NSBundle mainBundle]pathForResource:
   @"videoTest" ofType:@"mov"];
   moviePlayer = [[MPMoviePlayerViewController 
   alloc]initWithContentURL:[NSURL fileURLWithPath:path]];
   [self presentModalViewController:moviePlayer animated:NO];
}
@end

Remarque

Nous devons ajouter des fichiers audio et vidéo pour nous assurer d'obtenir la sortie attendue.

Production

Lorsque nous exécutons l'application, nous obtenons la sortie suivante -

Lorsque nous cliquons sur lire la vidéo, nous obtiendrons une sortie comme indiqué ci-dessous -

Lorsque nous cliquons sur play audio, vous entendrez l'audio.

La gestion des fichiers ne peut pas être expliquée visuellement avec l'application et, par conséquent, les principales méthodes utilisées pour gérer les fichiers sont expliquées ci-dessous. Notez que le bundle d'applications ne dispose que d'une autorisation de lecture et que nous ne pourrons pas modifier les fichiers. Vous pouvez de toute façon modifier le répertoire des documents de votre application.

Méthodes utilisées dans la gestion des fichiers

Les méthodes utilisées pour accessing et manipulatingles fichiers sont décrits ci-dessous. Ici, nous devons remplacer les chaînes FilePath1, FilePath2 et FilePath par nos chemins de fichiers complets requis pour obtenir l'action souhaitée.

Vérifier si un fichier existe sur un chemin

NSFileManager *fileManager = [NSFileManager defaultManager];

//Get documents directory
NSArray *directoryPaths = NSSearchPathForDirectoriesInDomains
(NSDocumentDirectory, NSUserDomainMask, YES);
NSString *documentsDirectoryPath = [directoryPaths objectAtIndex:0];

if ([fileManager fileExistsAtPath:@""]==YES) {
   NSLog(@"File exists");
}

Comparaison de deux contenus de fichiers

if ([fileManager contentsEqualAtPath:@"FilePath1" andPath:@" FilePath2"]) {
   NSLog(@"Same content");
}

Vérifier si inscriptible, lisible et exécutable

if ([fileManager isWritableFileAtPath:@"FilePath"]) {
   NSLog(@"isWritable");
}

if ([fileManager isReadableFileAtPath:@"FilePath"]) {
   NSLog(@"isReadable");
}

if ( [fileManager isExecutableFileAtPath:@"FilePath"]) {
   NSLog(@"is Executable");
}

Déplacer le fichier

if([fileManager moveItemAtPath:@"FilePath1" 
   toPath:@"FilePath2" error:NULL]) {
   NSLog(@"Moved successfully");
}

Copier un fichier

if ([fileManager copyItemAtPath:@"FilePath1" 
   toPath:@"FilePath2"  error:NULL]) {
   NSLog(@"Copied successfully");
}

Effacer le fichier

if ([fileManager removeItemAtPath:@"FilePath" error:NULL]) {
   NSLog(@"Removed successfully");
}

Lire le fichier

NSData *data = [fileManager contentsAtPath:@"Path"];

Ecrire un fichier

[fileManager createFileAtPath:@"" contents:data attributes:nil];

Les cartes nous sont toujours utiles pour localiser des lieux. Les cartes sont intégrées dans iOS à l'aide du framework MapKit.

Étapes impliquées

Step 1 - Créez une application simple basée sur la vue.

Step 2 - Sélectionnez votre fichier projet, puis sélectionnez les cibles puis ajoutez MapKit.framework.

Step 3 - Nous devrions également ajouter Corelocation.framework.

Step 4 - Ajoutez un MapView à ViewController.xib et créez un ibOutlet et nommez-le mapView.

Step 5 - Créez un nouveau fichier en sélectionnant Fichier → Nouveau → Fichier ... → sélectionnez la classe Objective C et cliquez sur Suivant.

Step 6 - Nommez la classe comme MapAnnotation avec "sous-classe de" comme NSObject.

Step 7 - Sélectionnez créer.

Step 8 - Mettez à jour MapAnnotation.h comme suit -

#import <Foundation/Foundation.h>
#import <MapKit/MapKit.h>

@interface MapAnnotation : NSObject<MKAnnotation>
@property (nonatomic, strong) NSString *title;
@property (nonatomic, readwrite) CLLocationCoordinate2D coordinate;

- (id)initWithTitle:(NSString *)title andCoordinate:
   (CLLocationCoordinate2D)coordinate2d;

@end

Step 9 - Mettre à jour MapAnnotation.m comme suit -

#import "MapAnnotation.h"

@implementation MapAnnotation
-(id)initWithTitle:(NSString *)title andCoordinate:
   (CLLocationCoordinate2D)coordinate2d {
  
   self.title = title;
   self.coordinate =coordinate2d;
   return self;
}
@end

Step 10 - Mettre à jour ViewController.h comme suit -

#import <UIKit/UIKit.h>
#import <MapKit/MapKit.h>
#import <CoreLocation/CoreLocation.h>

@interface ViewController : UIViewController<MKMapViewDelegate> {
   MKMapView *mapView;
}
@end

Step 11 - Mettre à jour ViewController.m comme suit -

#import "ViewController.h"
#import "MapAnnotation.h"

@interface ViewController ()
@end

@implementation ViewController

- (void)viewDidLoad {
   [super viewDidLoad];
   mapView = [[MKMapView alloc]initWithFrame:
   CGRectMake(10, 100, 300, 300)];
   mapView.delegate = self;
   mapView.centerCoordinate = CLLocationCoordinate2DMake(37.32, -122.03);
   mapView.mapType = MKMapTypeHybrid;
   CLLocationCoordinate2D location;
   location.latitude = (double) 37.332768;
   location.longitude = (double) -122.030039;
   
   // Add the annotation to our map view
   MapAnnotation *newAnnotation = [[MapAnnotation alloc]
   initWithTitle:@"Apple Head quaters" andCoordinate:location];
   [mapView addAnnotation:newAnnotation];
   CLLocationCoordinate2D location2;
   location2.latitude = (double) 37.35239;
   location2.longitude = (double) -122.025919;
   MapAnnotation *newAnnotation2 = [[MapAnnotation alloc] 
   initWithTitle:@"Test annotation" andCoordinate:location2];
   [mapView addAnnotation:newAnnotation2];
   [self.view addSubview:mapView];
}

// When a map annotation point is added, zoom to it (1500 range)
- (void)mapView:(MKMapView *)mv didAddAnnotationViews:(NSArray *)views {
   MKAnnotationView *annotationView = [views objectAtIndex:0];
   id <MKAnnotation> mp = [annotationView annotation];
   MKCoordinateRegion region = MKCoordinateRegionMakeWithDistance
   ([mp coordinate], 1500, 1500);
   [mv setRegion:region animated:YES];
   [mv selectAnnotation:mp animated:YES];
}

- (void)didReceiveMemoryWarning {
   [super didReceiveMemoryWarning];
   // Dispose of any resources that can be recreated.
}
@end

Production

Lorsque nous exécutons l'application, nous obtenons la sortie comme indiqué ci-dessous -

Lorsque nous faisons défiler la carte vers le haut, nous obtiendrons la sortie comme indiqué ci-dessous -

L'achat In-App est utilisé pour acheter du contenu supplémentaire ou mettre à niveau des fonctionnalités par rapport à une application.

Étapes impliquées

Step 1 - Dans iTunes connect, assurez-vous que vous disposez d'un unique App ID et lorsque nous créons la mise à jour de l'application avec le bundle ID et la signature de code dans Xcode avec le profil d'approvisionnement correspondant.

Step 2- Créez une nouvelle application et mettez à jour les informations de l'application. Vous pouvez en savoir plus sur Apple'sAdd new apps Documentation.

Step 3 - Ajoutez un nouveau produit pour un achat intégré dans Manage In-App Purchase de la page de votre application.

Step 4- Assurez-vous de configurer les coordonnées bancaires de votre application. Cela doit être configuré pourIn-App purchasetravailler. Créez également un compte utilisateur de test en utilisantManage Users option dans la page de connexion iTunes de votre application.

Step 5 - Les étapes suivantes sont liées à la gestion du code et à la création de l'interface utilisateur pour notre achat intégré.

Step 6 - Créer un single view application et entrez l'identifiant du bundle est l'identifiant spécifié dans iTunes connect.

Step 7 - Mettre à jour le ViewController.xib comme indiqué ci-dessous -

Step 8 - Créer IBOutlets pour les trois étiquettes et le bouton les nommant respectivement productTitleLabel, productDescriptionLabel, productPriceLabel et purchaseButton.

Step 9 - Sélectionnez votre fichier de projet, puis sélectionnez des cibles puis ajoutez StoreKit.framework.

Step 10 - Mettre à jour ViewController.h comme suit -

#import <UIKit/UIKit.h>
#import <StoreKit/StoreKit.h>

@interface ViewController : UIViewController<
SKProductsRequestDelegate,SKPaymentTransactionObserver> {
   SKProductsRequest *productsRequest;
   NSArray *validProducts;
   UIActivityIndicatorView *activityIndicatorView;
   IBOutlet UILabel *productTitleLabel;
   IBOutlet UILabel *productDescriptionLabel;
   IBOutlet UILabel *productPriceLabel;
   IBOutlet UIButton *purchaseButton;
}

- (void)fetchAvailableProducts;
- (BOOL)canMakePurchases;
- (void)purchaseMyProduct:(SKProduct*)product;
- (IBAction)purchase:(id)sender;

@end

Step 11 - Mettre à jour ViewController.m comme suit -

#import "ViewController.h"
#define kTutorialPointProductID 
@"com.tutorialPoints.testApp.testProduct"

@interface ViewController ()
@end

@implementation ViewController

- (void)viewDidLoad {
   [super viewDidLoad];
   
   // Adding activity indicator
   activityIndicatorView = [[UIActivityIndicatorView alloc]
   initWithActivityIndicatorStyle:UIActivityIndicatorViewStyleWhiteLarge];
   activityIndicatorView.center = self.view.center;
   [activityIndicatorView hidesWhenStopped];
   [self.view addSubview:activityIndicatorView];
   [activityIndicatorView startAnimating];
   
   //Hide purchase button initially
   purchaseButton.hidden = YES;
   [self fetchAvailableProducts];
}

- (void)didReceiveMemoryWarning {
   [super didReceiveMemoryWarning];
   // Dispose of any resources that can be recreated.
}

-(void)fetchAvailableProducts {
   NSSet *productIdentifiers = [NSSet 
   setWithObjects:kTutorialPointProductID,nil];
   productsRequest = [[SKProductsRequest alloc] 
   initWithProductIdentifiers:productIdentifiers];
   productsRequest.delegate = self;
   [productsRequest start];
}

- (BOOL)canMakePurchases {
   return [SKPaymentQueue canMakePayments];
}

- (void)purchaseMyProduct:(SKProduct*)product {
   if ([self canMakePurchases]) {
      SKPayment *payment = [SKPayment paymentWithProduct:product];
      [[SKPaymentQueue defaultQueue] addTransactionObserver:self];
      [[SKPaymentQueue defaultQueue] addPayment:payment];
   } else {
      UIAlertView *alertView = [[UIAlertView alloc]initWithTitle:
      @"Purchases are disabled in your device" message:nil delegate:
      self cancelButtonTitle:@"Ok" otherButtonTitles: nil];
      [alertView show];
   }
}
-(IBAction)purchase:(id)sender {
   [self purchaseMyProduct:[validProducts objectAtIndex:0]];
   purchaseButton.enabled = NO; 
}

#pragma mark StoreKit Delegate

-(void)paymentQueue:(SKPaymentQueue *)queue 
updatedTransactions:(NSArray *)transactions {
   for (SKPaymentTransaction *transaction in transactions) {
      switch (transaction.transactionState) {
         case SKPaymentTransactionStatePurchasing:
            NSLog(@"Purchasing");
         break;
         
         case SKPaymentTransactionStatePurchased:
            if ([transaction.payment.productIdentifier 
            isEqualToString:kTutorialPointProductID]) {
               NSLog(@"Purchased ");
               UIAlertView *alertView = [[UIAlertView alloc]initWithTitle:
               @"Purchase is completed succesfully" message:nil delegate:
               self cancelButtonTitle:@"Ok" otherButtonTitles: nil];
               [alertView show];
            }
            [[SKPaymentQueue defaultQueue] finishTransaction:transaction];
         break;
            
         case SKPaymentTransactionStateRestored:
            NSLog(@"Restored ");
            [[SKPaymentQueue defaultQueue] finishTransaction:transaction];
         break;
            
         case SKPaymentTransactionStateFailed:
            NSLog(@"Purchase failed ");
         break
         default:
         break;
      }
   }
}

-(void)productsRequest:(SKProductsRequest *)request 
didReceiveResponse:(SKProductsResponse *)response {
   SKProduct *validProduct = nil;
   int count = [response.products count];
   
   if (count>0) {
      validProducts = response.products;
      validProduct = [response.products objectAtIndex:0];
      
      if ([validProduct.productIdentifier 
         isEqualToString:kTutorialPointProductID]) {
         [productTitleLabel setText:[NSString stringWithFormat:
            @"Product Title: %@",validProduct.localizedTitle]];
         [productDescriptionLabel setText:[NSString stringWithFormat:
            @"Product Desc: %@",validProduct.localizedDescription]];
         [productPriceLabel setText:[NSString stringWithFormat:
            @"Product Price: %@",validProduct.price]];
      }
   } else {
      UIAlertView *tmp = [[UIAlertView alloc]
         initWithTitle:@"Not Available"
         message:@"No products to purchase"
         delegate:self
         cancelButtonTitle:nil
         otherButtonTitles:@"Ok", nil];
         [tmp show];
   }
   
   [activityIndicatorView stopAnimating];
   purchaseButton.hidden = NO;
}
@end

Remarque

Vous devez mettre à jour kTutorialPointProductID avec le productID que vous avez créé pour votre achat intégré. Vous pouvez ajouter plusieurs produits en mettant à jour le NSSet de productIdentifiers dans fetchAvailableProducts. De même, gérez les actions liées à l'achat pour les ID de produit que vous ajoutez.

Production

Lorsque nous exécutons l'application, nous obtenons la sortie suivante -

Assurez-vous que vous vous êtes déconnecté de votre compte dans l'écran des paramètres. En cliquant sur Lancer l'achat, sélectionnez Utiliser l'identifiant Apple existant. Saisissez le nom d'utilisateur et le mot de passe de votre compte de test valide. L'alerte suivante s'affichera dans quelques secondes.

Une fois votre produit acheté avec succès, vous recevrez l'alerte suivante. Vous pouvez voir le code pertinent pour mettre à jour les fonctionnalités de l'application où nous affichons cette alerte.

iAd est utilisé pour afficher des publicités, diffusées par le serveur Apple. iAd nous aide à générer des revenus à partir d'une application iOS.

Intégration iAd - étapes impliquées

Step 1 - Créez une application simple basée sur la vue.

Step 2 - Sélectionnez votre fichier de projet, puis sélectionnez les cibles, puis ajoutez iAd.framework dans Choose frameworks.

Step 3 - Mettez à jour ViewController.h comme suit -

#import <UIKit/UIKit.h>
#import <iAd/iAd.h>

@interface ViewController : UIViewController<ADBannerViewDelegate> {
   ADBannerView *bannerView;
}
@end

Step 4 - Mettre à jour ViewController.m comme suit -

#import "ViewController.h"

@interface ViewController ()
@end

@implementation ViewController

- (void)viewDidLoad {
   [super viewDidLoad];
   bannerView = [[ADBannerView alloc]initWithFrame:
   CGRectMake(0, 0, 320, 50)];
   
   // Optional to set background color to clear color
   [bannerView setBackgroundColor:[UIColor clearColor]];
   [self.view addSubview: bannerView];
}

- (void)didReceiveMemoryWarning {
   [super didReceiveMemoryWarning];
   // Dispose of any resources that can be recreated.
}

#pragma mark - AdViewDelegates

-(void)bannerView:(ADBannerView *)banner 
   didFailToReceiveAdWithError:(NSError *)error {
   NSLog(@"Error loading");
}

-(void)bannerViewDidLoadAd:(ADBannerView *)banner {
   NSLog(@"Ad loaded");
}

-(void)bannerViewWillLoadAd:(ADBannerView *)banner {
   NSLog(@"Ad will load");
}

-(void)bannerViewActionDidFinish:(ADBannerView *)banner {
   NSLog(@"Ad did finish");
}
@end

Production

Lorsque nous exécutons l'application, nous obtenons la sortie suivante -

Gamekit est un cadre qui fournit un tableau de bord, des réalisations et plus de fonctionnalités à une application iOS. Dans ce tutoriel, nous expliquerons les étapes de l'ajout d'un classement et de la mise à jour du score.

Étapes impliquées

Step 1 - Dans iTunes connect, assurez-vous que vous disposez d'un unique App ID et lorsque nous créons la mise à jour de l'application avec le bundle ID et la signature de code dans Xcode avec le profil d'approvisionnement correspondant.

Step 2- Créez une nouvelle application et mettez à jour les informations de l'application. Vous pouvez en savoir plus à ce sujet dans la documentation de nouvelles applications Apple.

Step 3 - Mettre en place un tableau des leaders dans Manage Game Center de la page de votre application où ajouter un seul classement et donner leaderboard IDet le type de score. Ici, nous donnons l'ID du tableau de bord sous forme de tutorielsPoint.

Step 4 - Les étapes suivantes sont liées à la gestion du code et à la création de l'interface utilisateur pour notre application.

Step 5 - Créer un single view application et entrez le bundle identifier est l'identifiant spécifié dans iTunes connect.

Step 6 - Mettez à jour ViewController.xib comme indiqué ci-dessous -

Step 7 - Sélectionnez votre fichier de projet, puis sélectionnez targets puis ajoutez GameKit.framework.

Step 8 - Créer IBActions pour les boutons que nous avons ajoutés.

Step 9 - Mettre à jour le ViewController.h fichier comme suit -

#import <UIKit/UIKit.h>
#import <GameKit/GameKit.h>

@interface ViewController : UIViewController
<GKLeaderboardViewControllerDelegate>

-(IBAction)updateScore:(id)sender;
-(IBAction)showLeaderBoard:(id)sender;

@end

Step 10 - Mettre à jour ViewController.m comme suit -

#import "ViewController.h"

@interface ViewController ()
@end

@implementation ViewController

- (void)viewDidLoad {
   [super viewDidLoad];
   if([GKLocalPlayer localPlayer].authenticated == NO) {
      [[GKLocalPlayer localPlayer] 
      authenticateWithCompletionHandler:^(NSError *error) {
         NSLog(@"Error%@",error);
      }];
   }    
}

- (void)didReceiveMemoryWarning {
   [super didReceiveMemoryWarning];
   // Dispose of any resources that can be recreated.
}

- (void) updateScore: (int64_t) score 
   forLeaderboardID: (NSString*) category {
   GKScore *scoreObj = [[GKScore alloc]
   initWithCategory:category];
   scoreObj.value = score;
   scoreObj.context = 0;
   
   [scoreObj reportScoreWithCompletionHandler:^(NSError *error) {
      // Completion code can be added here
      UIAlertView *alert = [[UIAlertView alloc]
      initWithTitle:nil message:@"Score Updated Succesfully" 
      delegate:self cancelButtonTitle:@"Ok" otherButtonTitles: nil];
      [alert show];
   }];
}

-(IBAction)updateScore:(id)sender {
   [self updateScore:200 forLeaderboardID:@"tutorialsPoint"];
}

-(IBAction)showLeaderBoard:(id)sender {
   GKLeaderboardViewController *leaderboardViewController =
   [[GKLeaderboardViewController alloc] init];
   leaderboardViewController.leaderboardDelegate = self;
   [self presentModalViewController:
   leaderboardViewController animated:YES];
}

#pragma mark - Gamekit delegates
- (void)leaderboardViewControllerDidFinish:
(GKLeaderboardViewController *)viewController {
   [self dismissModalViewControllerAnimated:YES];
}
@end

Production

Lorsque nous exécutons l'application, nous obtenons la sortie suivante -

Lorsque nous cliquons sur "Afficher le tableau de classement", nous obtenons un écran similaire au suivant -

Lorsque nous cliquons sur "mettre à jour le score", le score sera mis à jour dans notre tableau des leaders et nous recevrons une alerte comme indiqué ci-dessous -

Les storyboards sont introduits dans iOS 5. Lorsque nous utilisons des storyboards, notre objectif de déploiement doit être 5.0 ou supérieur. Les storyboards nous aident à créer tous les écrans d'une application et à interconnecter les écrans sous une seule interface MainStoryboard.storyboard. Cela aide également à réduire le codage des contrôleurs de vue poussant / présentant.

Étapes impliquées

Step 1 - Créer un single view application et assurez-vous de sélectionner storyboard case à cocher lors de la création de l'application.

Step 2 - Sélectionnez MainStoryboard.storyboardoù vous pouvez trouver un contrôleur de vue unique. Ajoutez un autre contrôleur de vue et mettez à jour les contrôleurs de vue comme indiqué ci-dessous.

Step 3- Connectons maintenant les deux contrôleurs de vue. Cliquez avec le bouton droit sur le bouton "Afficher modal" et faites-le glisser vers le contrôleur de vue droit dans le contrôleur de vue du côté gauche comme indiqué ci-dessous.

Step 4 - Sélectionnez modal parmi les trois options affichées comme indiqué ci-dessous.

Step 5 - Mettre à jour ViewController.h comme suit -

#import <UIKit/UIKit.h>

@interface ViewController : UIViewController

-(IBAction)done:(UIStoryboardSegue *)seque;

@end

Step 6 - Mettre à jour ViewController.m comme suit -

#import "ViewController.h"

@interface ViewController ()
@end

@implementation ViewController

- (void)viewDidLoad {
   [super viewDidLoad];	
}

- (void)didReceiveMemoryWarning {
   [super didReceiveMemoryWarning];
   // Dispose of any resources that can be recreated.
}

-(IBAction)done:(UIStoryboardSegue *)seque {
   [self.navigationController popViewControllerAnimated:YES];
}

@end

Step 7 - Sélectionnez MainStoryboard.storyboard et cliquez avec le bouton droit sur le bouton Quitter dans le contrôleur de vue de droite, sélectionnez terminé et connectez-vous avec le bouton de retour comme indiqué ci-dessous.

Production

Lorsque nous exécutons l'application dans un iPhone appareil, nous obtiendrons la sortie suivante -

Lorsque nous sélectionnons "show modal", nous obtiendrons la sortie suivante -

Les mises en page automatiques ont été introduites dans iOS 6.0.Lorsque nous utilisons des dispositions automatiques, notre objectif de déploiement doit être 6.0 et supérieur. Les mises en page automatiques nous aident à créer des interfaces qui peuvent être utilisées pour plusieurs orientations et plusieurs appareils.

But de notre exemple

Nous ajouterons deux boutons qui seront placés à une certaine distance du centre de l'écran. Nous allons également essayer d'ajouter un champ de texte redimensionnable qui sera placé à une certaine distance au-dessus des boutons.

Notre approche

Nous ajouterons un champ de texte et deux boutons dans le code ainsi que leurs contraintes. Les contraintes de chaque élément de l'interface utilisateur seront créées et ajoutées à la super vue. Nous devrons désactiver le redimensionnement automatique pour chacun des éléments de l'interface utilisateur que nous ajoutons afin d'obtenir le résultat souhaité.

Étapes impliquées

Step 1 - Créez une application simple basée sur la vue.

Step 2 - Nous n'éditerons que ViewController.m et c'est comme suit -

#import "ViewController.h"

@interface ViewController ()
@property (nonatomic, strong) UIButton *leftButton;
@property (nonatomic, strong) UIButton *rightButton;
@property (nonatomic, strong) UITextField *textfield;

@end
@implementation ViewController

- (void)viewDidLoad {
   [super viewDidLoad];
   UIView *superview = self.view;

   /*1. Create leftButton and add to our view*/
   self.leftButton = [UIButton buttonWithType:UIButtonTypeRoundedRect];
   self.leftButton.translatesAutoresizingMaskIntoConstraints = NO;
   [self.leftButton setTitle:@"LeftButton" forState:UIControlStateNormal];
   [self.view addSubview:self.leftButton];

   /* 2. Constraint to position LeftButton's X*/
   NSLayoutConstraint *leftButtonXConstraint = [NSLayoutConstraint 
   constraintWithItem:self.leftButton attribute:NSLayoutAttributeCenterX 
   relatedBy:NSLayoutRelationGreaterThanOrEqual toItem:superview attribute:
   NSLayoutAttributeCenterX multiplier:1.0 constant:-60.0f];

   /* 3. Constraint to position LeftButton's Y*/
   NSLayoutConstraint *leftButtonYConstraint = [NSLayoutConstraint 
   constraintWithItem:self.leftButton attribute:NSLayoutAttributeCenterY 
   relatedBy:NSLayoutRelationEqual toItem:superview attribute:
   NSLayoutAttributeCenterY multiplier:1.0f constant:0.0f];

   /* 4. Add the constraints to button's superview*/
   [superview addConstraints:@[ leftButtonXConstraint,
   leftButtonYConstraint]];

   /*5. Create rightButton and add to our view*/
   self.rightButton = [UIButton buttonWithType:UIButtonTypeRoundedRect];
   self.rightButton.translatesAutoresizingMaskIntoConstraints = NO;
   [self.rightButton setTitle:@"RightButton" forState:UIControlStateNormal];
   [self.view addSubview:self.rightButton];

   /*6. Constraint to position RightButton's X*/
   NSLayoutConstraint *rightButtonXConstraint = [NSLayoutConstraint 
   constraintWithItem:self.rightButton attribute:NSLayoutAttributeCenterX 
   relatedBy:NSLayoutRelationGreaterThanOrEqual toItem:superview attribute:
   NSLayoutAttributeCenterX multiplier:1.0 constant:60.0f];

   /*7. Constraint to position RightButton's Y*/
   rightButtonXConstraint.priority = UILayoutPriorityDefaultHigh;
   NSLayoutConstraint *centerYMyConstraint = [NSLayoutConstraint 
   constraintWithItem:self.rightButton attribute:NSLayoutAttributeCenterY 
   relatedBy:NSLayoutRelationGreaterThanOrEqual toItem:superview attribute:
   NSLayoutAttributeCenterY multiplier:1.0f constant:0.0f];
   [superview addConstraints:@[centerYMyConstraint,
   rightButtonXConstraint]];

   //8. Add Text field
   self.textfield = [[UITextField alloc]initWithFrame:
   CGRectMake(0, 100, 100, 30)];
   self.textfield.borderStyle = UITextBorderStyleRoundedRect;
   self.textfield.translatesAutoresizingMaskIntoConstraints = NO;
   [self.view addSubview:self.textfield];

   //9. Text field Constraints
   NSLayoutConstraint *textFieldTopConstraint = [NSLayoutConstraint 
   constraintWithItem:self.textfield attribute:NSLayoutAttributeTop 
   relatedBy:NSLayoutRelationGreaterThanOrEqual toItem:superview 
   attribute:NSLayoutAttributeTop multiplier:1.0 constant:60.0f];
   NSLayoutConstraint *textFieldBottomConstraint = [NSLayoutConstraint 
   constraintWithItem:self.textfield attribute:NSLayoutAttributeTop 
   relatedBy:NSLayoutRelationGreaterThanOrEqual toItem:self.rightButton 
   attribute:NSLayoutAttributeTop multiplier:0.8 constant:-60.0f];
   NSLayoutConstraint *textFieldLeftConstraint = [NSLayoutConstraint 
   constraintWithItem:self.textfield attribute:NSLayoutAttributeLeft 
   relatedBy:NSLayoutRelationEqual toItem:superview attribute:
   NSLayoutAttributeLeft multiplier:1.0 constant:30.0f];
   NSLayoutConstraint *textFieldRightConstraint = [NSLayoutConstraint 
   constraintWithItem:self.textfield attribute:NSLayoutAttributeRight 
   relatedBy:NSLayoutRelationEqual toItem:superview attribute:
   NSLayoutAttributeRight multiplier:1.0 constant:-30.0f];
   [superview addConstraints:@[textFieldBottomConstraint ,
   textFieldLeftConstraint, textFieldRightConstraint, 
   textFieldTopConstraint]];
}

- (void)didReceiveMemoryWarning {
   [super didReceiveMemoryWarning];
   // Dispose of any resources that can be recreated.
}
@end

Points à noter

Dans les étapes marquées 1, 5 et 8, nous avons simplement ajouté par programme deux boutons et un champ de texte respectivement.

Dans le reste des étapes, nous avons créé des contraintes et ajouté ces contraintes aux super vues respectives, qui sont en fait des auto-vues. Les contraintes de l'un des boutons de gauche sont comme indiqué ci-dessous -

NSLayoutConstraint *leftButtonXConstraint = [NSLayoutConstraint 
constraintWithItem:self.leftButton attribute:NSLayoutAttributeCenterX 
relatedBy:NSLayoutRelationGreaterThanOrEqual toItem:superview attribute:
NSLayoutAttributeCenterX multiplier:1.0 constant:-60.0f];

Nous avons constraintWithItem et toItem qui décident entre quels éléments d'interface utilisateur nous créons la contrainte. L'attribut décide sur quelle base les deux éléments sont liés. "relatedBy" décide de l'effet des attributs entre les éléments. Le multiplicateur est le facteur de multiplication et la constante sera ajoutée au multiplicateur.

Dans l'exemple ci-dessus, le X de leftButton est toujours supérieur ou égal à -60 pixels par rapport au centre de la super vue. De même, d'autres contraintes sont définies.

Production

Lorsque nous exécutons l'application, nous obtenons la sortie suivante sur le simulateur iPhone -

Lorsque nous changeons l'orientation du simulateur en paysage, nous obtiendrons la sortie suivante -

Lorsque nous exécutons la même application sur le simulateur iPhone 5, nous obtiendrons la sortie suivante -

Lorsque nous changeons l'orientation du simulateur en paysage, nous obtiendrons la sortie suivante -

Twitter a été intégré dans iOS 5.0 et Facebook a été intégré dans iOS 6.0. Notre tutoriel se concentre sur l'utilisation des classes fournies par Apple et les cibles de déploiement pour Twitter et Facebook sont respectivement iOS 5.0 et iOS 6.0.

Étapes impliquées

Step 1 - Créez une application simple basée sur la vue.

Step 2 - Sélectionnez votre fichier de projet, puis sélectionnez targets puis ajoutez Social.framework et Accounts.framework dans choose frameworks.

Step 3 - Ajoutez deux boutons nommés facebookPost et twitterPost et créez des ibActions pour eux.

Step 4 - Mettre à jour ViewController.h comme suit -

#import <Social/Social.h>
#import <Accounts/Accounts.h>
#import <UIKit/UIKit.h>

@interface ViewController : UIViewController

-(IBAction)twitterPost:(id)sender;
-(IBAction)facebookPost:(id)sender;

@end

Step 5 - Mettre à jour ViewController.m comme suit -

#import "ViewController.h"

@interface ViewController ()
@end

@implementation ViewController

- (void)viewDidLoad {
   [super viewDidLoad];
}

- (void)didReceiveMemoryWarning {
   [super didReceiveMemoryWarning];
   // Dispose of any resources that can be recreated.
}

-(IBAction)facebookPost:(id)sender {
   SLComposeViewController *controller = [SLComposeViewController 
   composeViewControllerForServiceType:SLServiceTypeFacebook];
   SLComposeViewControllerCompletionHandler myBlock = 
      ^(SLComposeViewControllerResult result){
      
      if (result == SLComposeViewControllerResultCancelled) {
         NSLog(@"Cancelled");
      } else {
         NSLog(@"Done");
      }
      [controller dismissViewControllerAnimated:YES completion:nil];
   };
   controller.completionHandler = myBlock;

   //Adding the Text to the facebook post value from iOS
   [controller setInitialText:@"My test post"];

   //Adding the URL to the facebook post value from iOS
   [controller addURL:[NSURL URLWithString:@"http://www.test.com"]];

   //Adding the Text to the facebook post value from iOS
   [self presentViewController:controller animated:YES completion:nil];
}

-(IBAction)twitterPost:(id)sender {
   SLComposeViewController *tweetSheet = [SLComposeViewController 
   composeViewControllerForServiceType:SLServiceTypeTwitter];
   [tweetSheet setInitialText:@"My test tweet"];
   [self presentModalViewController:tweetSheet animated:YES];
}
@end

Production

Lorsque nous exécutons l'application et cliquons sur facebookPost, nous obtiendrons la sortie suivante -

Lorsque nous cliquons sur twitterPost, nous obtenons la sortie suivante -

La gestion de la mémoire sous iOS était initialement non-ARC (Automatic Reference Counting), où nous devons conserver et libérer les objets. Maintenant, il prend en charge ARC et nous n'avons pas à conserver et à libérer les objets. Xcode prend en charge le travail automatiquement au moment de la compilation.

Problèmes de gestion de la mémoire

Selon la documentation Apple, les deux principaux problèmes de gestion de la mémoire sont:

  • Libération ou écrasement des données encore en cours d'utilisation. Cela provoque une corruption de la mémoire et entraîne généralement le plantage de votre application ou, pire encore, des données utilisateur corrompues.

  • Ne pas libérer de données qui ne sont plus utilisées entraîne des fuites de mémoire. Lorsque la mémoire allouée n'est pas libérée même si elle ne sera plus jamais utilisée, on parle de fuite de mémoire. Les fuites amènent votre application à utiliser des quantités de mémoire de plus en plus importantes, ce qui peut à son tour entraîner de mauvaises performances du système ou (sous iOS) l'arrêt de votre application.

Règles de gestion de la mémoire

  • Nous possédons les objets que nous créons et nous devons ensuite les libérer lorsqu'ils ne sont plus nécessaires.

  • Utilisez Conserver pour acquérir la propriété d'un objet que vous n'avez pas créé. Vous devez également libérer ces objets lorsqu'ils ne sont pas nécessaires.

  • Ne relâchez pas les objets que vous ne possédez pas.

Gestion de la mémoire dans ARC

Vous n'avez pas besoin d'utiliser la version et la conservation dans ARC. Ainsi, tous les objets du contrôleur de vue seront libérés lorsque le contrôleur de vue est supprimé. De même, les sous-objets de tout objet seront libérés lorsqu'ils seront libérés. Notez que si d'autres classes ont une référence forte à un objet d'une classe, alors la classe entière ne sera pas libérée. Il est donc recommandé d'utiliser des propriétés faibles pour les délégués.

Outils de gestion de la mémoire

Nous pouvons analyser l'utilisation de la mémoire à l'aide d'instruments de l'outil Xcode. Il comprend des outils tels que le moniteur d'activité, les allocations, les fuites, les zombies, etc.

Étapes d'analyse des allocations de mémoire

Step 1 - Ouvrez une application existante.

Step 2 - Sélectionnez Produit puis Profil comme indiqué ci-dessous.

Step 3 - Sélectionnez Allocations dans l'écran suivant ci-dessous et sélectionnez Profil.

Step 4 - Nous verrons l'allocation de mémoire pour différents objets comme indiqué ci-dessous.

Step 5 - Vous pouvez basculer entre les contrôleurs de vue et vérifier si la mémoire est libérée correctement.

Step 6 - De même, au lieu d'allocations, nous pouvons utiliser Activity Monitor pour voir la mémoire globale allouée à l'application.

Step 7 - Ces outils nous aident à accéder à notre consommation de mémoire et à localiser les endroits où des fuites éventuelles se sont produites.

Nous pouvons commettre des erreurs lors du développement d'une application, ce qui peut conduire à différents types d'erreurs. Afin de corriger ces erreurs ou bogues, nous devons déboguer l'application.

Sélection d'un débogueur

Xcode a deux débogueurs à savoir, les débogueurs GDB et LLDB. GDB est sélectionné par défaut. LLDB est un débogueur qui fait partie du projet de compilateur open source LLVM. Vous pouvez changer le débogueur par l'option "éditer les schémas actifs".

Comment trouver des erreurs de codage?

Pour localiser les erreurs liées au codage, vous devez créer votre application qui compilera le code. Dans le cas où le code contient des erreurs, le compilateur affichera tous les messages, erreurs et avertissements avec leurs raisons possibles.

Vous pouvez cliquer sur Produit, puis sur Analyser pour localiser les problèmes possibles dans une application.

Définir des points d'arrêt

Les points d'arrêt nous aident à connaître les différents états de nos objets d'application, ce qui nous aide à identifier de nombreuses failles, y compris des problèmes logiques. Il suffit de cliquer sur le numéro de ligne pour créer un point d'arrêt. Pour supprimer un point d'arrêt, cliquez simplement dessus et faites-le glisser. La capture d'écran suivante montre comment définir un point d'arrêt -

Lorsque nous exécutons l'application et sélectionnons le bouton playVideo, l'application se mettra en pause au numéro de ligne où nous avions défini le point d'arrêt. Cela nous laisse le temps d'analyser l'état de l'application. Lorsque le point d'arrêt est déclenché, nous obtiendrons une sortie comme indiqué ci-dessous.

Vous pouvez facilement identifier le thread qui a déclenché le point d'arrêt. En bas, vous pouvez voir des objets comme self, sender et ainsi de suite, qui contiennent les valeurs des objets correspondants et nous pouvons développer certains de ces objets, et voir quel est l'état de chacun de ces objets.

Pour continuer l'application, nous allons sélectionner le bouton Continuer (bouton le plus à gauche), dans la zone de débogage ci-dessous. Les autres options incluent l'entrée, la sortie et le franchissement.

Point d'arrêt d'exception

Nous avons également des points d'arrêt d'exception qui déclenchent l'arrêt d'une application à l'emplacement où l'exception se produit. Nous pouvons insérer des points d'arrêt d'exception en sélectionnant le bouton + après avoir sélectionné le navigateur de débogage. Vous obtiendrez la fenêtre suivante.

Ensuite, nous devons sélectionner Ajouter un point d'arrêt d'exception, qui affichera la fenêtre suivante.

Vous pouvez collecter plus d'informations sur le débogage et d'autres fonctionnalités Xcode à partir du guide de l'utilisateur Xcode 4 .