您的位置:首页 > 移动开发 > IOS开发

ios学习-delegate、传值、跳转页面

2014-04-04 16:14 302 查看
1.打开xcode,然后选择ios--Application--Empty Application一个空项目。

项目目录:





2.输入项目名称以及选择保存路径即可。



3.创建文件夹Model、Controller。

4.Model文件夹创建User类:User.h User.m





代码:

User.h:

#import <Foundation/Foundation.h>

@interface User : NSObject
@property  (nonatomic, retain) NSString *name;
@property  (nonatomic, retain) NSString *pword;
@end


User.m:

#import "User.h"

@implementation User
@synthesize name;
@synthesize pword;
@end


5.创建controller文件里的4个文件。

TLViewController.h:

#import <UIKit/UIKit.h>
#import "UserDelegate.h"
@interface TLViewController : UIViewController<UserDelegate>

@end


UserDelegate协议类在后面。

TLViewController.m:

#import "TLViewController.h"
#import "User.h"
#import "AddViewController.h"
@interface TLViewController ()

@end

@implementation TLViewController{
UILabel *labelname ;
UILabel *labelpwd ;
User *user;
}

- (id)initWithNibName:(NSString *)nibNameOrNil bundle:(NSBundle *)nibBundleOrNil
{
self = [super initWithNibName:nibNameOrNil bundle:nibBundleOrNil];
if (self) {
}
return self;
}

- (void)viewDidLoad
{

//显示用户名
labelname = [[UILabel alloc]initWithFrame:CGRectMake(50, 20, 200, 50)];
//设置显示文字

labelname.text =[NSString stringWithFormat:@"用户名:%@",user.name];
//设置字体:粗体,正常的是 SystemFontOfSize
labelname.font = [UIFont boldSystemFontOfSize:20];
//设置文字颜色
labelname.textColor = [UIColor blackColor];
[self.view addSubview:labelname];
[labelname release];

//显示密码
labelpwd = [[UILabel alloc]initWithFrame:CGRectMake(50, 70., 200, 50)];
//设置显示文字
labelpwd.text = [NSString stringWithFormat:@"密   码:%@",user.pword];
//设置字体:粗体,正常的是 SystemFontOfSize
labelpwd.font = [UIFont boldSystemFontOfSize:20];
//设置文字颜色
labelpwd.textColor = [UIColor blackColor];
[self.view addSubview:labelpwd];
[labelpwd release];

UIButton *btnAdd=[[UIButton alloc] initWithFrame:CGRectMake(10, 130, 300, 30)];
[btnAdd setTitle:@"返    回" forState:UIControlStateNormal];
[btnAdd setTitleColor:[UIColor whiteColor] forState:UIControlStateNormal];

[btnAdd.titleLabel setFont:[UIFont boldSystemFontOfSize:20]];
btnAdd.backgroundColor = [UIColor redColor];
[btnAdd addTarget:self action:@selector(BackView) forControlEvents :UIControlEventTouchUpInside];
[self.view addSubview:btnAdd];
[btnAdd release];

[super viewDidLoad];

}
-(void)BackView{
//    AddViewController *ad=[[AddViewController alloc] init];

[self dismissViewControllerAnimated:YES completion:nil];
//    [ad release];
}

-(void)setValue:(User *)userValue{
user=userValue;
}

- (void)didReceiveMemoryWarning
{
[super didReceiveMemoryWarning];
// Dispose of any resources that can be recreated.
}

@end


AddViewController.h:

#import <UIKit/UIKit.h>
#import "UserDelegate.h"
@interface AddViewController : UIViewController<UITextFieldDelegate>{
id<UserDelegate> deleage;
}
@property(assign,nonatomic)id<UserDelegate> delegate;

@end


AddViewController.m:

#import "AddViewController.h"
#import "User.h"
#import "TLViewController.h"

@interface AddViewController ()
{
UITextField *tfname;
UITextField *tfpassword;
}
@end

@implementation AddViewController- (id)initWithNibName:(NSString *)nibNameOrNil bundle:(NSBundle *)nibBundleOrNil
{
self = [super initWithNibName:nibNameOrNil bundle:nibBundleOrNil];
if (self) {
// 下一个界面的返回按钮
UIBarButtonItem *temporaryBarButtonItem = [[UIBarButtonItem alloc] init];
temporaryBarButtonItem.title = @"返回";

self.navigationItem.backBarButtonItem = temporaryBarButtonItem;
[temporaryBarButtonItem release];

}
return self;
}
@synthesize delegate;
- (void)viewDidLoad
{
[super viewDidLoad];

UILabel *lname = [[UILabel alloc]initWithFrame:CGRectMake(10, 40, 100, 30)];
//设置显示文字
lname.text = @"用户名:";
//设置字体:粗体,正常的是 SystemFontOfSize
lname.font = [UIFont boldSystemFontOfSize:20];
//设置文字颜色
lname.textColor = [UIColor blackColor];
lname.textAlignment=NSTextAlignmentRight;
[self.view addSubview:lname];
[lname release];

UILabel *lpassword = [[UILabel alloc]initWithFrame:CGRectMake(10, 80, 100, 30)];
//设置显示文字
lpassword.text = @"密   码:";
//设置字体:粗体,正常的是 SystemFontOfSize
lpassword.font = [UIFont boldSystemFontOfSize:20];
//设置文字颜色
lpassword.textColor = [UIColor blackColor];
lpassword.textAlignment=NSTextAlignmentRight;
[self.view addSubview:lpassword];
[lpassword release];

tfname= [[UITextField alloc] initWithFrame:CGRectMake(110, 40, 200, 30)];
[tfname setBorderStyle:UITextBorderStyleRoundedRect]; //外框类型
tfname.placeholder = @"请输入用户名"; //默认显示的字
tfname.delegate = self;
[self.view addSubview:tfname];
[tfname release];

tfpassword= [[UITextField alloc] initWithFrame:CGRectMake(110, 80, 200, 30)];
[tfpassword setBorderStyle:UITextBorderStyleRoundedRect]; //外框类型
tfpassword.placeholder = @"请输入密码"; //默认显示的字
tfpassword.delegate = self;
tfpassword.secureTextEntry = YES; //密码
[self.view addSubview:tfpassword];
[tfpassword release];

UIButton *btnAdd=[[UIButton alloc] initWithFrame:CGRectMake(10, 130, 300, 30)];
[btnAdd setTitle:@"登       陆" forState:UIControlStateNormal];
[btnAdd setTitle:@"登陆中......" forState:UIControlStateHighlighted];

[btnAdd setTitleColor:[UIColor whiteColor] forState:UIControlStateNormal];
[btnAdd setTitleColor:[UIColor blueColor] forState:UIControlStateHighlighted];
[btnAdd.titleLabel setFont:[UIFont boldSystemFontOfSize:20]];
btnAdd.backgroundColor = [UIColor redColor];
[btnAdd addTarget:self action:@selector(LoginUser) forControlEvents :UIControlEventTouchUpInside];
[self.view addSubview:btnAdd];
[btnAdd release];

// 创建自定义的触摸手势来实现对键盘的隐藏
UITapGestureRecognizer *tapGr = [[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(viewTapped:)];
tapGr.cancelsTouchesInView = NO;
[self.view addGestureRecognizer:tapGr];

}

//键盘的隐藏
-(void)viewTapped:(UITapGestureRecognizer*)tapGr{
[tfname resignFirstResponder];
[tfpassword resignFirstResponder];
}

//登陆并跳转
-(void)LoginUser{
NSLog(@"%@",tfname.text);
TLViewController *tv=[[TLViewController alloc] init];
self.delegate=tv;
User *user=[[User alloc] init];
user.name=tfname.text;
user.pword=tfpassword.text;
[self.delegate setValue:user];
tv.modalTransitionStyle=UIModalTransitionStyleCrossDissolve;
[self presentModalViewController:tv  animated:YES];
[user release];
[tv release];

}
- (BOOL)textFieldShouldReturn:(UITextField *)textField
{
[textField resignFirstResponder];
return YES;
}

- (void)didReceiveMemoryWarning
{
[super didReceiveMemoryWarning];
// Dispose of any resources that can be recreated.
}

@end


6.创建UserDelegate类:

UserDelegate.h:

#import <Foundation/Foundation.h>
#import "User.h"

@protocol UserDelegate <NSObject>
-(void)setValue:(User *)userValue;
@end


7.AppDelegate文件:

AppDelegate.h

#import <UIKit/UIKit.h>
@class TLViewController;
@class AddViewController;

@interface AppDelegate : UIResponder <UIApplicationDelegate>

@property (strong, nonatomic) UIWindow *window;

@property (readonly, strong, nonatomic) NSManagedObjectContext *managedObjectContext;
@property (readonly, strong, nonatomic) NSManagedObjectModel *managedObjectModel;
@property (readonly, strong, nonatomic) NSPersistentStoreCoordinator *persistentStoreCoordinator;
//自定义控件
//@property (strong, nonatomic) TLViewController *viewController;
@property (strong, nonatomic) AddViewController *addviewController;

- (void)saveContext;
- (NSURL *)applicationDocumentsDirectory;

@end


AppDelegate.m:

#import "AppDelegate.h"
#import "TLViewController.h"
#import "AddViewController.h"
@implementation AppDelegate

@synthesize managedObjectContext = _managedObjectContext;
@synthesize managedObjectModel = _managedObjectModel;
@synthesize persistentStoreCoordinator = _persistentStoreCoordinator;

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{
self.window = [[UIWindow alloc] initWithFrame:[[UIScreen mainScreen] bounds]];
// Override point for customization after application launch.
self.window.backgroundColor = [UIColor whiteColor];
self.addviewController = [[AddViewController alloc] init];
self.window.rootViewController = self.addviewController;

[self.window makeKeyAndVisible];
return YES;
}

- (void)applicationWillResignActive:(UIApplication *)application
{
// Sent when the application is about to move from active to inactive state. This can occur for certain types of temporary interruptions (such as an incoming phone call or SMS message) or when the user quits the application and it begins the transition to the background state.
// Use this method to pause ongoing tasks, disable timers, and throttle down OpenGL ES frame rates. Games should use this method to pause the game.
}

- (void)applicationDidEnterBackground:(UIApplication *)application
{
// Use this method to release shared resources, save user data, invalidate timers, and store enough application state information to restore your application to its current state in case it is terminated later.
// If your application supports background execution, this method is called instead of applicationWillTerminate: when the user quits.
}

- (void)applicationWillEnterForeground:(UIApplication *)application
{
// Called as part of the transition from the background to the inactive state; here you can undo many of the changes made on entering the background.
}

- (void)applicationDidBecomeActive:(UIApplication *)application
{
// Restart any tasks that were paused (or not yet started) while the application was inactive. If the application was previously in the background, optionally refresh the user interface.
}

- (void)applicationWillTerminate:(UIApplication *)application
{
// Saves changes in the application's managed object context before the application terminates.
[self saveContext];
}

- (void)saveContext
{
NSError *error = nil;
NSManagedObjectContext *managedObjectContext = self.managedObjectContext;
if (managedObjectContext != nil) {
if ([managedObjectContext hasChanges] && ![managedObjectContext save:&error]) {
// Replace this implementation with code to handle the error appropriately.
// abort() causes the application to generate a crash log and terminate. You should not use this function in a shipping application, although it may be useful during development.
NSLog(@"Unresolved error %@, %@", error, [error userInfo]);
abort();
}
}
}

#pragma mark - Core Data stack

// Returns the managed object context for the application.
// If the context doesn't already exist, it is created and bound to the persistent store coordinator for the application.
- (NSManagedObjectContext *)managedObjectContext
{
if (_managedObjectContext != nil) {
return _managedObjectContext;
}

NSPersistentStoreCoordinator *coordinator = [self persistentStoreCoordinator];
if (coordinator != nil) {
_managedObjectContext = [[NSManagedObjectContext alloc] init];
[_managedObjectContext setPersistentStoreCoordinator:coordinator];
}
return _managedObjectContext;
}

// Returns the managed object model for the application.
// If the model doesn't already exist, it is created from the application's model.
- (NSManagedObjectModel *)managedObjectModel
{
if (_managedObjectModel != nil) {
return _managedObjectModel;
}
NSURL *modelURL = [[NSBundle mainBundle] URLForResource:@"Login" withExtension:@"momd"];
_managedObjectModel = [[NSManagedObjectModel alloc] initWithContentsOfURL:modelURL];
return _managedObjectModel;
}

// Returns the persistent store coordinator for the application.
// If the coordinator doesn't already exist, it is created and the application's store added to it.
- (NSPersistentStoreCoordinator *)persistentStoreCoordinator
{
if (_persistentStoreCoordinator != nil) {
return _persistentStoreCoordinator;
}

NSURL *storeURL = [[self applicationDocumentsDirectory] URLByAppendingPathComponent:@"Login.sqlite"];

NSError *error = nil;
_persistentStoreCoordinator = [[NSPersistentStoreCoordinator alloc] initWithManagedObjectModel:[self managedObjectModel]];
if (![_persistentStoreCoordinator addPersistentStoreWithType:NSSQLiteStoreType configuration:nil URL:storeURL options:nil error:&error]) {
/*
Replace this implementation with code to handle the error appropriately.

abort() causes the application to generate a crash log and terminate. You should not use this function in a shipping application, although it may be useful during development.

Typical reasons for an error here include:
* The persistent store is not accessible;
* The schema for the persistent store is incompatible with current managed object model.
Check the error message to determine what the actual problem was.

If the persistent store is not accessible, there is typically something wrong with the file path. Often, a file URL is pointing into the application's resources directory instead of a writeable directory.

If you encounter schema incompatibility errors during development, you can reduce their frequency by:
* Simply deleting the existing store:
[[NSFileManager defaultManager] removeItemAtURL:storeURL error:nil]

* Performing automatic lightweight migration by passing the following dictionary as the options parameter:
@{NSMigratePersistentStoresAutomaticallyOption:@YES, NSInferMappingModelAutomaticallyOption:@YES}

Lightweight migration will only work for a limited set of schema changes; consult "Core Data Model Versioning and Data Migration Programming Guide" for details.

*/
NSLog(@"Unresolved error %@, %@", error, [error userInfo]);
abort();
}

return _persistentStoreCoordinator;
}

#pragma mark - Application's Documents directory

// Returns the URL to the application's Documents directory.
- (NSURL *)applicationDocumentsDirectory
{
return [[[NSFileManager defaultManager] URLsForDirectory:NSDocumentDirectory inDomains:NSUserDomainMask] lastObject];
}

@end


效果图:





本项目传值用到delegate委托,可以可以用更加单的方法传值,就是在B页面定义一个User类,在A页面初始化B时进行赋值:如b.user=user1;

点击空白区域隐藏键盘,基本都是简单的一个demo而已,仅供参考学习。

项目如果报:release不能使用。

ARC forbids explicit message send of'release'
'release' is unavailable: not available inautomatic reference counting mode

解决办法:
打开当前工程,打开"Build Settings",找到Objective-C Automatic Reference Counting项,将它的值设置为NO。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: