Wie bereits erwähnt FirstApp iPhone: Guess the Zahl - Teil 1 sehen wir, wie Sie eine Anwendung für das Apple iPhone ohne Interface Builder zu machen! In der Tat werden wir beseitigen physischen Dateien von Interface Builder Wizard erstellt Xcode. Am Ende von diesem Post, dann haben wir eine Anwendung in jeder Hinsicht identisch, die denen im ersten Teil gebaut, mit dem Unterschied, dass wir alle unsere visuelle Komponenten, einschließlich der im Hauptfenster für vollständige Code zu erreichen.
Die Anwendung bereits gemacht, wenn Sie gerade herunterladen möchten, finden Sie auf meiner Google-Code-Repository:
Ich möchte darauf hinweisen, das sofort als ZIP dieses Beispiels wiegt weniger als das letzte Mal! ![]()
Wir schaffen das Projekt
Wir beginnen mit der Erstellung unseres Projektes SecondApp (um es von FirstApp unterscheiden), obwohl diese Zeitfenster-basierte Applikation Bitte wählen Sie:

Nun wollen wir löschen alles, was mit Interface Builder. : eliminatelo anche dal file system, quindi selezionate Also Move to Trash . Beseitigen Sie die Datei MainWindow.xib , sich im Ordner Resources , entfernen Sie sie aus dem Dateisystem auch, und wählen Sie dann auch den Papierkorb verschieben. nella casella Main nib file base name : Wählen Sie dann die Datei SecondoApp-info.plist und löschen Sie den Verweis auf die MainWindow nib-Datei in der Main-box basierte Name:

An dieser Stelle haben wir nicht mehr alle Fenster, zumindest über Interface Builder. , e modifichiamo la funzione main() in questo modo: Also öffnen wir die Datei main.m , in gelegen Other Sources , und ändern Sie die Funktion main() etwa so:
1 2 3 4 5 6 7 8 9 10 11 | int argc, char * argv [ ] ) { int main (int argc, char * argv []) { pool = [ [ NSAutoreleasePool alloc ] init ] ; NSAutoreleasePool Pool * = [[ NSAutoreleasePool alloc] init]; / / Durch das Entfernen der Datei. XIB wir verloren Tracking / / Die App Delegierter und dann weiterzugeben, um "Hand" UIApplicationMain ( argc, argv, nil , @ "SecondAppAppDelegate" ) ; int retVal = UIApplicationMain (argc, argv, nil, @ "SecondAppAppDelegate"); ; [Pool release]; zurück retVal; } |
Öffnen Sie SecondAppAppDelegate.me dann schaffen wir das Hauptfenster über den Code:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | void ) applicationDidFinishLaunching : ( UIApplication * ) application { - (Void) applicationDidFinishLaunching: (UIApplication *) Anwendung { / / Holen Sie sich die Bildschirmgröße (320, 480) UIScreen mainScreen ] applicationFrame ] ; CGRect windowRect = [[UIScreen mainScreen] applicationFrame]; / / Erzeugt ein Fenster - so wie wir bye bye zu Interface Builder tat [ [ UIWindow alloc ] initWithFrame : windowRect ] ; UIWindow MainWindow * = [[UIWindow alloc] initWithFrame: windowRect]; / / Stellen Sie den Hintergrund des Fensters, um gelbe, zu differenzieren / / Die ältere Anmeldung FirstApp [ UIColor yellowColor ] ] ; [MainWindow setBackgroundColor: [UIColor yellowColor]]; mainWindow ] ; [Self setWindow: MainWindow]; ; [Window makeKeyAndVisible]; ; [MainWindow release]; } |
Sie können bereits testen Sie die Anwendung, wenn ein Fenster erscheint gelb Sie haben alles richtig gemacht!
, necessario solo se si usa Interface Builder. In der Datei SecondAppAppDelegate.h können wir beseitigen IBOutlet , nur benötigt, wenn Sie Interface Builder verwenden. Auch hier hinzufügen, dass unsere globale Variablen, das letzte Mal, dass wir in der Steuerung eingegeben hatte. Dann ändern Sie die Datei SecondAppAppDelegate.h :
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | # Import <UIKit/UIKit.h> NSObject <UIApplicationDelegate> { @ Interface SecondAppAppDelegate: NSObject {<UIApplicationDelegate> UIWindow * Fenster; UITextField * Zahl; UIButton *-Taste; int numeroACaso; } nonatomic, retain ) UIWindow * window; @ Property (atomare, behalten) UIWindow * Fenster; void ) controllaNumero; - (Void) getNumber; @ End |
, in quanto non stiamo usando Interface Builder. Auch in diesem Fall haben wir die Definition der Methode vorbereitet controllaNumero , wie beim letzten Mal, aber wir haben den Hinweis beseitigt IBAction , da wir nicht mit Interface Builder.
Wir bilden die Schnittstelle Code
Es ist Zeit, um Code mit allen Komponenten unserer Schnittstelle zu schaffen. ed inseriamo il seguente codice: Wir kehren in der Datei SecondAppAppDelegate.m , posizioniamoci vor [mainWindow release] und setzen Sie den folgenden Code ein:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 | / / Erstellen Sie auf die Titelleiste [ [ UINavigationBar alloc ] initWithFrame : CGRectMake ( 0.0 , 0.0 , 320.0 , 44.0 ) ] ; UINavigationBar myNavigationBar * = [[UINavigationBar alloc] initWithFrame: CGRectMake (0,0, 0,0, 320,0, 44,0)]; myNavigationBar.barStyle = UIBarStyleDefault; [ [ UINavigationItem alloc ] initWithTitle : @ "Indovina un numero" ] ; UINavigationItem navigationItem * = [[UINavigationItem alloc] initWithTitle: @ "Guess eine Reihe"]; navigationItem animated : NO ] ; [MyNavigationBar pushNavigationItem: navigationItem animiert: NO]; myNavigationBar ] ; [Window addSubview: myNavigationBar]; / / Erstellen Sie das Etikett [ [ UILabel alloc ] initWithFrame : CGRectMake ( 10 , 50 , 300 , 80 ) ] ; UILabel myLabel * = [[UILabel alloc] initWithFrame: CGRectMake (10, 50, 300, 80)]; UIColor clearColor ] ; myLabel.backgroundColor = [UIColor clearColor]; ; myLabel.numberOfLines = 2; "iPhone ha pensato un numero da 1 a 10, prova ad indovinarlo?" ; myLabel.text = @ "Das iPhone hat eine Zahl von 1 bis 10 ausgebildet, versuchen zu erraten?" myLabel ] ; [Window addSubview: myLabel]; / / Erstellen der Texteingabe UITextField alloc ] initWithFrame : CGRectMake ( 10 , 120 , 300 , 30 ) ] ; Zahl = [[UITextField alloc] initWithFrame: CGRectMake (10, 120, 300, 30)]; numero.borderStyle = UITextBorderStyleRoundedRect; numero.textAlignment = UITextAlignmentCenter; numero.keyboardType = UIKeyboardTypeNumberPad; "Inserisci il numero" ; numero.placeholder = @ "Nummer eingeben"; numero ] ; [Window addSubview: Anzahl]; / / Erstellen der Taste UIButton buttonWithType : UIButtonTypeRoundedRect ] ; Taste = [UIButton buttonWithType: UIButtonTypeRoundedRect]; 10 , 180 , 300 , 30 ) ; bottone.frame = CGRectMake (10, 180, 300, 30); @ "Premi qui" forState : UIControlStateNormal ] ; [Button setTitle: @ "Hier klicken" forState: UIControlStateNormal]; self action : @selector ( controllaNumero ) forControlEvents : UIControlEventTouchUpInside ] ; [AddTarget Button: Selbst Aktion: @ selector (getNumber) forControlEvents: UIControlEventTouchUpInside]; bottone ] ; [Window addSubview: Taste]; ; [MyLabel release]; ; [NavigationItem release]; ; [MyNavigationBar release]; |
della scorsa volta, subito dopo il [mainWindow release]; inseriamo: Da das ' applicationDidFinishLaunching entspricht viewDidLoad wie beim letzten Mal, direkt nach dem [mainWindow release]; Einsatz:
1 | + arc4random ( ) % 10 ; numeroACaso = 1 + arc4random ()% 10; |
Jetzt können wir tun, ist die Methode umzusetzen controllaNumero , die gleich wird (abgesehen von dem Prototyp) zum letzten Mal benutzt ein:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 | void ) controllaNumero { - (Void) {getNumber "Premuto bottone di controlla numero" ) ; NSLog (@ "gedrückten Taste Steuerung Zahl"); [ numero.text integerValue ] ; int numeroInserito = [numero.text integerWert]; message; NSString * message; "Il numero inserito è %d" , numeroInserito ) ; NSLog (@ "Die eingegebene Zahl ist% d", numeroInserito); numeroInserito <numeroACaso ) { if (numeroInserito <numeroACaso) { "Troppo basso..." ; message = @ "zu niedrig ..."; ( numeroInserito> numeroACaso ) { } Else if (numeroInserito> numeroACaso) { "Troppo alto..." ; @ message = "Too high ..."; ( numeroInserito == numeroACaso ) { } Else if (numeroInserito numeroACaso ==) { "Bravo hai indovinato" ; @ message = "Bravo Sie haben es erraten"; + arc4random ( ) % 10 ; numeroACaso = 1 + arc4random ()% 10; "Numero pensato %d" , numeroACaso ) ; NSLog (@ "% d dachte:" numeroACaso); } [ [ UIAlertView alloc ] UIAlertView alertMessaggio * = [[UIAlertView alloc] "Responso" initWithTitle: @ "Response" Nachricht: Nachrichten Delegierter: nil "OK" cancelButtonTitle: @ "OK" ] ; otherButtonTitles: nil]; ; [AlertMessaggio Show]; ; [AlertMessaggio release]; "" ; numero.text @ = ""; } |
Wir sind fertig!
Schlussfolgerungen und Überlegungen
, proprio perchè volevo lasciarlo il più semplice e snello possibile e, anche, per dimostrare che non sono elementi sempre necessari. Dieses Beispiel macht nicht den direkten Einsatz eines UIView oder UIViewController , weil ich es so einfach und einheitlich wie möglich verlassen wollten und auch, um zu zeigen, dass die Elemente nicht immer notwendig sind. Allerdings kann das Einfügen von Objekten direkt im Fenster haben einen Sinn in diesem Beispiel und andere sporadische Kontexten. portano comunque benefici in tantissimi altri casi, ein alcuni sono praticamente indispensabili; come avremo modo di vedere in futuro. Die Verwendung von UIView und UIViewController noch Vorteile bringen in vielen anderen Fällen, undbei einige sind fast unverzichtbar, wie wir in Zukunft sehen werden.








Neueste Kommentare
Mark : Vielen Dank, ich habe angezündet
Ich löste es, indem Sie [cc_objc] / / OptionViewController.m - ...
Giovambattista Fazioli : @ Mark: Ich schlage vor, Sie denken, ein richtiger Ansatz. Wenn Sie das Unterklasse der Registerkarte ...
Mark : Entschuldigen Sie die Spam .. Ich bemerkte, dass es einen Fehler .. hier ist die Korrektur [cc_objc] / PrimaClasse.h **** / # import ...
Marco : vergessen .. in [IHK] OptionViewController [/ CCI] für [IHK] @ syntetize [/ CCI] Ich legte den Delegierten
Louis : sehr klar und einfach ich muss zugeben, dass das Schreiben eines pa kaum Delegaten verwenden, erstellt von ...