Swift初体验ios新知识iOS开发

UIApplication总结Version0.6

2015-08-03  本文已影响569人  石丘

( ̄ ︶  ̄)↗从老博客里搬过来的

一、程序启动UIApplicationMain

UIApplication的基类是UIResponder,和4.2以前生成的工程是不同的,以前是继承自NSObject

main函数中执行了一个UIApplicationMain这个函数

int UIApplicationMain(int argc, char argv[], NSString principalClassName, NSString *delegateClassName);

argcargv:

直接传递给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 controllerstatus bar的设置优先级高于application的设置。 为NO则以application的设置为准,view controllerprefersStatusBarHidden方法无效,是根本不会被调用的。

(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()方法,委托类在这个方法内可以进行释放内存的操作以防止操作系统强制 终止应用程序的运行。

application生命周期.png
上一篇 下一篇

猜你喜欢

热点阅读