Quando qualcuno mi chiede che lavoro faccio e limito la mia risposta a un semplice "sviluppo app mobile" vedo le reazioni più disparate: c'è chi capisce al volo, chi mi guarda come fossi Einstein e chi invece chiede spiegazioni aggiuntive 🤔.
Effettivamente il termine inglese mobile mette i bastoni fra le ruote, ma l'alternativa sarebbe smartphone o tablet, quindi lo scoglio linguistico è inevitabile.
Fortunatamente, una volta afferrato il concetto, risulta facile capire di cosa sto parlando, dato che chiunque, ormai, sa come installare un'app sul proprio dispositivo.
Ottimo, quindi app e mobile li abbiamo smarcati ✅. Mentre sviluppo❓
Beh, facile: vuol dire realizzare! Ma cosa significa - precisamente - realizzare un app?
Vediamo cosa si nasconde dietro a questa parola, scoprendo insieme in cosa consiste un tipico processo di sviluppo app.
Fasi del processo di sviluppo app mobile
Il termine app è nato dall'abbreviazione di application, per identificare quelle applicazioni software pensate per girare su piccoli dispositivi portatili senza fili 📱.
Risulta quindi immediato pensare che per realizzarne una bastino dei programmatori, ma non è così. Essi coprono sicuramente un ruolo importante, ma le attività da svolgere richiedono competenze eterogenee:
- Analisi e pianificazione. Identificazione degli obiettivi che l'app deve raggiungere, delle funzionalità necessarie e pianificazione delle fasi successive.
- Progettazione. Definizione dell'architettura software dell'app e dei flussi utente.
- Design e prototipazione. Progettazione schermate, ideazione dello stile grafico ed eventuale generazione di prototipi interattivi.
- Sviluppo. Implementazione app ed eventuale backend server in cui sono centralizzati i dati.
- Testing. Controllo qualità tramite predisposizione di piani di test ed esecuzione degli stessi sia internamente che esternamente al team di sviluppo.
- Distribuzione. Configurazione e pubblicazione dell'app sugli store.
- Supporto ed evoluzione. Pubblicazione di aggiornamenti correttivi o evolutivi in base all'analisi dei dati di utilizzo misurazioni o nuove esigenze.
Hai più dubbi di prima? 😅
Proviamo ad aggiungere qualche dettaglio in più per ogni fase...
1. Analisi e pianificazione
La prima cosa da fare è sicuramente individuare quali sono gli obiettivi che l'app desidera raggiungere e in base ad essi definire il cosiddetto MVP (Minimum Viable Product), ovvero il Minimo Prodotto Vendibile che permetta di farlo.
In pratica si tratta di concentrarsi sulle funzionalità fondamentali e solo su di esse, eliminando tutto ciò che è superfluo, almeno in una prima versione dell'app.
Ora non resta che pianificare le fasi successive e mettersi all'opera.
2. Progettazione
Come per la costruzione di una casa, quando si lavora su un progetto software di sviluppo app mobile è essenziale gettare le fondamenta adeguate. Probabilmente è per questo che si usa il termine architettura software per indicare come è strutturato ogni componente dell'app e come è interconnesso agli altri.
I risultati di questa fase sono generalmente grafici e diagrammi di flusso che identificano principalmente due cose:
- Requisiti e caratteristiche tecniche dei vari moduli dell'app;
- Flussi utente che chiariscono come sia possibile raggiungere tutte le funzionalità dell'app.
Rimanendo sulla metafora architettonica si tratta di definire struttura, planimetria e materiali della casa e di posizionare porte, finestre e scale in modo che sia possibile accedere comodamente a tutte le stanze 🏠.
3. Design e prototipazione
Quando si parla di design, in informatica, generalmente si usano gli acronimi UX e UI, ma cosa significano?
UX sta per User Experience - Esperienza Utente - ovvero l'insieme di percezioni e reazioni vissute dall'utente quando entra in contatto con l'applicazione. Si tratta di un concetto molto ampio che può spaziare dalla fase di scoperta dell'app, alla fase di utilizzo effettivo analizzandone efficienza e facilità e a seconda delle esigenze può essere affrontato con diversi livelli di profondità.
UI sta per User Interface - Interfaccia Utente - ovvero l'aspetto grafico che permette all'utente di interagire con le funzionalità dell'app.
Banalizzando, si parla di colori, pulsanti, icone, sfondi e tutto ciò che contribuisce a dare uno stile distintivo all'app.
Tenendo conto delle Human Interface Guidelines di Apple e del Material Design di Android, il processo di design UX e UI generalmente è attraversa le seguenti sotto-fasi:
- Wireframe. Bozza della struttura delle schermate con posizionamento di funzionalità e contenuti con l'obiettivo di validare i flussi utente definiti nella fase di progettazione.
- Mockup. Rappresentazione statica delle schermate con aspetto grafico completo e definitivo applicato a ciò che è stato progettato nel wireframe.
- Prototipo. Rappresentazione interattiva dei flussi utente o di eventuali animazioni da analizzare prima dell'effettiva implementazione.
L'immagine qui sopra mostra una fase di design dall'app Daikin mAP. Leggi la case history.
4. Sviluppo
Il cuore dello sviluppo app mobile consiste nella scrittura di codice nei linguaggi di programmazione di ogni piattaforma sui cui è stato deciso di rendere disponibile l'app in fase di analisi iniziale.
Cosa intendiamo con piattaforme? In ambito app mobile ci riferiamo sostanzialmente alle due seguenti:
- iOS. Sistema operativo di tutti gli iPhone di marca Apple, che usano Obj-C o Swift come linguaggi di programmazione.
- Android. Sistema operativo di tutte le altre marche di smartphone, come Samsung, Xiaomi, Huawei e molte altre che usano Java o Kotlin come linguaggi di programmazione.
Esiste anche una terza piattaforma - il Backend Web - che è necessario considerare quando l'app deve memorizzare dei dati online. Si tratta effettivamente di un sito web su cui vengono salvati alcuni dati utilizzati dalle app, come ad esempio le informazioni dei profili utente.
In questo caso i linguaggi di programmazione utilizzabili sono innumerevoli, ma Tiknil generalmente predilige PHP.
Nella maggior parte dei casi un'app viene sviluppata sia per iOS, sia per Android, ma talvolta capita che sia sufficiente concentrarsi su una singola piattaforma permettendo di diminuire il tempo di sviluppo.
5. Testing
Una volta completato (e in alcuni casi durante) lo sviluppo è importante definire dei piani di test. Essi raccolgono i principali casi d'uso dell'app e puntano a coprire la maggior parte dei flussi utente possibile, anche i più strani e impensabili, in modo da minimizzare il numero di bug o comportamenti errati dell'app.
Esistono diverse categorie di test e l'esecuzione di alcune di esse sono automatizzabili, ma nel caso delle Connective App è generalmente più efficace eseguirle manualmente, vista la necessità di connessione ad un altro dispositivo fisico.
Inoltre è consigliabile affidarne l'esecuzione ad una persona esterna al team di sviluppo in modo che abbia un approccio il più possibile simile ad un utente che non conosce i dettagli dell'app.
6. Distribuzione
Ora che l'app ha passato brillantemente il controllo qualità, è completa!
Procediamo dunque alla pubblicazione sui principali store, ovvero l'App Store di Apple e il Play Store di Android.
Ciò permetterà agli utenti di scaricare l'app sui propri smartphone e mantenerla aggiornata nel tempo.
Detta così sembra un'attività banale, ma in realtà si tratta di un puzzle composto da tanti piccoli pezzi, tra cui la definizione di nome, descrizione, categoria, icona, parole chiave, screenshot, privacy dei dati, caratteristiche di sicurezza e chi più ne ha più ne metta.
Gli store offrono effettivamente una vetrina su cui pubblicizzare la propria app, ma le logiche di visibilità su di essi non sono molto diverse da quelle per posizionarsi in prima pagina sui motori di ricerca, al punto che esiste un termine apposito: ASO - App Store Optimization.
7. Supporto ed evoluzione
Ora che l'app è sullo store, è fondamentale monitorarne l'utilizzo. Ciò è possibile grazie all'analisi delle recensioni utente e alle statistiche di utilizzo fornite dagli store, ma spesso è utile integrare dei sistemi di analisi dati aggiuntivi, come ad esempio Firebase.
Grazie ad essi è possibile ottenere informazioni su eventuali malfunzionamenti e dettagli aggiuntivi sull'utilizzo dell'app da parte degli utenti, in modo da pianificare evoluzioni mirate per fornire un'esperienza utente via via sempre migliore.
Che lavoro faccio?
Sviluppo app mobile... e non solo!
Ora è più chiaro? 😁
Spero di esser riuscito a darti qualche informazione in più sul lavoro che facciamo in Tiknil e nel caso fossi riuscito a stuzzicare la tua curiosità, sappi che hai visto solo la punta dell'iceberg... dai un'occhiata alla pagina: