AppDelegate.m
文件是一个管理整个应用程序生命周期的类。UIApplication
继承自UIResponder
,的主要作用是提供了iOS程序运行期间的控制和协作工作,每个iOS程序运行期间都会有一个UIApplication
实例,,UIApplication
是iPhone应用程序的开始并且负责初始化并显示 UIWindow
,并负责加载应用程序的第一个UIView到UIWindow
窗体中。UIApplication
的另一个任务是帮助管理应用程序的生命周期,而UIApplication
通过UIApplicationDelegate
代理类来履行这个任务。尽管 UIApplication
会负责接收事件,而UIApplicationDelegate
则决定应用程序如何去响应这些事件,UIApplicationDelegate
可以处理的事件包括应用程序的生命周期事件(比如程序启动和关闭)、系统事件(比如来电)
启动调用
应用程序启动入口,在应用程序启动时执行一次
@param application 获取程序的状态,变量
@param launchOptions 传递程序启动原因
@return <#return value description#>
*/
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{
在应用程序启动后覆盖自定义点。
launchOptions中的值:
1.用户直接启动,lauchOptions内无数据;
2.其他应用程序通过openURL:启动,则UIApplicationLaunchOptionsURLKey对应的对象为启动URL(NSURL),
UIApplicationLaunchOptionsSourceApplicationKey对应启动的源应用程序的bundle ID (NSString);
3.本地通知启动,则UIApplicationLaunchOptionsLocalNotificationKey对应的是为启动应用程序的的本地通知对象(UILocalNotification);
4.远程通知启动,则UIApplicationLaunchOptionsRemoteNotificationKey对应的是启动应用程序的的远程通知信息userInfo(NSDictionary);
5.其他键:
UIApplicationLaunchOptionsAnnotationKey userInfo包含带注释属性列表的对象
UIApplicationLaunchOptionsLocationKey 应用程序是响应CoreLocation事件而启动的
UIApplicationLaunchOptionsNewsstandDownloadsKey userInfo包含NKAssetDownload的NSArray
UIApplicationLaunchOptionsBluetoothCentralsKey userInfo包含CBCentralManager恢复标识符的NSArray
UIApplicationLaunchOptionsBluetoothPeripheralsKey userInfo包含CBPeripheralManager恢复的NSArray
UIApplicationLaunchOptionsShortcutItemKey userInfo包含用于启动应用程序的UIApplicationShortcutItem。
键入选项字典传递给应用程序:[will | didFinishLaunchingWithOptions和UIApplicationDidFinishLaunchingNotification的信息
UIApplicationLaunchOptionsUserActivityDictionaryKey 存在用户活动时启动选项中存在的子词典
UIApplicationLaunchOptionsUserActivityTypeKey 键入活动类型的用户活动字典
UIApplicationLaunchOptionsCloudKitShareMetadataKey 此键的存在表示应用程序已启动,以便处理CloudKit共享邀请。 此键的值是共享元数据对象。
return YES;
}
将要从活跃到不活跃 如:前台到后台 切换应用程序 在此期间,应用程序不接收消息或事件,比如网络电话。
- (void)applicationWillResignActive:(UIApplication *)application
{
当应用程序即将从活动状态迁移到非活动状态时发送。 这可能发生在某些类型的临时中断(例如来电或SMS消息)时,或者当用户退出应用程序并且开始转换到后台状态时。
使用此方法暂停正在进行的任务,禁用计时器,并使渲染回调无效。 游戏应该使用这种方法暂停游戏。
}
从后台到前台
- (void)applicationWillEnterForeground:(UIApplication *)application
{
被称为从后台到活动状态的转换的一部分; 在这里你可以撤消许多在输入背景所做的更改。
}
从后他到前台时会调用 应用程序将要进入活跃状态
- (void)applicationDidBecomeActive:(UIApplication *)application
{
在应用程序处于非活动状态时,重新启动已暂停(或尚未启动)的任何任务。 如果应用程序先前在后台,则可选择刷新用户界面。
}
从后台到前台时会调用 在这里可以设置允许后台运行
- (void)applicationDidEnterBackground:(UIApplication *)application
{
使用此方法释放共享资源,保存用户数据,使计时器无效,并存储足够的应用程序状态信息以将应用程序恢复到其当前状态,以防以后终止。
如果您的应用程序支持后台执行,则调用此方法,而不是applicationWillTerminate:当用户退出时。
}
程序即将退出
- (void)applicationWillTerminate:(UIApplication *)application
{
在应用程序即将终止时调用。 保存数据,推出前清理数据 需要设置UIApplicationExitsOnSuspend的键值。
}
- (void)applicationDidReceiveMemoryWarning:(UIApplication *)application
{
iPhone设备只有有限的内存,如果为应用程序分配了太多内存**操作系统**会终止应用程序的运行,在终止前会执行这个方法,通常可以在这里进行内存清理工作防止程序被终止
}
当系统时间发生改变时执行
- (void)applicationSignificantTimeChange:(UIApplication*)application
{
}
当程序载入后执行
- (void)applicationDidFinishLaunching:(UIApplication*)application
{
}
当StatusBar栏将要变化执行
-(void)application:(UIApplication *)application willChangeStatusBarFrame:(CGRect)newStatusBarFrame
{
}
当StatusBar栏方向将要变化时执行
- (void)application:(UIApplication*)application willChangeStatusBarOrientation:
(UIInterfaceOrientation)newStatusBarOrientation
duration:(NSTimeInterval)duration
{
}
当通过URL时执行
- (BOOL)application:(UIApplication*)application handleOpenURL:(NSURL*)url
{
return YES;
}
当StatusBar框方向变化完成后执行
-(void)application:(UIApplication*)application didChangeStatusBarOrientation:(UIInterfaceOrientation)oldStatusBarOrientation
{
}
当StatusBar框变化完成后执行
-(void)application:(UIApplication*)application didChangeSetStatusBarFrame:(CGRect)oldStatusBarFrame
{
}
/********************远程推送的处理***************************/
-(void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userinfo
{
当一个运行着的应用程序收到一个远程的通知 发送到委托去...
}
-(void) application:(UIApplication *) application didRegisterForRemoteNotificationsWithDeviceToken:(NSData *) deviceToken
{
当一个应用程序成功的注册一个推送服务(APS) 发送到委托去...
}
-(void) application:(UIApplication *)application didFailToRegisterForRemoteNotificationsWithError:(NSError *) error
{
当 APS无法成功的完成向 程序进程推送时 发送到委托去...
}
/******************处理本地消息******************************/
UILocalNotification类在ios10中被弃用 换成UNNotificationRequest了 需要添加UserNotifications.frame静态库
-(void)application:(UIApplication *)application didReceiveLocalNotification:(UNNotificationRequest *)notification
{
当一个运行着的应用程序收到一个本地的通知 发送到委托去...
}
/******************特殊事件*********************************/
响应受保护内容的改变
-(void)applicationProtectedDataDidBecomeAvailable:(UIApplication *)application
{
通知委托,受保护的文件当前变为可用的
}
-(void)applicationProtectedDataWillBecomeUnavailable:(UIApplication *)application
{
通知委托,受保护的文件当前变为不可用的
}