Kuidas teha kalkulaatorit Xcode'is, kasutades Swiftit: 9 sammu
Kuidas teha kalkulaatorit Xcode'is, kasutades Swiftit: 9 sammu

Video: Kuidas teha kalkulaatorit Xcode'is, kasutades Swiftit: 9 sammu

Video: Kuidas teha kalkulaatorit Xcode'is, kasutades Swiftit: 9 sammu
Video: 30 лучших советов и рекомендаций по Windows 10 на 2020 год 2025, Jaanuar
Anonim
Image
Image

Selles lühikeses õpetuses näitan teile, kuidas luua lihtsat kalkulaatorit, kasutades Swift Xcode'is. See rakendus näeb välja peaaegu identne iOS -i algse kalkulaatorirakendusega. Võite kas samm-sammult juhiseid järgida ja koos minuga kalkulaatori ehitada või minna lihtsalt viimasele sammule ja kopeerida ning kleepida koodi oma vaate kontrollerisse. Kui aga seda teete, ühendage kindlasti kõik süžeeskeemi elemendid oma vaate kontrolleriga.

Samm: projekti loomine

Süžeeskeemi paigutus
Süžeeskeemi paigutus

Meie kalkulaatori valmistamise esimene samm on projekti tegelik loomine Xcode'is. Seda saate teha, klõpsates nuppu "Loo uus Xcode -projekt" ja pannes sellele nime, mida soovite. Panin omale nimeks "Kalkulaator". Järgmine samm on valida rakenduse tüübi jaoks "Ühe vaate rakendus". Hoidke kogu muu teave vaikeväärtusena.

2. samm: süžeeskeemi paigutus

Meie kalkulaatori loomise 2. etapis peate kujundama süžeeskeemis põhipaigutuse. Enne selle alustamist soovitan vahetada simulaator iPhone 7 Plus vastu. Alustuseks lohistage nupp süžeeskeemile ja muutke selle mõõtmed 89 x 89. Muutke selle taustavärv atribuutide inspektoril elavhõbedaks ja fondivärv volframiks. Seejärel reguleerige font Helvetica Light 30. Jätkake nupu kopeerimist ja kleepimist, kuni teil on kokku 20. Reguleerige nende nuppude paigutust nii, et teil oleks viis rida ja neli veergu.

3. samm: süžeeskeemi disain ja esteetika

Süžeeskeemi disain ja esteetika
Süžeeskeemi disain ja esteetika

Kustutage alumisest reast teine nupp ja laiendage esimest nuppu, et see ruum üle võtta. Muutke selle nupu kohatäite väärtus nulliks. Jätkake iga nupu numbriväärtuste ja sümbolite muutmist, kuni see on praktiliselt identne ülaltoodud pildiga. Atribuutide inspektoril on tumehall värv hõbedane, oranž värv mandariin ja fondivärv oranžidel nuppudel lumeks muudetud. Seejärel klõpsake vaate kontrollerit ja muutke selle taustavärv mustaks. Lisage nuppude kohale silt ja reguleerige selle suurust vastavalt oma mugavusele. Joondage tekst paremale ja muutke sildi font Helvetica light 70 -ks. Soovi korral saate lisada piirangud kõikidele elementidele, et muuta rakendus kõigi seadmete jaoks ühesuguseks.

Samm: elementide ühendamine ja integreerimine

Elementide ühendamine ja integreerimine
Elementide ühendamine ja integreerimine
Elementide ühendamine ja integreerimine
Elementide ühendamine ja integreerimine

Avage atribuutide inspektor ja muutke iga numbrinupu silti. Märgend peaks olema tegelikust arvväärtusest 1 võrra suurem. Näiteks nupu #0 märgendi väärtus peaks olema 1, nupu #1 märgendi väärtus peaks olema 2, nupu #2 märgendi väärtus peaks olema 3 jne. Seejärel vajutage juhtnuppu, klõpsake nuppu #0 ja lohistage see vaate kontrollerile. Ekraanile peaks ilmuma hüpikaken. Muutke ühendus väärtuseks „action”, tüübiks „UIButton”, sündmuseks „Touch Up Inside”, argumentideks „Sender” ja selle nimeks „numbrid”. Saate nime muuta mis tahes sooviks, kuid see tähendab, et peate funktsiooni hiljem kutsudes uuesti nime muutma. Seejärel kontrollige, klõpsake ja lohistage iga numbrinupp äsja loodud funktsiooni. Nüüd kontrollige, klõpsake ja lohistage silt programmi, kuid mitte funktsiooni. See tähendab, et lisate sildi funktsiooni lihtsalt eraldi muutujana. Pidage meeles, et kui olete koodi osas kunagi segaduses, olen jätnud kogu oma koodi teile kasutamiseks käesoleva juhendi viimases etapis.

5. samm: muutujate määramine

Muutujate kehtestamine
Muutujate kehtestamine

Selleks, et muuta meie numbrinupud funktsionaalseks, peame nende väärtuse funktsiooni „numbrid” sildiga siduma. Seda saate teha, luues esmalt muutuja 'numberOnScreen' ja muutes selle tüübiks topelt ja võrdne 0: var numberOnScreen: Double = 0; Ja ärge unustage, kui siin olev kood on veidi ebaselge, olen jätnud teile viimase koodi jaoks täieliku koodi, mida saate oma maitse järgi kasutada. Järgmisena seadistage teine bool tüüpi muutuja 'performanceMath' ja tehke see valeks: var performanceMath = false; Samuti looge teine muutuja nimega "previousNumber" tüüpi double ja määrake see võrdseks väärtusega 0: var previousNumber: Double = 0; Viimane muutuja, mille peate looma, on muutuja „operatsioon”. Määrake see võrdseks 0 -ga: var operatsioon = 0;

6. samm: numbrinuppude funktsioon

Nuppude funktsioon
Nuppude funktsioon

Pärast sobivate muutujate määramist võite selle koodi kopeerida ja kleepida oma funktsiooni "numbrid":

if performanceMath == true {

label.text = String (saatja.tag-1)

numberOnScreen = Kahekordne (silt.tekst!)!

performanceMath = vale

}

muu {

silt.tekst = silt.tekst! + String (sender.tag-1)

numberOnScreen = Kahekordne (silt.tekst!)!

}

Põhimõtteliselt kuvab see koodijupp vastava nupu vajutamisel sildil teatud numbrid. Siiski peame ikkagi saama kasutada kõiki teisi nuppe ja muuta kalkulaator funktsionaalseks. Teeme seda järgmise paari sammu jooksul.

Samm 7: Juhtnuppude integreerimine

Juhtnuppude integreerimine
Juhtnuppude integreerimine
Juhtnuppude integreerimine
Juhtnuppude integreerimine

Avage atribuutide inspektor ja muutke kõigi erinevate nuppude märgendit. Selge nupu silt peaks olema 11, jagamisnupul peaks olema silt 12, korrutamisnupul peaks olema silt 13, lahutamisnupul peaks olema silt 14, lisamisnupul peaks olema silt 15, ja nupul võrdne peaks olema silt 16. Seejärel vajutage juhtnuppu, klõpsake kustutamisnupul ja lohistage see vaate kontrollerile. Ekraanile peaks ilmuma hüpikaken. Muutke ühendus väärtuseks „action”, tüübiks „UIButton”, sündmuseks „Touch Up Inside”, argumentideks „Sender” ja selle nimeks „nupud”. Saate nime muuta mis tahes sooviks, kuid see tähendab, et peate funktsiooni hiljem kutsudes uuesti nime muutma. Seejärel kontrollige, klõpsake ja lohistage iga mitmesugust nuppu äsja loodud funktsiooni.

8. samm: mitmesuguste nuppude funktsioon

Mitmesuguste nuppude funktsioon
Mitmesuguste nuppude funktsioon

Kui olete kõik märgistatud mitmesugused nupud vastava funktsiooniga ühendanud, võite hakata koodi sisestama nuppude funktsiooni:

previousNumber = Kahekordne (silt.tekst!)!

kui sender.tag == 12 {// Jaga

label.text = "/";

}

kui sender.tag == 13 {// Korruta

label.text = "x";

}

kui sender.tag == 14 {// Lahuta

label.text = "-";

}

kui sender.tag == 15 {// Lisa

label.text = "+";

}

operatsioon = saatja.tag

performanceMath = true;

}

muidu, kui sender.tag == 16 {

kui operatsioon == 12 {// Jaga

label.text = String (previousNumber / numberOnScreen)

}

else if operatsioon == 13 {// Korruta

label.text = String (previousNumber * numberOnScreen)

}

else if operatsioon == 14 {// Lahuta

label.text = String (previousNumber - numberOnScreen)

}

else if operation == 15 {// Lisa

label.text = String (previousNumber + numberOnScreen)

}

}

muidu, kui sender.tag == 11 {

label.text = ""

eelmineNumber = 0;

numberOnScreen = 0;

operatsioon = 0;

}

Põhimõtteliselt kuvab see kooditükk selle vajutamisel ühe mitmesugustest nuppudest ja arvutab lõpliku vastuse ning kuvab selle sildil.

9. samm: täielik kood

Täielik kood
Täielik kood

Kui te ei tahtnud minuga samm -sammult kalkulaatorit läbi viia ja ehitada, saate elemendid lihtsalt oma süžeeskeemile lisada ning kopeerida ja kleepida oma vaatekontrollerisse. Siin on kood:

import UIKit

klassi ViewController: UIViewController {

var numberOnScreen: topelt = 0;

var previousNumber: Topelt = 0;

var performanceMath = vale;

var operatsioon = 0;

@IBAction func numbrid (_ saatja: UIButton) {

if performanceMath == true {

label.text = String (saatja.tag-1)

numberOnScreen = Kahekordne (silt.tekst!)!

performanceMath = vale

}

muu {

silt.tekst = silt.tekst! + String (sender.tag-1)

numberOnScreen = Kahekordne (silt.tekst!)!

}

}

@IBOutlet nõrk var silt: UILabel!

@IBAction func nupud (_ saatja: UIButton) {

if label.text! = "" && sender.tag! = 11 && sender.tag! = 16 {

previousNumber = Kahekordne (silt.tekst!)!

kui sender.tag == 12 {// Jaga

label.text = "/";

}

kui sender.tag == 13 {// Korruta

label.text = "x";

}

kui sender.tag == 14 {// Lahuta

label.text = "-";

}

kui sender.tag == 15 {// Lisa

label.text = "+";

}

operatsioon = saatja.tag

performanceMath = true;

}

muidu, kui sender.tag == 16 {

kui operatsioon == 12 {// Jaga

label.text = String (previousNumber / numberOnScreen)

}

else if operatsioon == 13 {// Korruta

label.text = String (previousNumber * numberOnScreen)

}

else if operatsioon == 14 {// Lahuta

label.text = String (previousNumber - numberOnScreen)

}

else if operation == 15 {// Lisa

label.text = String (previousNumber + numberOnScreen)

}

}

muidu, kui sender.tag == 11 {

label.text = ""

eelmineNumber = 0;

numberOnScreen = 0;

operatsioon = 0;

}

}

alistama func viewDidLoad () {

super.viewDidLoad ()

// Tehke pärast vaate laadimist täiendavaid seadistusi, tavaliselt nibust.

}

alistama func didReceivedMemoryWarning () {

super.didReceivedMemoryWarning ()

// Kõrvaldage kõik ressursid, mida saab uuesti luua.

}

}