IPhone

IPhone

Sortie de l’application mobile Xebia pour iPhone et iPad

Sortie de l’application mobile Xebia pour iPhone et iPad

appli-XebiaC’est avec une joie non dissimulée que je vous annonce aujourd’hui la sortie de l’application Xebia pour iPhone et iPad. Publiée il y a tout juste quelques jours sur l’App Store, l’application vous propose de réunir au sein d’une seule et unique interface l’ensemble des flux d’informations de Xebia, ainsi que des bonus agiles qui viendront s’étoffer avec le temps.

L’application est optimisée pour iOS 7, mais fonctionne parfaitement sur iOS 6.

Où trouver l’application ?

Vous pouvez retrouver l’application mobile Xebia sur son mini-site dédié à l’adresse suivante: http://xebia-app.com, ou bien directement sur l’App Store.

Les fonctionnalités

Au menu des réjouissances :

  • L’application Xebia vous permettra de consulter l’ensemble des articles du blog dans un format spécialement adapté aux mobiles et tablettes Apple. En particulier, la mise en page des articles prend en charge la mise en forme des codes sources afin de rendre la lecture plus agréable.
  • Vous pourrez également retrouver les articles du blog Xebia grâce à leur tag ou encore leur catégorie. 
  • Si vous n’êtes pas un aficionados de Twitter ou déjà abonné à notre timeline, vous pourrez tout de même suivre les tweets de Xebia en consultant les dernières infos en un clin d’oeil sur un écran dédié.
  • En bon craftsman et agiliste convaincu, vous pourrez retrouver l’ensemble du deck de cartes Xebia Essentials, et éplucher leurs conseils avisés ! 
  • Par ailleurs, il sera possible de consulter les dates des prochains Tech Events et de visionner ceux déjà passés si vous les avez manqués. 
  • Enfin, si vous souhaitez être informé en premier de la sortie d’un nouvel article ou bien encore du dernier Tech-Event, sachez que vous pourrez être notifié en push à peine quelques instants après publication !

Du côté de la technique

Côté client

L’application Xebia est une appli native basée sur une stack Open-Source (AFNetworking, DTCoreText, MBProgressHUD, ParseKit, ShareKit, PKRevealController, SDWebImage, SVPullToRefresh, TTTAttributedLabel, et bien d’autres…).

Elle est construite dans le Cloud grâce à Travis-CI, et est disponible en Open-Source sur GitHub.

Côté tooling, elle s’appuie sur XCTool, l’outil de build de Facebook, ainsi que CocoaPods pour la partie gestion de dépendances.

Côté serveur

L’application mobile Xebia s’appuie sur un backend Node.js qui sert l’ensemble des informations via une API REST spécialement développée pour les besoins de l’application. Les différents flux d’informations sont synchronisés régulièrement dans le but de les stocker en cache et de les resservir dans un format adapté, avec des performances optimales. C’est par ailleurs ce même backend qui a la charge de servir les notifications de l’application mobile via l’APNS d’Apple.

Le fruit du travail sur le backend Node.js est disponible sous forme d’une présentation couverte lors de l’Open-XKE que vous pouvez retrouver à l’adresse suivante: http://akinsella.github.io/node-overview/

Quid d’une application mobile Xebia pour Android ? 

L’application mobile Xebia pour iPhone et iPad a été développée par mes soins dans sa première version dans le but de partager la passion de Xebians. Sachez qu’il n’existe pas actuellement d’équivalent à cette application pour Android, mais vous pouvez d’ores et déjà retrouver l’application Xebia Essentials de Gautier Mechling (Nilhcem) sur le Play Store de Google.

Feedback

Bien entendu, tout feedback est le bienvenu. N’hésitez pas à partager vos idées d’améliorations, anomalies rencontrées ou bien encore les fonctionnalités que vous attendez !

Code source de l’application Clock pour iPhone proposé dans un tutoriel OVH

Code source de l’application Clock pour iPhone proposé dans un tutoriel OVH

Il y a trois mois, OVH proposait sur son site un tutoriel aidant à développer sa première application iPhone. Le tutoriel en question avait pour objectif le développement d’une application permettant d’afficher l’heure au centre de l’écran sur un fond noir. Rien d’extraordinaire de premier abord, mais la complexité de prise en main de l’IDE d’Apple (XCode) donne à ce tutoriel son intérêt puisqu’il permet de démarrer en douceur en se familiarisant avec différentes de ses fonctionnalités.

Malheureusement, le code source du tutoriel n’est pas fourni, je vous propose donc de le retrouver sur GitHub, et de le consulter tout au long de la lecture du tutoriel.

L’url du repo GitHub: https://github.com/akinsella/clock

L’url du tutoriel sur le site d’OVH: http://www.ovh.com/fr/all/a494.creer_sa_premiere_application_iphone

  • Le fichier ‘ViewController.h’
//
//  ViewController.h
//  Clock
//
//  Created by Alexis Kinsella on 09/06/12.
//  Copyright (c) 2012 __MyCompanyName__. All rights reserved.
//

#import <uikit /UIKit.h>

@interface ViewController : UIViewController {
    UILabel *hoursAndMinutesLabel;
    UILabel *secondsLabel;
}

@property (nonatomic, retain) IBOutlet UILabel *hoursAndMinutesLabel;
@property (nonatomic, retain) IBOutlet UILabel *secondsLabel;

@property (nonatomic, retain) NSDateFormatter *dateFormatter;
@property (nonatomic, retain) NSTimer *walkTimer;



- (void)updateClock;
   
@end
  • Le fichier ‘ViewController.m’
//
//  ViewController.m
//  Clock
//
//  Created by Alexis Kinsella on 09/06/12.
//  Copyright (c) 2012 __MyCompanyName__. All rights reserved.
//

#import "ViewController.h"

@implementation ViewController

@synthesize hoursAndMinutesLabel;
@synthesize secondsLabel;
@synthesize walkTimer;
@synthesize dateFormatter;

-(void)updateClock {
    NSDate *currentDate = [[NSDate alloc] init];
   
    [self.dateFormatter setDateFormat:@"hh:mm"];
    self.hoursAndMinutesLabel.text = [self.dateFormatter stringFromDate:currentDate];
    [self.dateFormatter setDateFormat:@"ss"];
    self.secondsLabel.text = [self.dateFormatter stringFromDate:currentDate];
   
    // ARC forbids explicits release  
    // [currentDate release];
}

- (void) viewWillAppear:(BOOL)animated {
    NSTimer *timer = [NSTimer timerWithTimeInterval:1.0
                                             target:self
                                           selector:@selector(updateClock)
                                           userInfo:nil repeats:YES];
    [self setWalkTimer: timer];
   
    [[NSRunLoop currentRunLoop] addTimer:timer forMode:NSDefaultRunLoopMode];
   
    [self updateClock];
   
    [super viewWillAppear:animated];
}

- (void) viewDidDisappear:(BOOL)animated {
    [[self walkTimer] invalidate];
    [self setWalkTimer:nil];
}


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

    NSDateFormatter *df = [[NSDateFormatter alloc] init];
   
    [self setDateFormatter: df];
   
    // [dateFormatter release];
   
    [self.dateFormatter setLocale:[NSLocale autoupdatingCurrentLocale]];
}

- (void)viewDidUnload
{
    [super viewDidUnload];
   
    self.dateFormatter = nil;

    // Release any retained subviews of the main view.    
    self.hoursAndMinutesLabel = nil;
    self.secondsLabel = nil;
}

- (BOOL)shouldAutorotateToInterfaceOrientation:(UIInterfaceOrientation)interfaceOrientation
{
    return YES;
}

@end
  • Le fichier ‘AppDelegate.m’
//
//  AppDelegate.m
//  Clock
//
//  Created by Alexis Kinsella on 09/06/12.
//  Copyright (c) 2012 __MyCompanyName__. All rights reserved.
//

#import "AppDelegate.h"

#import "ViewController.h"

@implementation AppDelegate

@synthesize window = _window;
@synthesize viewController = _viewController;

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

- (void)applicationWillResignActive:(UIApplication *)application
{
    // Sent when the application is about to move from active to inactive state. This can occur for certain types of temporary interruptions (such as an incoming phone call or SMS message) or when the user quits the application and it begins the transition to the background state.
    // Use this method to pause ongoing tasks, disable timers, and throttle down OpenGL ES frame rates. Games should use this method to pause the game.
}

- (void)applicationDidEnterBackground:(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:.
}

@end

Android, retour d’impressions

Android, retour d’impressions

Après quelques semaines d’utilisation, je commence à me faire une idée des capacités de la plateforme et de ses qualités ert défauts! Et il y a de quoi parler, à commencer par l’émulateur. Ce dernier m’a semblé de prime abord de très bonne facture, mais il s’impose vite la conclusion suivante: l’émulateur propose des performances catastrophiques! Le PC sur lequel je développe est un portable Athlon XP 3000+, ok il n’est pas tout neuf, mais cela reste honorable, étant donnée que l’ordinateur dispose de 1,5Go de RAM et d’un disque 5400 tpm, les performances restent donc correctes. Cependant, dès que l’émulateur est lancé, le pourcentage d’utilisation CPU monte à 95 % très facilement et le pc ne répond pas vraiment bien (C’est le moins qu’on puisse dire) . Ce qui me trouble le plus reste les performances des programmes exécutés sur l’émulateur. Je ne suis pas arrivé à des performances correctes sans faire des concessions importantes sur le design applicatif et encore avec difficulté.

Je comprend l’angoument autour de la plateforme, mais également pourquoi on voit si peu de programmes disponibles (Je ne pense pas que ce soit lié au concour Android de Google uniquement). La source du problème n’est pas tant dans la plateforme que dans les performances de l’émulateur qui ont de quoi dégouter du développement sur Android et pousser à explorer les progrès fait sur J2ME et les JVM MIDP de Sony et Nokia qui semblent d’ailleurs très intéressant.

Même si les constructeurs proposent des machines performantes, il va falloir que Google fasse un effort sur son émulateur pour proposer des performances acceptables sur son émulateur. Dans le cas contraire, il se pourrait que certains développeurs soient rebutés. Pour l’instant j’en fait parti.

Autre bémol et de taille: c’est l’obscurantisme des API de la plateforme et le peu d’explications qu’on peut trouver. On est bien trop amené à essayer de deviner comment utiliser les API.  Les API étant complètement nouvelles, elles obligent le développeur à un apprentissage nouveau. De plus les API sont complexes et accrobatiques à utiliser. Souvent élégantes dans le concept, il faut tout de même avoir de bonnes notions de développement pour les exploiter correctement.

j’appuye cette petit analyse sur un retour d’expérience réel , j’ai essayé d’exploiter des API REST simples et cela me pose trop de difficultés pour en rendre le développement sympathique: j’ai plus tendance à m’arracher les cheveux entre la complexité des API et les performances de l’émulateur.

Gageons que la plateforme est encore jeune, et des best practices Android simples et efficaces  apparaitrons, mais pour le moment ce n’est pas la panacé. Et un travail urgent est à faire sur les performances de l’émulateur. Pour am part, le constat est simple: j’arrêtele développement Android ou bien j’achète un nouveau PC…

Un dernier mot: Je suis en 1280 et l’émulateur prend une grande partie de mon écran! C’est quand même assez embêtant. Google est capable de penser des API complexe, mais pas à un détail aussi simple.

A noter: les JVM de Sony et de Nokia embarquent aujourd’hui tout un ensemble d’extensions intéressantes, sur lesquelles je reviendrais un autre fois, mais qui permettent de développer facilement aujourd’hui des applications intéressantes sans vraiment de difficultés particulières. Les problématiques d’antant n’existent plus vraiment sur MIDP aujourd’hui.

Depuis quelques jours, j’ai un W910 de Sony, et il faut dire que je suis impressionné par les progrès effectués et la diversité des API MIDP proposées (Sensor API, Content handler API, MMAPI, Bluetooth API, …). De plus, les JVM sony, par exemple, en sont à leur 8ème génération, ce qui en fait un choix de plateforme proposant de nombreux avantages (performances, stabilité, support d’API étendues, …) et un choix pour le moment bien plus sûr qu’Android.

Ma conclusion, est donc la suivante: comme de nombreuses personnes, je suis rentré dans le jeu des Buzz (IPhone /Android), mais rien ne vaut les valeurs sûres telles que MIDP ou le DotNet CF ou bien la plateforme de dev Symbian ou Palm. Attendons donc quelques mois que la plateforme Android murisse et que les premiers modèles sortent avant de trop en dire sur Android. N’oublions pas, entre autre, pour le moment qu’Android repose sur une plateforme Linux qui n’est compatible ni Symbian, ni Windows Mobile, ni Palm. Le marché est de ce fait extrêmement restreint. De la même manière que l’Iphone, le marché Android risque de rester une niche un certain temps. L’arrivée de l’IPhone et d’Android ne font que segmenter le marché et rendre la tâche plus difficile pour les sociétés travaillant dans le domaine de la mobilité. Il existe au bas mot 6 plateformes importantes: Midp, Windows Mobile, Symbian, Palm, l’IPhone et Android!

N’hésitez pas à faire part de vos impressions!

Eh hop, une bonne claque à MAC et l’IPhone !

Eh hop, une bonne claque à MAC et l’IPhone !

Je pense que cette vidéo va satisfaire les plus curieux ainsi que les plus septiques d’entre vous au sujet de la plateforme de Google, il n’y a pas vraiment besoin de rajouter de commentaires, mais pour résumer on y voit en vrac:

  • 2 modèles de téléphones compatibles Androi, on dira que ça correspond à 2 profils de téléphons différents: un haut de gamme et un entrée de gamme.
  • du Google Map + l’application Google de visionnage en 3D photo des alentours
  • du jeu avec Quake en OpenGL
  • du browsing avec WebKit
  • quelques fonctionnalités système

On y voit également l’équipe d’Android qui présente les deux téléphones (le deuxième est impressionnant! C’est un prototype en plus …), ainsi la vision de Google en terme de mobilité, qui est de créer un système ouvert, tel que Linux l’a été pour le PC.

Pour ma part, je trouve que Google fait très fort, il propose tout ce que j’ai toujours attendu d’une plateforme de développement pour la mobilité. Et pourtant, j’en ai vu d’autres, j’ai donc de quoi comparer : PalmOS, SuperWaba, Compact Framework sur PocketPC, J2ME. Et pas une seule ne semble rivaliser avec ce que Google pourra offrir avec une plateforme comme Android.

Aujourd’hui les plateformes qui permettent de concurrencer Android sont des systèmes directement comme Windows Mobile 6, l’IPhone et Symbian + UIQ avec leur outils de développements, mais leur apprentissage ou leur prise en main n’est pas aisée, ni à la portée de tous.

Je me demande cependant ce qu’il en est de la capacité du système à prendre en charge les appels WebService, ainsi que la capacité du sytème à prendre en charge les API Web qui font aujourd’hui le Web 2.0 .

Android est là, et l’Iphone dans la place…

Android est là, et l’Iphone dans la place…

hello_world_8.pngC’est y est le SDK Google de la plateforme Android est disponible, vous pourrez le trouver à l’adresse suivante:

Pour ce que j’en ai lu pour le moment, je trouve le concept très intéressant, et Google fournit avec Android en quelques sortes un remplaçant au vieillissant J2ME avec son profil MIDP 2.


Plusieurs points positifs sont à noter:

  • Un environnement intégré à Eclipse!
  • Un emulateur de la plateforme.
  • Une API qui semble complète pour le faciliter le debug sur la plateforme.
  • Une base Java bien sûr :D

Il fallait s’en douter, les premiers sceptiques se plaignent déjà: entre autre de ne pas avoir d’accès natif à la plateforme (du moins pour le moment), qu’Android est trop ressemblant à J2ME, pas assez proche du matétiel, bla bla bla… Pour ma part, la programmation moderne ne nécessite pasde manipuler à outrance des ressources natives (peut-être une déformation de vision liée à l’uitlisation de Java). Il est plus intéressant être en mesure d’exploiter des ressources natives à travers des API exposées, et c’est sur ce point que j’attend Google: exposer la richesse du système sur lequel repose le téléphone à travers des API adaptées via leur SDK. S’ils répondent avec succès à ces besoins, il n’y a pas de raison que la plateforme ne soit pas un succès commercial.

Il semble que HTC ait déjà annoncé 3 téléphone compatible Android pour l’année 2008. Si HTC est de la partie, c’est déjà très bon signe! Pour ma part un GooglePhone de ce type me semble bien plus attirant qu’un IPhone tel qu’il existe aujourd’hui.

L’IPhone est un triste exemple de ce que risquerait de devenir la téléphonie:

  • Une téléphone exclusivement explotable sur un opérateur
  • Un téléphone limité logiciellement (pas de MMS, pas de Vidéo, des fonctionnalités générales très limitées, pas de support pour le moment de développement de logiciel)
  • Un téléphone dont les limitations matérielles sont inversement proportionnelle à l’ingéniosité de son interface graphique (GPS, 3G, Vidéo, APN 2MP, et j’en passe)
  • Un téléphone dont les fonctionnalités dépendent d’accords commerciaux : La vidéo avec YouTube, GoogleMap
  • Des forfaits hors de prix à cause de la gloutonnerie financière de MAC
  • Une faille de sécurité plus que douteuse, mais bien pratique pour créer un buzz de l’IPhone.

Un détail me chagrine quand même concernant l’IPhone … Pourquoi ne sortirait-il pas un nouveau firmware, au hasard vers février, qui permettrait à l’IPhone d’être le premier téléphone ‘Android’, en effet, on sait que MAC annonce une plateforme de développement pour l’IPhone en février 2008, l’IPhone repose bien sur un noyau BSD au MAC dérivé de BSD. Pourquoi pas après tout! Android correspond bien à ce que MAC souhaite proposer une plateforme de développement qui isole les ressources du téléphone du développeur par une couche intermédiaire.

L’IPhone… Un succès annoncé!

L’IPhone… Un succès annoncé!

Bien qu’on en entende parler un peu partout, et qu’on puisse trouver des infos ou bien des vidéos à tire larigot à propos « de vous savez quoi », je pense que visionner cette vidéo ne pourra pas faire de mal tant elle ramène les autres téléphones portables dans la préhistoire!

iphone_hero_20070621.jpg

http://www.apple.com/iphone/usingiphone/guidedtour.html

Je vous le dis le oup est entré dans la bergerie!

2 liens indispensables si vous voulez en savoir plus:

Sachez dans la foulée qu’un IPhone 3G pour l’Europe serait prévu. De plus, un IPhone 2G serait prévu pour début 2008, il proposerait entre autre du Wifi N, une puce GPS, et un meilleur objectif! Pas mal l’air de rien!