UIApplication总结Version0.6
( ̄ ︶  ̄)↗从老博客里搬过来的
一、程序启动UIApplicationMain
UIApplication
的基类是UIResponder
,和4.2以前生成的工程是不同的,以前是继承自NSObject
。
main
函数中执行了一个UIApplicationMain
这个函数
int UIApplicationMain(int argc, char argv[], NSString principalClassName, NSString *delegateClassName);
argc
、argv
:
直接传递给UIApplicationMain
进行相关处理即可
principalClassName
:
指定应用程序类名(app的象征),该类必须是UIApplication
(或子类)。如果为nil,则用UIApplication
类作为默认值
delegateClassName
:
指定应用程序的代理类,该类必须遵守UIApplicationDelegate
协议
1.UIApplicationMain
函数会根据principalClassName
创建UIApplication
对象
2.根据delegateClassName
创建一个delegate
对象 ,并将该delegate
对象赋值给UIApplication
对象中的delegate
属性.
3.接着会建立应用程序的Main Runloop
(事件循环),进行事件的处理(首先会在程序完毕后调用delegate
对象的application:didFinishLaunchingWithOptions:
方法)
4.程序正常退出时UIApplicationMain
函数才返回
二、UIApplication
1.简单介绍
iOS程序启动后创建的第一个对象就是UIApplication
对象,一个UIApplication
对象就代表一个应用程序.
每个应用都有自己的UIApplication对象
,且是单例.如果试图在程序中新建一个UIApplication
对象,那么将提示报错
通过[UIApplication sharedApplication]
可以获得这个单例对象.利用UIApplication
对象,能进行一些应用级别的操作.
UIApplication
的核心作用是提供iOS程序运行期间的控制和协作工作。
在程序开始运行的时候,UIApplicationMain
函数就是程序进入点,这个函数做了很多工作,其中一个重要的工作就是创建一个UIApplication
的单例实例.
UIApplication
的一个主要工作是处理用户事件,它会起一个队列,把所有用户事件都放入队列,逐个处理,在处理的时候,它会发送当前事件到一个合适的处理事件的目标控件.此外UIApplication
实例还维护一个在本应用中打开的window
列表(UIWindow
实例),这样它就可以接触应用中的任何一个UIView
对象.
UIApplication
实例会被赋予一个代理对象,以处理应用程序的生命周期事件(比如程序启动和关闭)、系统事件(比如来电、记事项警告)等等。
2.应用级别的操作示例
(1)设置应用程序图标右上角的红色提醒数字(如QQ消息的时候,图标上面会显示1,2,3条新信息等。) //0表示隐藏 [UIApplication sharedApplication].applicationIconBadgeNumber = 4;
这里还有个功能就是清除本地通知
看作者的意思,应该是他经常收到N多通知,而通过其中一条通知打开一个app以后,发现那个app的其它通知还在通知中心。作者不喜欢这样的情况。我以为我也存在的这样的情况,马上检查了一下,
发现没有。看来是少数app的问题。但是也记录一下。作者总结的从通知中心移除通知的三种方法:
1.将app的BadgeNumber设为0,就是app图标右上角那个
[[UIApplication sharedApplication] setApplicationIconBadgeNumber:0];
2.如果BadgeNumber本身就是0的情况,可以先将其设1再设置成0
[[UIApplication sharedApplication] setApplicationIconBadgeNumber:1];
[[UIApplication sharedApplication] setApplicationIconBadgeNumber:0];
3.如果以上的办法都不好使的话,那就用本地通知欺骗一下。
UIApplication* application = [UIApplication sharedApplication];
NSArray* scheduledNotifications = [NSArray arrayWithArray:application.scheduledLocalNotifications];
application.scheduledLocalNotifications = scheduledNotifications;
(2)设置联网指示器的可见性 [UIApplication sharedApplication].networkActivityIndicatorVisible=YES;
(3)管理状态栏 从iOS7开始,系统提供了2种管理状态栏的方式 info.plist
文件中,View controller-based status bar appearance
项设为YES
,则View controller
对status bar
的设置优先级高于application
的设置。 为NO则以application
的设置为准,view controller
的prefersStatusBarHidden
方法无效,是根本不会被调用的。
(4)UIApplication
有个功能十分强大的openURL:
方法
UIApplication *app = [UIApplication sharedApplication];
打电话
[app openURL:[NSURLURLWithString:@"tel://10086"]];
发短信
[app openURL:[NSURLURLWithString:@"sms://10086"]];
发邮件
[app openURL:[NSURLURLWithString:@"mailto://12345@qq.com"]];
打开网页
[app openURL:[NSURLURLWithString:@"http://ios.cn"]];
跳转到设置页面的对应项:
//比如打开wifi [app openURL:[NSURL URLWithString:@"prefs:root=WIFI"]]; About — prefs:root=General&path=About Accessibility — prefs:root=General&path=ACCESSIBILITY Airplane Mode On — prefs:root=AIRPLANE_MODE Auto-Lock — prefs:root=General&path=AUTOLOCK Brightness — prefs:root=Brightness Bluetooth — prefs:root=General&path=Bluetooth Date & Time — prefs:root=General&path=DATE_AND_TIME FaceTime — prefs:root=FACETIME General — prefs:root=General Keyboard — prefs:root=General&path=Keyboard iCloud — prefs:root=CASTLE iCloud Storage & Backup — prefs:root=CASTLE&path=STORAGE_AND_BACKUP International — prefs:root=General&path=INTERNATIONAL Location Services — prefs:root=LOCATION_SERVICES Music — prefs:root=MUSIC Music Equalizer — prefs:root=MUSIC&path=EQ Music Volume Limit — prefs:root=MUSIC&path=VolumeLimit Network — prefs:root=General&path=Network Nike + iPod — prefs:root=NIKE_PLUS_IPOD Notes — prefs:root=NOTES Notification — prefs:root=NOTIFICATIONS_ID Phone — prefs:root=Phone Photos — prefs:root=Photos Profile — prefs:root=General&path=ManagedConfigurationList Reset — prefs:root=General&path=Reset Safari — prefs:root=Safari Siri — prefs:root=General&path=Assistant Sounds — prefs:root=Sounds Software Update — prefs:root=General&path=SOFTWARE_UPDATE_LINK Store — prefs:root=STORE Twitter — prefs:root=TWITTER Usage — prefs:root=General&path=USAGE VPN — prefs:root=General&path=Network/VPN Wallpaper — prefs:root=Wallpaper Wi-Fi — prefs:root=WIFI
openURL
方法,可以打开其他APP
要用到 URL Scheme
(5)设置摇动手势的时候,是否支持redo,undo操作 3.0以后引进,默认YES
[UIApplication sharedApplication].applicationSupportsShakeToEdit =YES;
(6)判断程序运行状态 在2.0以后引入
UIApplicationStateActive, UIApplicationStateInactive, UIApplicationStateBackground
if([UIApplicationsharedApplication].applicationState ==UIApplicationStateInactive){ NSLog(@"程序在运行状态"); }
(7)阻止屏幕变暗进入休眠状态 ,耗电,慎重默认NO
[UIApplicationsharedApplication].idleTimerDisabled =YES;
(8)在map上显示一个地址
NSString addressText = @"1 Infinite Loop, Cupertino, CA 95014";
addressText = [addressText stringByAddingPercentEscapesUsingEncoding:NSASCIIStringEncoding];
NSString urlText = [NSString stringWithFormat:@"http://maps.google.com/maps?q=%@", addressText];
[[UIApplication sharedApplication]openURL:[NSURLURLWithString:urlText]];
三、UIApplication Delegate
UIApplication
接收到所有的系统事件和生命周期事件时,都会把事件传递给UIApplicationDelegate
进行处理,对于用户输入事件,则传递给相应的目标对象去处理.比如我们在应用程序被来电等消息后,可以调用应用程序委托类的applicationWillResignActive()
方法,这个方法在用户锁住屏幕时,也会调用.与之相适应的是应用程序重新被用户打开时的委托方法.另外常用的就是内存不足的系统警告,此时会调用应用程序委托类的applicationDidReceiveMemoryWarning()
方法, 然后我们就可以试着释放一些内存了.
UIApplication对象实例化后,程序启动时首先会调用该方法。
- (BOOL)application:(UIApplication )application didFinishLaunchingWithOptions:(NSDictionary )launchOptions
1、- (void)applicationWillResignActive:(UIApplication *)application
说明:通知委托应用程序将要进入非活动状态执行,在此期间,应用程序不接收消息或事件,比如来电话了、锁屏等。
2、- (void)applicationDidBecomeActive:(UIApplication *)application
说明:当应用程序入活动状态执行,请恢复数据,这个刚好跟上面那个方法相反
3、- (void)applicationDidEnterBackground:(UIApplication *)application
说明:当程序被推送到后台的时候调用。所以要设置后台继续运行,则在这个函数里面设置即可
4、- (void)applicationWillEnterForeground:(UIApplication *)application
说明:当程序从后台将要重新回到前台时候调用,这个刚好跟上面的那个方法相反。
5、- (void)applicationWillTerminate:(UIApplication *)application
说明:当程序将要退出时被调用,通常是用来保存数据和一些退出前的清理工作。这个需要要设置UIApplicationExitsOnSuspend的键值。
6、- (void)applicationDidReceiveMemoryWarning:(UIApplication *)application
说明:iPhone设备只有有限的内存,如果为应用程序分配了太多内存操作系统会终止应用程序的运行,在终止前会执行这个方法,通常可以在这里进行内存清理工作防止程序被终止
7、- (void)applicationSignificantTimeChange:(UIApplication*)application
说明:当系统时间发生改变时执行(主要是指时间属性,而不是具体的时间值)
8、- (void)applicationDidFinishLaunching:(UIApplication*)application
说明:当程序载入后执行
9、- (void)application:(UIApplication)application willChangeStatusBarFrame:(CGRect)newStatusBarFrame
说明:当StatusBar框将要变化时执行
10、- (void)application:(UIApplication*)application willChangeStatusBarOrientation: (UIInterfaceOrientation)newStatusBarOrientation duration:(NSTimeInterval)duration
说明:当StatusBar框方向将要变化时执行,控制状态栏方位变化
11、- (BOOL)application:(UIApplication)application handleOpenURL:(NSURL)url
说明:当通过url执行,打开指定的URL
12、- (void)application:(UIApplication*)application didChangeStatusBarOrientation:(UIInterfaceOrientation)oldStatusBarOrientation
说明:当StatusBar框方向变化完成后执行,设备方向将要发生改变
13、- (void)application:(UIApplication*)application didChangeSetStatusBarFrame:(CGRect)oldStatusBarFrame
说明:当StatusBar框变化完成后执行
14、- (BOOL) application:(UIApplication *)application shouldSaveApplicationState:(NSCoder *)coder
15、- (void) application:(UIApplication *)application willEncodeRestorableStateWithCoder:(NSCoder *)coder
16、- (void) application:(UIApplication *)application didDecodeRestorableStateWithCoder:(NSCoder *)coder
iPhone中的应用程序很容易受到打扰,比如一个来电可能导致应用程序失去焦点,如果这个时候接听了电话,那么应用程序会转到后台运行。还有很多 其它类似的事件会导致iPhone应用程序失去焦点,在应用程序失去焦点前会调用委托类的applicationWillResignActive()
方 法,而应用程序再次获取到焦点的时候会调用applicationDidBecomeActive()
方法。比如在运行应用程序的时候锁屏会调用委托类的 applicationWillResignActive()
方法,而当屏幕被解锁的时候,又会调用 applicationDidBecomeActive()
方法。
另外一个非常重要的方法就是applicationDidReceiveMemoryWarning()
,因为iPhone设备只有有限的内存,如果为应用程序分配了太多内存操作系统会终止应用程序的运行,但在终止之前操作系统会通过先调用委托类的 applicationDidReceiveMemoryWarning()
方法警告应用程序,在UIApplication
接收到这个事件后它会传递给 委托类的applicationDidReceiveMemoryWarning()
方法,委托类在这个方法内可以进行释放内存的操作以防止操作系统强制 终止应用程序的运行。
![](https://img.haomeiwen.com/i301562/862aa5c43597bae1.png)