Ouvrir le menu principal

iGeneration

Recherche

Développeurs : d'iOS à Android

Anthony Nelzin-Santos

vendredi 05 août 2011 à 14:29 • 22

iPhone

Co-fondateur de Spotlight Mobile, Nick Farina a décidé de porter son application de micro-géolocalisation, Meridian [1.1.1 – US – Gratuit – Spotlight Mobile, Inc.], d'iOS vers Android. Ce faisant, il explique ce qu'il a apprécié dans le développement sur Android, et ce qu'il a moins apprécié, du point de vue d'un développeur iOS. skitched Farina a pris une décision dès le début du projet : puisqu'il code de manière native sur iOS, il n'a aucune raison de faire autrement sur Android. Il a donc décidé de ne pas utiliser d'outils de développement multiplateforme, de coller au plus près des canons d'interface Android, et de coder en Java. Une décision importante qui conditionne de nombreux choix. La première question a été celle du choix d'un IDE (environnement de développement intégré) : celui d'iOS est Xcode sur Mac, point — éditeur de code, SDK, outils de test, simulateurs, tout est inclus. Google fournit le SDK Android, le développeur ayant le choix de l'éditeur. Farina a pris le parti d'utiliser la solution recommandée, Eclipse, avec le plug-in ADT (Android Development Tools pour Eclipse). skitched « Vous allez tout simplement détester Eclipse. », assure Farina : « Vous allez brûler de haine envers lui comme un millier de soleils en furie [NdT : une phrase de développeurs en forme de référence à Cheers]. Il est lourd, et plus lourd encore que lourd […] ». Ce premier contact négatif doit cependant être surpassé pour découvrir la puissance de cet IDE monolithique : « un bon moyen de s'y retrouver dans Eclipse est de passer quelques heures, et je suis extrêmement sérieux à ce sujet, à bidouiller avec les centaines d'options, de cases à cocher et de petits bidules dans la section préférences. » Cette manière de se forcer à découvrir Eclipse, à comprendre sa logique, est le prix à payer pour développer plus facilement pour Android : « [Eclipse] va tout simplement coder à votre place ». Nick%20Farina%20-%20An%20iOS%20Developer%20Takes%20on%20Android
La version Objective-C.
Cette manière d'approcher les choses est en fait la clef, selon Farina, pour que le développement sous Android se passe dans les meilleures conditions possibles : plutôt que de partir avec des idées préconçues sur Eclipse ou Java, il faut comprendre comment Android utilise Eclipse et Java, pourquoi, et s'y tenir. Ce serait la manière la plus simple d'éviter de nombreuses sources de frustrations : « en général, les frameworks d'Android sont plutôt bien conçus et cohérents, et les API s'intègrent parfaitement au langage Java. En fait, […] notre application a presque la même structure de classes sur Android et sur iOS. Le code lui-même est incroyablement similaire sur les deux versions ». skitched
La version Java.
L'émulateur Android, destiné à tester les applications, n'a pas les faveurs de Farina : comme tous les émulateurs, il est lent. Le simulateur iOS a l'inconvénient de passer par une compilation x86/64 (Intel x86 et non ARM, ce qui signifie que vous pourrez passer à côté de bogues qui seront présents dans l'application sur un appareil réel), mais a l'énorme avantage d'être rapide. Selon lui, la solution est simple : il suffit de tester l'application sur un smartphone, voire sur plusieurs smartphones aux configurations différentes. Le nombre de configurations possibles est évidemment beaucoup plus grand avec Android, mais il faut de toute manière tester son application iOS sur plusieurs profils (iPod touch, iPhone, génération actuelle, génération précédente), donc autant se plier à l'exercice sur toutes les plateformes. skitched Farina critique aussi bien iOS qu'Android en matière de création d'interfaces. Côté iOS, Interface Builder n'est pas une solution miracle, et le développement entièrement personnalisé est parfois particulièrement complexe pour des choses finalement très simples. Même chose côté Android : on ne peut utiliser seulement Java ou seulement le système de layouts XML. Il y a cependant en matière d'animations une différence fondamentale entre les deux OS : Android a été conçu comme un concurrent de Windows Mobile et BlackBerry OS, et reprend leur logique de rendu logiciel, ce qui permet de se passer d'une puce graphique très puissante. iOS au contraire a été conçu avec l'accélération OpenGL en tête, et le système similaire dans Android 3.0 est limité. Dans un OS comme dans l'autre, il faut donc à nouveau se poser la question de la pertinence des choix techniques : suis-je près à perdre un peu de fluidité dans cette vue contre une manière un peu plus simple de coder (iOS) ? est-ce que je dois utiliser le rendu CPU à cet endroit, avec le risque de l'occuper un peu trop parce que pendant ce temps il doit aussi parser mon flux (Android) ? skitched Bref, Farina essaye de faire passer un message simple : si l'on veut s'éviter bien des peines, sur iOS comme sur Android, il faut prendre du recul, peser ses choix techniques, comprendre la philosophie des plateformes. Choses qui ne peuvent être accomplies avec des frameworks multiplateforme. Mais tout cela demande des compétences, et du temps — donc de l'argent : le portage de Meridian a pris quatre mois. Tous les développeurs n'ont pas ce luxe.

Rejoignez le Club iGen

Soutenez le travail d'une rédaction indépendante.

Rejoignez la plus grande communauté Apple francophone !

S'abonner

Meta tente tout son possible pour bloquer le livre d’une ex-employée

13/03/2025 à 23:00

• 9


Spotify, « l'une des pires choses arrivées aux musiciens » ?

13/03/2025 à 21:00

• 45


Test de l'Insta360 Flow 2 Pro : le meilleur stabilisateur pour iPhone compatible DockKit (encore une fois)

13/03/2025 à 20:30

• 6


Le nouveau Siri montré en 2024 n'aura été qu'une fable et une fumisterie

13/03/2025 à 18:19

• 114


Skich Store, une nouvelle boutique tierce de jeux pour iPhone

13/03/2025 à 16:00

• 1


Incogni : protégez vos données et évitez les arnaques par SMS en toute simplicité 📍

13/03/2025 à 15:54


WebKit : le régulateur britannique accuse Apple de freiner l’innovation dans les navigateurs mobiles

13/03/2025 à 14:00

• 42


Les promotions sur les iPad Air M2 font de l'ombre aux nouveaux M3

13/03/2025 à 11:45

• 32


Tusk présente des optiques et des filtres pour filmer avec l’iPhone comme à Hollywood

13/03/2025 à 11:00

• 7


Le HomePod à écran entrerait toujours en production cet été

13/03/2025 à 07:23

• 7


Chiffrement d’iCloud au Royaume-Uni : l’audience demandée par Apple se tiendra vendredi

12/03/2025 à 22:15

• 3


iOS 19, un ravalement de façade pour cacher les retards ?

12/03/2025 à 20:45

• 70


Sonos annule son projet Pinewood, concurrent de l’Apple TV

12/03/2025 à 19:45

• 30


Il y a bien un risque d'incendie avec certains Pixel 4a selon les autorités australiennes

12/03/2025 à 19:00

• 10


iRobot présente les aspirateurs-robots Roomba de la dernière chance

12/03/2025 à 17:30

• 23


La fin des iPhone avec un écran LCD est un problème pour ceux qui sont sensibles au scintillement des écrans OLED

12/03/2025 à 16:00

• 38