Een rekenmachine maken in Xcode met Swift: 9 stappen
Een rekenmachine maken in Xcode met Swift: 9 stappen

Video: Een rekenmachine maken in Xcode met Swift: 9 stappen

Video: Een rekenmachine maken in Xcode met Swift: 9 stappen
Video: Hoe maak je een app met Xcode en Swift 2025, Januari-
Anonim
Image
Image

In deze korte tutorial laat ik je zien hoe je een eenvoudige rekenmachine maakt met Swift in Xcode. Deze app is gebouwd om er bijna identiek uit te zien als de originele rekenmachine-app voor iOS. Je kunt de aanwijzingen stap voor stap volgen en de rekenmachine samen met mij bouwen, of je kunt gewoon naar de laatste stap gaan en de code kopiëren en plakken in je viewcontroller. Als je dit echter doet, zorg er dan voor dat je al je elementen op het storyboard verbindt met je viewcontroller.

Stap 1: Het project maken

Storyboard-indeling
Storyboard-indeling

De eerste stap bij het maken van onze rekenmachine is om het project daadwerkelijk in Xcode te maken. U kunt dit doen door op "Een nieuw Xcode-project maken" te klikken en het een naam te geven die u maar wilt. Ik noemde de mijne "Rekenmachine". De volgende stap is om "Single View Application" te selecteren voor het app-type. Bewaar alle andere informatie als de standaardwaarde.

Stap 2: Storyboard-indeling

Stap 2 van het maken van onze rekenmachine vereist dat u een basislay-out in het storyboard ontwerpt. Voordat je hiermee begint, raad ik aan om je simulatorapparaat te wijzigen naar de iPhone 7 Plus. Begin door een knop naar het storyboard te slepen en de afmetingen te wijzigen in 89 x 89. Verander de achtergrondkleur in kwik in de attributeninspecteur en de letterkleur in wolfraam. Pas vervolgens het lettertype aan naar Helvetica Light 30. Blijf de knop kopiëren en plakken tot je er in totaal 20 hebt. Pas de lay-out van deze knoppen aan zodat je vijf rijen en vier kolommen hebt.

Stap 3: Storyboard-ontwerp en esthetiek

Storyboardontwerp en esthetiek
Storyboardontwerp en esthetiek

Verwijder de tweede knop op de onderste rij en vouw de eerste knop uit om deze ruimte over te nemen. Wijzig de waarde van de tijdelijke aanduiding van deze knop in nul. Ga door met het wijzigen van de nummerwaarden en symbolen van elke knop totdat deze praktisch identiek is aan de afbeelding hierboven. In de attributeninspecteur is de donkergrijze kleur zilver, de oranje kleur mandarijn en de tekstkleur is veranderd in sneeuw op de oranje knoppen. Klik vervolgens op de weergavecontroller en verander de achtergrondkleur in zwart. Voeg een label toe boven de knopen en pas de grootte aan zoals jij je prettig voelt. Lijn de tekst naar rechts uit en wijzig het lettertype van het label in Helvetica light 70. Als je wilt, kun je beperkingen toevoegen aan alle elementen om de app er voor alle apparaten hetzelfde uit te laten zien.

Stap 4: Elementen verbinden en integreren

Elementen verbinden en integreren
Elementen verbinden en integreren
Elementen verbinden en integreren
Elementen verbinden en integreren

Open de attributeninspecteur en wijzig de tag voor elke afzonderlijke cijferknop. De tag moet 1 meer zijn dan de werkelijke numerieke waarde. De #0-knop moet bijvoorbeeld een tagwaarde van 1 hebben, de #1-knop moet een tagwaarde van 2 hebben, de #2-knop moet een tagwaarde van 3 hebben, enzovoort. Druk vervolgens op Control, klik op de #0-knop en sleep deze naar de viewcontroller. Er zou een pop-up op het scherm moeten verschijnen. Wijzig de verbinding in 'actie', het type in 'UIButton', de gebeurtenis in 'Touch Up Inside', de argumenten in 'Afzender' en de naam in 'nummers'. U kunt de naam wijzigen in wat u maar wilt, maar dat betekent dat u de naam opnieuw moet wijzigen wanneer u de functie later in het programma aanroept. Bedien, klik en sleep vervolgens elke cijferknop naar de functie die we zojuist hebben gemaakt. Controleer, klik en sleep het label nu naar het programma, maar NIET naar de functie. Dit betekent dat je het label gewoon als aparte variabele in de functie brengt. Onthoud dat als je ooit in de war bent over de code, ik al mijn code voor je heb achtergelaten om te gebruiken bij de laatste stap van deze Instructable.

Stap 5: Variabelen vaststellen

Variabelen vaststellen
Variabelen vaststellen

Om onze cijfertoetsen functioneel te maken, zullen we hun waarde moeten koppelen aan het label in onze 'nummers'-functie. U kunt dit doen door eerst een variabele 'numberOnScreen' aan te maken en deze van het type double en gelijk aan 0 te maken: var numberOnScreen: Double = 0; En vergeet niet, als de code hier een beetje onduidelijk is, ik heb je de volledige code bij de laatste stap achtergelaten die je naar wens kunt gebruiken. Stel vervolgens een andere variabele 'performingMath' van het type bool in en maak deze false: var performingMath = false; Maak ook een andere variabele met de naam 'previousNumber' van het type double en stel deze in op 0: var previousNumber: Double = 0; De laatste variabele die je moet aanmaken is de 'operation' variabele. Stel het gelijk aan 0: var operatie = 0;

Stap 6: Cijferknoppen Functie

Cijferknoppen Functie
Cijferknoppen Functie

Nadat u de juiste variabelen hebt vastgesteld, kunt u doorgaan met het kopiëren en plakken van deze code in uw 'nummers'-functie:

if PerformingMath == true {

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

numberOnScreen = Dubbel(label.tekst!)!

presterenMath = false

}

anders {

label.tekst = label.tekst! + String (afzender.tag-1)

numberOnScreen = Dubbel(label.tekst!)!

}

In wezen geeft dit stukje code bepaalde nummers op het label weer wanneer op de juiste knop wordt gedrukt. We moeten echter nog steeds alle andere knoppen kunnen gebruiken en de rekenmachine functioneel maken. We zullen dit in de volgende paar stappen doen.

Stap 7: Bedieningsknoppen integreren

Bedieningsknoppen integreren
Bedieningsknoppen integreren
Bedieningsknoppen integreren
Bedieningsknoppen integreren

Open de attributeninspecteur en wijzig de tag voor alle diverse knoppen. De duidelijke knop moet een tag van 11 hebben, de deelknop moet een tag van 12 hebben, de vermenigvuldigingsknop moet een tag van 13 hebben, de aftrekknop moet een tag van 14 hebben, de optelknop moet een tag van 15 hebben, en de equal-knop moet een tag van 16 hebben. Druk vervolgens op control, klik op de clear-knop en sleep deze naar de view-controller. Er zou een pop-up op het scherm moeten verschijnen. Wijzig de verbinding in 'action', het type in 'UIButton', de gebeurtenis in 'Touch Up Inside', de argumenten in 'Sender' en de naam in 'buttons'. U kunt de naam wijzigen in wat u maar wilt, maar dat betekent dat u de naam opnieuw moet wijzigen wanneer u de functie later in het programma aanroept. Bedien, klik en sleep vervolgens elke diverse knop naar de functie die we zojuist hebben gemaakt.

Stap 8: Diverse knoppen Functie

Diverse knoppen Functie
Diverse knoppen Functie

Nadat u alle getagde diverse knoppen hebt verbonden met hun juiste functie, kunt u beginnen met het invoegen van de code in de functie 'knoppen':

previousNumber = Double(label.text!)!

if afzender.tag == 12 {//Verdelen

label.tekst = "/";

}

if afzender.tag == 13 {//Vermenigvuldigen

label.tekst = "x";

}

if afzender.tag == 14 {//Aftrekken

label.tekst = "-";

}

if afzender.tag == 15 { //Toevoegen

label.tekst = "+";

}

operatie = afzender.tag

presterenMath = waar;

}

anders als afzender.tag == 16 {

if operatie == 12 {//Delen

label.text = String (vorige nummer / nummer op scherm)

}

anders als bewerking == 13 {//Vermenigvuldigen

label.text = String (vorige nummer * nummer op scherm)

}

else if operatie == 14 {//Aftrekken

label.text = String (vorige nummer - nummer op scherm)

}

else if operatie == 15{ //Toevoegen

label.text = String (vorige nummer + nummer op scherm)

}

}

anders als afzender.tag == 11{

label.tekst = ""

vorig nummer = 0;

nummer op scherm = 0;

operatie = 0;

}

In wezen geeft dit stukje code een van de diverse knoppen weer wanneer erop wordt gedrukt en wordt het uiteindelijke antwoord berekend en weergegeven op het label.

Stap 9: Volledige code

Volledige code
Volledige code

Als je de rekenmachine niet stap voor stap met mij wilt doornemen en bouwen, dan kun je eenvoudig de elementen aan je storyboard toevoegen en de volledige code kopiëren en plakken in je viewcontroller. Hier is de code:

import UIKit

klasse ViewController: UIViewController {

var numberOnScreen: Dubbel = 0;

var previousNumber: Dubbel = 0;

var performingMath = false;

var bewerking = 0;

@IBAction functienummers(_ afzender: UIButton) {

if PerformingMath == true {

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

numberOnScreen = Dubbel(label.tekst!)!

presterenMath = false

}

anders {

label.tekst = label.tekst! + String (afzender.tag-1)

numberOnScreen = Dubbel(label.tekst!)!

}

}

@IBOutlet zwak var-label: UILabel!

@IBAction-functieknoppen (_ afzender: UIButton) {

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

previousNumber = Double(label.text!)!

if afzender.tag == 12 {//Verdelen

label.tekst = "/";

}

if afzender.tag == 13 {//Vermenigvuldigen

label.tekst = "x";

}

if afzender.tag == 14 {//Aftrekken

label.tekst = "-";

}

if afzender.tag == 15 { //Toevoegen

label.tekst = "+";

}

operatie = afzender.tag

presterenMath = waar;

}

anders als afzender.tag == 16 {

if operatie == 12 {//Delen

label.text = String (vorige nummer / nummer op scherm)

}

anders als bewerking == 13 {//Vermenigvuldigen

label.text = String (vorige nummer * nummer op scherm)

}

else if operatie == 14 {//Aftrekken

label.text = String (vorige nummer - nummer op scherm)

}

else if operatie == 15{ //Toevoegen

label.text = String (vorige nummer + nummer op scherm)

}

}

anders als afzender.tag == 11{

label.tekst = ""

vorig nummer = 0;

nummer op scherm = 0;

operatie = 0;

}

}

overschrijven func viewDidLoad() {

super.viewDidLoad()

// Voer aanvullende instellingen uit na het laden van de weergave, meestal vanaf een punt.

}

override func didReceiveMemoryWarning() {

super.didReceiveMemoryWarning()

// Gooi alle bronnen weg die opnieuw kunnen worden gemaakt.

}

}