Chiudi il Menu
iSpazioiSpazio
  • Notizie
  • Offerte iSpazio
  • Sfondi
  • Downloads
  • Recensioni
  • iOS 26
  • Sconti Amazon
Menu Espanso
  • Home
  • Forum
  • Notizie
  • Offerte iSpazio
  • iOS 26
  • iPhone 16
  • Downloads
  • Guide
  • Sconti Amazon
  • Contatti
  • Pubblicità
Facebook X (Twitter) Instagram YouTube TikTok
iSpazioiSpazio
  •  Forum
  • Offerte iSpazio
  • Wallpapers Central
  • Teslers
Scarica l'App
  • Offerte
  • Sfondi
  • Guide
    • Personalizzazione
    • Video Guide TikTok
  • Recensioni
  • Downloads
    • Sfondi
    • Suonerie
    • Comandi Rapidi
    • Sfondi Personalizzati
    • Widget e Altro
    • iOS
    • iTunes
  • Dispositivi Apple
    1. iPhone
    2. iPad
    3. Mac
    4. Apple Watch
    5. iOS 26
    6. Vedi tutto

    Apple vuole mantenere invariato il prezzo di partenza dell’iPhone 18

    28 Gen 2026

    Apple aggiorna iPhone 5s e iPhone 6 con un nuovo firmware a oltre dieci anni dal lancio

    27 Gen 2026

    Apple continua a macinare utili nonostante l’aumento dei costi della RAM

    21 Gen 2026

    Il tuo iPhone 17 Pro Arancione cosmico diventerà rosa? I test danno una risposta chiara

    21 Gen 2026

    Apple rilascia nuovi aggiornamenti per vecchie versioni di iOS, macOS e watchOS

    3 Feb 2026

    Pixelmator Pro arriva su iPad con Apple Creator Studio: tutte le novità della nuova app

    29 Gen 2026

    Apple annuncia l’arrivo di Pixelmator Pro su iPad

    13 Gen 2026

    iPadOS 26.2 e macOS 26.2 sbloccano un Wi-Fi più veloce su alcuni Mac e iPad

    6 Gen 2026

    Apple rilascia nuovi aggiornamenti per vecchie versioni di iOS, macOS e watchOS

    3 Feb 2026

    Nuovi MacBook Pro con chip M5 attesi con macOS 26.3

    2 Feb 2026

    Apple semplifica l’acquisto dei Mac eliminando le configurazioni predefinite

    2 Feb 2026

    Apple pronta a rinnovare due volte il MacBook Pro nello stesso anno

    26 Gen 2026

    Apple rilascia nuovi aggiornamenti per vecchie versioni di iOS, macOS e watchOS

    3 Feb 2026

    Un avviso di frequenza cardiaca elevata dell’Apple Watch ha salvato la vita a un giornalista

    29 Gen 2026

    Strava e Komoot portano finalmente le mappe offline su Apple Watch

    29 Gen 2026

    Apple rilascia watchOS 26.2.1: la funzione “Posizione precisa” per AirTag arriva su Apple Watch

    27 Gen 2026

    iPhone 18 Pro, poche novità estetiche dopo il successo del 17 Pro

    3 Feb 2026

    I prossimi chip A20 e M6 non useranno il nuovo processo produttivo N2P di TSMC

    3 Feb 2026

    Svelati nuovi dettagli sul design dell’iPhone pieghevole

    3 Feb 2026

    Apple celebra il Capodanno cinese 2026 con un corto girato con iPhone 17 Pro

    3 Feb 2026

    iPhone 18 Pro, poche novità estetiche dopo il successo del 17 Pro

    3 Feb 2026

    I prossimi chip A20 e M6 non useranno il nuovo processo produttivo N2P di TSMC

    3 Feb 2026

    Svelati nuovi dettagli sul design dell’iPhone pieghevole

    3 Feb 2026

    Apple celebra il Capodanno cinese 2026 con un corto girato con iPhone 17 Pro

    3 Feb 2026
  • iPhone 17
  • iOS 26
  • Sconti Amazon
Contatti
Pubblicità
iSpazioiSpazio
  • Notizie
  • Offerte iSpazio
  • Sfondi
  • Downloads
  • Recensioni
  • iOS 26
  • Sconti Amazon

iSpazio CountRotateApp – iSpazio Developer Program #4

Andrea BusiDi Andrea Busi19 Set 2008Commenta7 min di lettura
Condividi Facebook Twitter Telegram WhatsApp Copia Link Threads Email
Share
Facebook Twitter WhatsApp Telegram Threads Email Copia Link
In qualità di Affiliato Amazon, iSpazio riceve una commissione dagli acquisti idonei senza alcun costo per voi. (info).
Icona Cerchi Prodotti Apple ed accessori Tech in sconto?

Cerchi Prodotti Apple ed accessori Tech in sconto?

Segui il nostro canale @scontiamolo su Telegram!

Advertising

Eccoci al quarto tutorial dell’iSpazio Developer Program. Nella scorsa puntata ci siamo occupati della gestione delle immagini, di come muoverle e come creare un’animazione con esse. Oggi, invece, vedremo come implementare un’aspetto più comune, ovvero quello di realizzare una barra posta nella parte bassa dell’applicazione, che abbia dei pulsanti che compiano una determinata azione. Nel nostro caso questi due bottoni ci permetteranno di incrementare e decrementare un contatore posto al centro della schermata. Vedremo, infine, come implementare una funzione tanto gradia dell’iPhone/iPod Touch: l’autorotazione dello schermo.

TUTORIAL:

  1. Creiamo un nuovo progetto
  2. Creare l’interfaccia grafica dell’applicazione
  3. Creiamo le classi necessarie
  4. Aggiungiamo la rotazione automatica
  5. Facciamo funzionare i bottoni della barra!

1. Creiamo un nuovo progetto

Aprimo Xcode, selezioniamo “File -> New Project”. Nel menù che ci appare selezioniamo “ViewBased Application”, clicchiamo su “Choose…” e immettiamo come nome “CountRotateApp” e fate clic su “Save”. Abbiamo così creato il nostro nuovo progetto.

Prima di fare qualsiasi altra operazione, selezioniamo nell’editor Xcode la cartella “Resources” del nostro progetto ed eliminiamo il file “CountRotateAppViewController.xib”. Basterà cliccare con il tasto destro sul file, selezionare “Delete” e poi cliccare su “Also move to Trash”.

2. Creare l’interfaccia grafica dell’applicazione

Una volta eseguite queste semplici operazioni, andiamo a creare l’interfaccia grafica della nostra applicazione. Facciamo doppio click sul file “MainWindow.xib”, si aprirà così l’Interface Builder, con cui ormai abbiamo già preso conoscenza.
Selezioniamo la vista della nostra applcazione, e apriamo l’Attribute Inspector. Nel campo “NIB Name” eliminiamo la voce “CountRotateAppViewController” (semplicemente cancellando il testo), ovvero il file che abbiamo cancellato in precedenza.

Se premiamo poi invio e torniamo a selezionare la vista vedremo che essa ha mutato la scritta centrale, ed ora apparirà così:

Ora, dalla libreria (“Tools -> Library”) selezioniamo un componente di tipo “View” e trasciniamolo nella nostra applicazione. Andiamo poi in “Identity Inspector” e in Class scriviamo “MainView”.

Abbiamo creato la vista principale della nostra applicazione che, se vogliamo, possiamo personalizzare a nostro piacere (ad esempio impostando un colore di sfondo diverso dal classico bianco).

Sempre dalla libreria selezioniamo un componente “Toolbar” e trasciniamolo nella parte bassa della nostra vista. Dopo averlo trascinato facciamo doppio click sul bottone già presente, e modifichiamo il testo in “Sottrai”. Sempre dalla libreria selezioniamo un “Bar Button Item” e trasciniamolo all’interno della barra che abbiamo appena creato. Questa volta dobbiamo invece che settare solamente il nome, lo associamo ad un’identificatore già presente nell’Interface Builder. Andiamo, quindi, in Attribute Inspector e nel campo “Identifier” selezioniamo “Add”.

Noteremo subito che nel nostro bottone comparirà il simbolo “+”.

Dopo questi semplici step avremo un’applicazione che si presenterà così:

Proviamo a spostare il bottone “+” a destra. Esso ritornerà sempre nella sua posizione originale. Nostro errore? No. Come facciamo allora a spostarlo a destra? Semplice, aggiungiamo un componente “Flexible Space Bar Button Item”, che troviamo sempre nella libreria, e che ha proprio il compito di creare uno spazio tra i bottoni della barra. Aggiungiamolo tra i due bottoni ed otterremo una schermata come questa:

Questo componente ha una grossa utilità: non solo ci separa i due bottoni, ma ci permette di non doverci occupare della giusta distanza tra essi, anche nel caso che ne aggiungessimo un terzo. Inoltre esso ci permette di tenere i due bottoni alle estremità della barra anche nel caso in cui ruotassimo la nostra applicazione. Come facciamo a testarlo? Semplice. Cliccate sulla freccetta presente nel titolo della finestra della nostra applicazione:

Vedrete che la schermata ruoterà!

E come possiamo notare i due bottoni restano agli estremi della nostra barra. Proprio il risultato che volevamo.

Prendiamo ora una label, e inseriamola nella nostra vista, partendo da un angolo in alto a sinistra, per poi ingrandirla fino all’angolo opposto. In Attribute Inspector settate i seguenti parametri: “Text”: 0, allineamento centrale, e “Font Size” a 200. Dovreste avere il seguente risultato:

Proviamo ora a far ruotare la schermata come abbiamo fatto poco fa. Noteremo che lo zero non rimane in posizione centrale, ma addirittura esce dalla schermata dell’applicazione. Come facciamo a lasciarlo centrato? Anche qui ci viene in aiuto l’Interface Builder, che offre grandi potenzialità anche in questo aspetto.
Selezioniamo la label che contiene lo zero e apriamo il “Size Inspector”. Nella seconda parte possiamo vedere che vi è una sezione denominata “Autosizing”. Clicchiamo sulle due freccette rosse che vediamo nel riquadro piccolo, in modo da avere questo schema:

Proviamo ora a ruotare la nostra applicazione: lo zero resterà perfettamente in posizione centrale!

3. Creiamo le classi necessarie

Fino ad ora ci siamo occupati puramente degli aspetti grafici della nostra applicazione. Vediamo ora di aggiungere i controlli che ci serviranno.

Restiamo sempre nell’Interface Builder, e assicuriamoci di aver selezionato la vista principale. Andiamo nell’Identity Inspector, e aggiungiamo le due classi e le due azioni che ci occorrono. Facciamolo nella seguente maniera:

Ora dobbiamo collegare queste azioni che abbiamo creato agli oggetti veri e propri. Entriamo nella scheda “Connections”, trasciniamo il pallino a fianco di “label” sulla label contenente lo zero, e “toolBar” sulla barra. Dovremmo avere le proprietà così impostate:

Adesso dobbiamo collegare le azioni ai due bottoni presenti nella barra. Iniziamo con il bottone “+” (Aggiungi). Anche per questo ci basterà trascinare l’azione “add” sul bottone corrispondente:

Dobbiamo, quindi, impostare l’azione sul bottone “Sottrai”. Questa volta la procedura è leggermente diversa. Clicchiamo sul bottone, ed entriamo ancora nel pannello “Connections”. Questa volta vedremo l’azione “selector”, trasciniamola sulla vista principale (non potremo fare in altro modo). Apparirà questo piccolo menù:

Clicchiamo ovviamente su “subtract”. Avremo così collegato anche questa azione. Nel pannello Connections dovreste avere questo risultato:

Ora non ci resta che salvare le proprietà che abbiamo appena impostato in un file di classe. Andiamo nel menù “File -> Write Class Files…” e salviamo la classe “MainView” nella cartella Classes del nostro progetto.

Clicchiamo su “Save” e nella schermata successiva selezioniamo il nostro progetto prima di cliccare su “Add”.

Possiamo ora chiudere l’Interface Builder cliccando su “Save” nell’avviso che ci comparirà.

4. Aggiungiamo la rotazione automatica

Ora passiamo alla scrittura del codice in Xcode. Iniziamo spostando i due file (“MainView.m” e “MainView.h”) all’interno della cartella “Classes”:

Apriamo ora il file “MainView.h” e modifichiamo la riga di intestazione del metodo nel seguente modo:

Se proviamo ora a compilare l’applicazione e ad eseguirla noteremo che essa non fa nessuna delle azioni che vorremmo: non incrementa il contatore, non si ruota se ruotiamo l’iPhone. Dobbiamo quindi aggiungere tutte queste funzionalità.

Apriamo il file “CountRotateAppViewController.m” e impostiamo il metodo che permetterà alla nostra applicazione di ruotare quando viene ruotato il dispositivo. Dobbiamo modificare il metodo “shouldAutorotateToInterfaceOrientation” nel seguente modo:

Semplicemente impostiamo “YES” come valore di ritorno di questo metodo; è lo stesso commento presnte nel metodo a dirci di ritornare questo valore per abilitare l’autorientazione della nostra applicazione.
Clicchiamo ora su “Build and Go” e testiamo quello che abbiamo appena fatto. Nel Simulatore andiamo nel menù Hardware e selezioniamo “Ruota a sinistra” (o a destra, a vostro piacimento). La nostra applicazione ruoterà proprio come desiderato!

5. Facciamo funzionare i bottoni della barra!

Abbiamo quasi completato la nostra applicazione, manca solo.. la parte più importante! Dobbiamo, quindi, far funzionare i due bottoni presenti sulla barra, permettendogli di incrementare e decrementare il contatore.

Apriamo il file “MainView.h” e iniziamo con il dichiarare una variabile che conterrà il numero che poi noi andremo ad incrementare e a decrementare, e che verrà visualizzato. Dobbiamo quindi scrivere il seguente codice:

Qui non c’è bisogno di spiegazioni, possiamo facilmente capire che dichiariamo una variabile di tipo intero e la chiamiamo “numero”.

Apriamo ora il file “MainView.m” e scriviamo il seguente codice:

Il primo metodo, “awakeFromNib” viene chiamato all’avvio dell’applicazione, e azzera il valore della variabile numero. I due metodi, “add” e “subtract” fanno le stesse operazioni (con la sola differenza dell’operazione che compiono), ovvero prima incrementano (o decrementano) il valore della variabile numero, e poi la settano nella label predisposta per questo compito.

Clicchiamo su “Build and Go” e salviamo i file. Abbiamo così creato la nostra applicazione!!

Ecco due screen di come appare finita e funzionante:

Se Avete Problemi, questo è il nostro file di progetto.

La guida è stata creata in italiano da Andrea Busi per iSpazio.net. Trovare il video tutorial originale a questo indirizzo: “UIToolbar and AutoRotation” – iPhone Development Central. I meriti quindi relativamente alla versione inglese, sono del legittimo autore.

Sai che siamo anche su Telegram? Unisciti al nostro canale iSpazio per ricevere le notifiche oppure Apple Italia per chattare con altri utenti. Scopri i migliori prodotti Tech in sconto su Amazon con il nostro canale OFFERTE iSpazio.
Icona dell'applicazione Le Migliori Offerte Amazon disponibile su App Store

Le Migliori Offerte Amazon

Selezionate dalla redazione di iSpazio
GUARDALE LIVE  
  • Filtra:
  • Tutte
  • Minimo Storico
  • Alimentari e cura della casa
  • Cancelleria e prodotti per ufficio
  • Casa e cucina
  • Elettronica
  • Informatica
  • Moda
  • Videogiochi
19%  
Oro Ciok Biscotto con Tavoletta di Cioccolato al Latte – 10 X 25g
08:38
Oro Ciok Biscotto con Tavoletta di Cioccolato al Latte – 10 X 25g2,99€2,42€
24%  
Philips Ambilight 50PUS8510 4K QLED Smart TV – Display 50’’ con piattaforma Titan OS, Pixel Precise Ultra HD e Dolby Atmos Sound – Funziona con Alexa e Google Voice Assistant
08:36
Philips Ambilight 50PUS8510 4K QLED Smart TV – Display 50’’ con piattaforma Titan OS, Pixel Precise Ultra HD e Dolby Atmos Sound – Funziona con Alexa e Google Voice Assistant446,00€339,00€
17%
Nostromo – Filetti di Tonno al Naturale, Qualità Superiore, Lavorati a Mano, 1 Vasetto in Vetro da 180 gr
08:34
Nostromo – Filetti di Tonno al Naturale, Qualità Superiore, Lavorati a Mano, 1 Vasetto in Vetro da 180 gr5,39€4,47€
60%
Logitech G G203 LIGHTSYNC Mouse Gaming con Illuminazione RGB, Personalizzabile, 6 Pulsanti Programmabili, Sensore per Gaming, Tracciamento a 8.000 DPI, Peso Ridotto – Nero
08:30
Logitech G G203 LIGHTSYNC Mouse Gaming con Illuminazione RGB, Personalizzabile, 6 Pulsanti Programmabili, Sensore per Gaming, Tracciamento a 8.000 DPI, Peso Ridotto – Nero47,99€18,99€
49%
Logitech Pebble Mouse Wireless Con Bluetooth O Ricevitore Da 2.4 Ghz, Mouse Sottile Per Computer Con Clic Silenziosi, Per Laptop, Notebook, Ipad, Pc, Mac, Chromebook, Nero
08:26
Logitech Pebble Mouse Wireless Con Bluetooth O Ricevitore Da 2.4 Ghz, Mouse Sottile Per Computer Con Clic Silenziosi, Per Laptop, Notebook, Ipad, Pc, Mac, Chromebook, Nero29,99€15,29€
70%
G-STAR 3301 Slim Jeans, Jeans Uomo, Bianco (Paper White GD Destroyed 51001-d552-h155), 28W ,  30L
08:22
G-STAR 3301 Slim Jeans, Jeans Uomo, Bianco (Paper White GD Destroyed 51001-d552-h155), 28W , 30L150,00€45,14€
23%  
Motorola moto g86 con 3 anni di garanzia (8, 256GB, Fotocamera 50MP + flicker cam, Display 6.67″ pOLED 120Hz, batteria 5100mAh, MediaTek Dimensity 7300, Android 15), Spellbound
08:21
Motorola moto g86 con 3 anni di garanzia (8, 256GB, Fotocamera 50MP + flicker cam, Display 6.67″ pOLED 120Hz, batteria 5100mAh, MediaTek Dimensity 7300, Android 15), Spellbound259,90€199,90€
23%  
Motorola moto g86 con 3 anni di garanzia (8, 256GB, Fotocamera 50MP + flicker cam, Display 6.67″ pOLED 120Hz, batteria 5100mAh, MediaTek Dimensity 7300, Android 15), Cosmic Sky
08:16
Motorola moto g86 con 3 anni di garanzia (8, 256GB, Fotocamera 50MP + flicker cam, Display 6.67″ pOLED 120Hz, batteria 5100mAh, MediaTek Dimensity 7300, Android 15), Cosmic Sky259,90€199,90€
70%
Falcotto Alby-Sandali Semi Chiusi in Pelle, Blu 18
08:13
Falcotto Alby-Sandali Semi Chiusi in Pelle, Blu 1872,00€21,30€
27%  
Motorola edge 60 neo con Moto AI (8, 256GB, Tripla camera 50MP+13MP+10MP, selfie 32MP, Display 6.36″ Super HD 120Hz, MediaTek Dimensity 7400, 5000mAh, TurboPower 68W, Android 15), PANTONE Poinciana
08:11
Motorola edge 60 neo con Moto AI (8, 256GB, Tripla camera 50MP+13MP+10MP, selfie 32MP, Display 6.36″ Super HD 120Hz, MediaTek Dimensity 7400, 5000mAh, TurboPower 68W, Android 15), PANTONE Poinciana399,00€289,90€
50%  
SwitchBot S20 Robot Aspirapolvere Lavapavimenti, Evitamento Degli Ostacoli AI, 10000 Pa, Auto-Svuotamento e Riempimento, Lava e Asciuga Autopulizia Supporto Matter e Apple Home
08:09
SwitchBot S20 Robot Aspirapolvere Lavapavimenti, Evitamento Degli Ostacoli AI, 10000 Pa, Auto-Svuotamento e Riempimento, Lava e Asciuga Autopulizia Supporto Matter e Apple Home799,99€399,98€
27%  
Motorola edge 60 neo con Moto AI (8, 256GB, Tripla camera 50MP+13MP+10MP, selfie 32MP, Display 6.36″ Super HD 120Hz, MediaTek Dimensity 7400, 5000mAh, TurboPower 68W, Android 15), PANTONE Frostbite
08:05
Motorola edge 60 neo con Moto AI (8, 256GB, Tripla camera 50MP+13MP+10MP, selfie 32MP, Display 6.36″ Super HD 120Hz, MediaTek Dimensity 7400, 5000mAh, TurboPower 68W, Android 15), PANTONE Frostbite399,00€289,90€
40%
Pavesi Biscotti Frollini Gocciole Cioccolato, 500g
08:03
Pavesi Biscotti Frollini Gocciole Cioccolato, 500g2,99€1,78€
10%  
Insta360 GO Ultra Pack Creator Nero Notte- action cam mini 4K a mani libere, indossabile, superba in bassa luce, montala ovunque, stabilizzazione FlowState, 200 min di carica,bici e corsa
08:01
Insta360 GO Ultra Pack Creator Nero Notte- action cam mini 4K a mani libere, indossabile, superba in bassa luce, montala ovunque, stabilizzazione FlowState, 200 min di carica,bici e corsa479,00€429,00€

Scarica la nostra app e leggi le notizie in mobilità. Porta iSpazio sempre con te, anche su Telegram.
| Applicazione iOS
Con l'applicazione ufficiale di iSpazio resterai sempre aggiornato sulle notizie Apple, video tutorial per iPhone e tanto altro. riceverai una notifica per ogni nuovo articolo. Puoi utilizzare anche i Widget per tenere le novità sott'occhio nella Home o nella Lockscreen.
Scaricala subito!
| Canale Telegram 10.700+ Utenti
Su Telegram invece, segnaliamo soltanto le notizie più importanti ed urgenti oppure i nostri nuovi video su YouTube. E' un canale molto interessante, assolutamente non invasivo perchè non inviamo troppe push, e vi consigliamo di seguirci anche lì.
Unisciti a noi!
ispazio notifiche
Seguici su Google News
Condividi Facebook Twitter Telegram WhatsApp Threads Email Copia Link
Articolo precedenteTouch Ghosts 1.0
Articolo successivo WritingPad torna in AppStore!

Leggi o Aggiungi Commenti

Advertising

Da non perdere!

Starlink sugli iPhone 18 Pro? Apple tratta con SpaceX

29 Gen 2026

iOS 26.3 e iPadOS 26.3 beta 3 sono ora disponibili per gli sviluppatori

27 Gen 2026

Apple presenta AirTag 2: più preciso, più potente e ancora più utile per ritrovare gli oggetti

26 Gen 2026

Apple presenta il nuovo cinturino Black Unity intrecciato per Apple Watch

26 Gen 2026

Gli articoli più letti

iPhone 18 Pro, poche novità estetiche dopo il successo del 17 Pro

I prossimi chip A20 e M6 non useranno il nuovo processo produttivo N2P di TSMC

Info su iSpazio
Info su iSpazio

iSpazio è il punto di riferimento italiano per tutti gli appassionati Apple. Dal 2007, sul nostro sito trovi notizie, recensioni e guide per imparare ad utilizzare al meglio iOS, l'iPhone e tutti gli altri dispostivi dell'azienda.

Contattaci
Pubblicità

Il Network
Il Network

L'esperienza maturata su iSpazio ci ha portati, con il tempo, a realizzare altri progetti ed aprire nuovi siti con tematiche strettamente correlate al nostro Blog principale.

Oggi, siamo i fieri proprietari di un Network composto da: iSpazio, Scontiamolo, Wallpapers Central e Teslers.

Link Rapidi
  • Chi siamo
  • Contattaci
  • Legal
  • Privacy Policy
  • Pubblicità su
© Copyright 2026 iSpazio SRL | Partita IVA: 10137091210
  • Chi siamo
  • Contattaci
  • Legal
  • Privacy Policy
  • Pubblicità su

Scrivi quello che vuoi cercare e premi Invio.