IOS --- AppDelegate方法

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
{
    通知委托,受保护的文件当前变为不可用的
}

你可能感兴趣的:(IOS --- AppDelegate方法)