1、UIApplication介绍
-
1.1 UIApplication类介绍
- UIApplication的核心作用是提供了iOS程序运行期间的控制和协作工作。
- 每一个程序在运行期必须有且仅有一个UIApplication(或则其子类)的一个实例。回想一下我在前面的文章“main函数研究”的文章中提到的main函数的代码,可以看出,在程序开始运行的时候,UIApplicationMain函数是程序进入点,这个函数做了很多工作,其中一个重要的工作就是创建一个UIApplication的单例实例。在你的代码中你,你可以通过调用[UIApplication sharedApplication]来得到这个单例实例的指针。
- UIApplication的一个主要工作是处理用户事件,它会起一个队列,把所有用户事件都放入队列,逐个处理,在处理的时候,它会发送当前事件到一个合适的处理事件的目标控件。此外,UIApplication实例还维护一个在本应用中打开的window列表(UIWindow实例),这样它就可以接触应用中的任何一个UIView对象。UIApplication实例会被赋予一个代理对象,以处理应用程序的生命周期事件(比如程序启动和关闭)、系统事件(比如来电、记事项警告)等等。
- 新建一个任意类型的iOS应用工程,加入我们在Class Prefix输入是TC,我们可以看到工程中生成一个类:
TCAppDelegate :UIResponder - 这里这个类的基类是UIResponder,和4.2以前生成的工程是不同的,以前是继承自NSObject。不论如何,本类实现了一个名叫UIApplicationDelegate的接口,这个表明这个类就是这个工程中UIApplication实例的代理类。
- 在main函数中,
@autoreleasepool { returnUIApplicationMain(argc, argv, nil,NSStringFromClass([TCAppDelegateclass])); }
- 这里传入了代理类到UIApplicationMain函数中,UIApplicationMain函数在生成唯一个UIApplication的时候就可以把代理类的实例指针告诉这个单例对象了。
-
1.2 UIApplication内键值介绍
- launchOptions中的可能键值见UIApplication Class Reference的Launch Options Keys节 。
- 若用户直接启动,lauchOptions内无数据;
- 若由其他应用程序通过openURL:启动,则UIApplicationLaunchOptionsURLKey对应的对象为启动URL(NSURL),UIApplicationLaunchOptionsSourceApplicationKey对应启动的源应用程序的bundle ID (NSString);
- 若由本地通知启动,则UIApplicationLaunchOptionsLocalNotificationKey对应的是为启动应用程序的的本地通知对象(UILocalNotification);
- 若由远程通知启动,则UIApplicationLaunchOptionsRemoteNotificationKey对应的是启动应用程序的的远程通知信息userInfo(NSDictionary);
- 其他key还有UIApplicationLaunchOptionsAnnotationKey, UIApplicationLaunchOptionsLocationKey, UIApplicationLaunchOptionsNewsstandDownloadsKey。
- 如果要在启动时,做出一些区分,那就需要在下面的代码做处理。
- 比如:您的应用可以被某个其它应用调起(作为该应用的子应用),要实现单点登录,那就需要在启动代码的地方做出合理的验证,并跳过登录。
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions { NSURL *url = [options objectForKey:UIApplicationLaunchOptionsURLKey]; if(url) { } NSString *bundleId = [options objectForKey:UIApplicationLaunchOptionsSourceApplicationKey]; if(bundleId) { } UILocalNotification *localNotify = [options objectForKey:UIApplicationLaunchOptionsLocalNotificationKey]; if(localNotify) { } NSDictionary *userInfo = [options objectForKey:UIApplicationLaunchOptionsRemoteNotificationKey]; if(userInfo) { } }
2、UIApplication代理方法
-
2.1 直接应用
-
2.2 本地详细介绍
/************ 当程序载入后执行,应用程序启动入口 *****************************/ - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions { NSLog(@"当程序载入后执行"); NSURL *url = [launchOptions objectForKey:UIApplicationLaunchOptionsURLKey]; if(url) { } NSString *bundleId = [launchOptions objectForKey:UIApplicationLaunchOptionsSourceApplicationKey]; if(bundleId) { } UILocalNotification * localNotify = [launchOptions objectForKey:UIApplicationLaunchOptionsLocalNotificationKey]; if(localNotify) { } NSDictionary * userInfo = [launchOptions objectForKey:UIApplicationLaunchOptionsRemoteNotificationKey]; if(userInfo) { } } - 说明:当程序载入后执行,应用程序启动入口。 - 只在应用程序启动时执行一次。也就是说在应用程序启动后,要执行的委托调用。application参数用来获取应用程序的状态、变量等,值得注意的是字典参数:(NSDictionary *)launchOptions,该参数存储程序启动的原因。 - 若用户直接启动,lauchOptions内无数据; - 若由其他应用程序通过openURL:启动,则UIApplicationLaunchOptionsURLKey对应的对象为启动 URL(NSURL),UIApplicationLaunchOptionsSourceApplicationKey对应启动的源应用程序的 bundle ID (NSString); - 若由本地通知启动,则UIApplicationLaunchOptionsLocalNotificationKey对应的是为启动应用程序的的本地通知对象(UILocalNotification); - 若由远程通知启动,则UIApplicationLaunchOptionsRemoteNotificationKey对应的是启动应用程序的的远程通知信息userInfo(NSDictionary); - 其他key还有UIApplicationLaunchOptionsAnnotationKey,UIApplicationLaunchOptionsLocationKey,UIApplicationLaunchOptionsNewsstandDownloadsKey。 - 如果要在启动时,做出一些区分,那就需要在下面的代码做处理。比如:应用可以被某个其它应用调起(作为该应用的子应用),要实现单点登录,那就需要在启动代码的地方做出合理的验证,并跳过登录。 /************ 应用程序将要进入非活动状态,即将进入后台 *****************************/ - (void)applicationWillResignActive:(UIApplication *)application { NSLog(@"应用程序将要进入非活动状态,即将进入后台"); } 在应用程序将要由活动状态切换到非活动状态时候,要执行的委托调用, 如按下home按钮,返回主屏幕,或全屏之间切换应用程序等。 说明:当应用程序将要进入非活动状态时执行,在此期间,应用程序不接收消息或事件,比如来电话了。 /************ 当程序被推送到后台的时候调用 *****************************/ - (void)applicationDidEnterBackground:(UIApplication *)application { NSLog(@"如果应用程序支持后台运行,则应用程序已经进入后台运行"); } 说明:当程序被推送到后台的时候调用。所以要设置后台继续运行,则在这个函数里面设置即可 /************ 当程序从后台将要重新回到前台时候调用 *****************************/ - (void)applicationWillEnterForeground:(UIApplication *)application { NSLog(@"应用程序将要进入活动状态,即将进入前台运行"); } 说明:当程序从后台将要重新回到前台时候调用,这个刚好跟上面的那个方法相反。 /************ 当应用程序进入活动状态时执行 *****************************/ - (void)applicationDidBecomeActive:(UIApplication *)application { NSLog(@"应用程序已进入前台,处于活动状态"); } 说明:当应用程序进入活动状态时执行,这个刚好跟上面那个方法相反 。 /************ 当程序将要退出是被调用 *****************************/ - (void)applicationWillTerminate:(UIApplication *)application { NSLog(@"应用程序将要退出,通常用于保存数据和一些退出前的清理工作"); } 说明:当程序将要退出是被调用,通常是用来保存数据和一些退出前的清理工作。这个需要要设置UIApplicationExitsOnSuspend的键值。 /************ 系统内存不足,需要进行清理工作 *****************************/ - (void)applicationDidReceiveMemoryWarning:(UIApplication *)application { NSLog(@"系统内存不足,需要进行清理工作"); } 说明:iPhone设备只有有限的内存,如果为应用程序分配了太多内存操作系统会终止应用程序的运行,在终止前会执行这个方法,通常可以在这里进行内存清理工作防止程序被终止。 /************ 当系统时间发生改变时执行 *****************************/ - (void)applicationSignificantTimeChange:(UIApplication *)application { NSLog(@"当系统时间发生改变时执行"); } 说明:当系统时间发生改变时执行 /************ 当StatusBar框将要变化时执行 *****************************/ - (void)application:(UIApplication)application willChangeStatusBarFrame:(CGRect)newStatusBarFrame { NSLog(@"StatusBar框将要变化"); } 说明:当StatusBar框将要变化时执行 /************ 当StatusBar框方向将要变化时执行 *****************************/ - (void)application:(UIApplication*)application willChangeStatusBarOrientation:(UIInterfaceOrientation)newStatusBarOrientation duration:(NSTimeInterval)duration { } 说明:当StatusBar框方向将要变化时执行 /************ 当通过url执行 *****************************/ - (BOOL)application:(UIApplication*)application handleOpenURL:(NSURL*)url { } 说明:当通过url执行 /************ 当StatusBar框方向变化完成后执行 *****************************/ - (void)application:(UIApplication*)application didChangeStatusBarOrientation:(UIInterfaceOrientation)oldStatusBarOrientation { } 说明:当StatusBar框方向变化完成后执行 /************ 当StatusBar框变化完成后执行 *****************************/ - (void)application:(UIApplication*)application didChangeSetStatusBarFrame:(CGRect)oldStatusBarFrame { } 说明:当StatusBar框变化完成后执行
-
2.3 另外还有一些协议方法需要知道:
Handling Remote Notifications (处理远程消息) /************ 当一个运行着的应用程序收到一个远程的通知 *****************************/ - (void)application:(UIApplication *) applicationdidReceiveRemoteNotification:(NSDictonary *) userinfo 说明:当一个运行着的应用程序收到一个远程的通知 发送到委托去... /************ 当一个应用程序成功的注册一个推送服务(APS) *****************************/ - (void)application:(UIApplication *) applicationdidRegisterForRemoteNotificationsWithDeviceToken:(NSData *) deviceToken 说明:当一个应用程序成功的注册一个推送服务(APS) 发送到委托去... /************ 当 APS无法成功的完成向 程序进程推送时 *****************************/ - (void)application:(UIApplication *) applicationdidFailToRegisterForRemoteNotificationsWithError:(NSError *) error 说明:当 APS无法成功的完成向 程序进程推送时 发送到委托去... Handling Local Notification (处理本地消息) /************ 当一个运行着的应用程序收到一个本地的通知 *****************************/ - (void)application:(UIApplication *) applicationdidReceiveLocalNotification:(UILocalNotification *)notification 说明:当一个运行着的应用程序收到一个本地的通知 发送到委托去...
3、UIApplication设置
- iPhone中的应用程序很容易受到打扰,比如一个来电可能导致应用程序失去焦点,如果这个时候接听了电话,那么应用程序会转到后台运行。还有很多其它类似的事件会导致iPhone应用程序失去焦点,在应用程序失去焦点前会调用委托类的applicationWillResignActive()方法,而应用程序再次获取到焦点的时候会调用applicationDidBecomeActive()方法。比如在运行应用程序的时候锁屏会调用委托类的applicationWillResignActive()方法,而当屏幕被解锁的时候,又会调用applicationDidBecomeActive()方法。
- 另外一个非常重要的方法就是applicationDidReceiveMemoryWarning(),因为iPhone设备只有有限的内存,如果为应用程序分配了太多内存操作系统会终止应用程序的运行,但在终止之前操作系统会通过先调用委托类的applicationDidReceiveMemoryWarning()方法警告应用程序,在UIApplication接收到这个事件后它会传递给委托类的applicationDidReceiveMemoryWarning()方法,委托类在这个方法内可以进行释放内存的操作以防止操作系统强制终止应用程序的运行。
- 下面是这个类的一些功能:
-
3.1 设置icon上的数字图标
//设置主界面icon上的数字图标,在2.0中引进, 缺省为0 [UIApplicationsharedApplication].applicationIconBadgeNumber = 4;
-
3.2设置摇动手势的时候,是否支持redo,undo操作
//摇动手势,是否支持redo undo操作。 //3.0以后引进,缺省YES [UIApplicationsharedApplication].applicationSupportsShakeToEdit =YES;
-
3.3 判断程序运行状态
//判断程序运行状态,在2.0以后引入 /* UIApplicationStateActive, UIApplicationStateInactive, UIApplicationStateBackground */ if([UIApplicationsharedApplication].applicationState ==UIApplicationStateInactive){ NSLog(@"程序在运行状态"); }
-
3.4 阻止屏幕变暗进入休眠状态
//阻止屏幕变暗,慎重使用,缺省为no 2.0 [UIApplicationsharedApplication].idleTimerDisabled =YES; 慎重使用本功能,因为非常耗电。
-
3.5 显示联网状态
// 显示联网标记 2.0 [UIApplicationsharedApplication].networkActivityIndicatorVisible =YES;
-
3.6 在map上显示一个地址
NSString* addressText =@"1 Infinite Loop, Cupertino, CA 95014"; // URL encode the spaces addressText = [addressTextstringByAddingPercentEscapesUsingEncoding:NSASCIIStringEncoding]; NSString* urlText = [NSStringstringWithFormat:@"http://maps.google.com/maps?q=%@", addressText]; [[UIApplicationsharedApplication]openURL:[NSURLURLWithString:urlText]];
-
3.7 发送电子邮件
NSString *recipients =@"mailto:first@example.com?cc=second@example.com,third@example.com&subject=Hello from California!"; NSString *body =@"&body=It is raining in sunny California!"; NSString *email = [NSStringstringWithFormat:@"%@%@", recipients, body]; email = [emailstringByAddingPercentEscapesUsingEncoding:NSUTF8StringEncoding]; [[UIApplicationsharedApplication]openURL:[NSURLURLWithString:email]];
-
3.8 打电话到一个号码
// Call Google 411 [[UIApplicationsharedApplication]openURL:[NSURLURLWithString:@"tel://8004664411"]];
-
3.9 发送短信
// Text to Google SMS [[UIApplicationsharedApplication]openURL:[NSURLURLWithString:@"sms://466453"]];
-
3.10 打开一个网址
// Lanuch any iPhone developers fav site [[UIApplicationsharedApplication]openURL:[NSURLURLWithString:@"http://itunesconnect.apple.com"]];