zoukankan      html  css  js  c++  java
  • 自定义控制器

    应用程序加载完成后可以重写 didFinishLaunchingWithOptions这个方法来实现我们自定义的一些操作

    1.将系统提供的viewController.h/.m  和 main.storyboard 删除

    2.在应用加载完毕方法内实现加载自定义控制器

       1.自定义控制器,继承自系统的UIViewController

           1.先创建一个窗口

           2.设定窗口的根控制器为自定义控制器

           3.将折扣窗口作为主窗口并显示

     //1.先创建一个窗口

    //UIWindow *window  =[[UIWindow alloc] initWithFrame:[UIScreen mainScreen].bounds];

     self.window = [UIWindow alloc] initWithFrame:[UIScreen mainScreen].bounds];

    //2.设定窗口的根控制器为自定义控制器

      WriterViewController *customVC =[[WriterViewController alloc]init];

      self.window.rootViewController = customVC;

    //3.将这个窗口作为主窗口并显示

     [self.window makeKeyAndVisible];

     iOS 程序启动时总会调用application:didFinishLaunchingWithOptions:,其中第二个参数launchOptions为NSDictionary类型的对象,里面存储有此程序启动的原因。

    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)
        {
        }
    
    }
    /////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
    这里是分割线
    /////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////

    IOS 中的 AppDelegate.m/h 文件是很重要的呢,因为它是对 Application 的整个生命周期进行管理的。

    先明白,每个iPhone应用程序都有一个UIApplication,UIApplication是iPhone应用程序的开始并且负责初始化并显 示 UIWindow,并负责加载应用程序的第一个UIView到UIWindow窗体中。UIApplication的另一个任务是帮助管理应用程序的 生命 周期,而UIApplication通过一个名字为UIApplicationDelegate的代理类来履行这个任务。尽管 UIApplication 会负责接收事件,而UIApplicationDelegate则决定应用程序如何去响应这些事 件,UIApplicationDelegate可以处理 的事件包括应用程序的生命周期事件(比如程序启动和关闭)、系统事件(比如来电、记事项警 告),本文会介绍如何加载应用程序的UIView到 UIWindow以及如何利用UIApplicationDelegate处理系统事件。
     
    通 常对于UIApplication读者是没必要修改它的,只需要知道UIApplication接收系统事件即可,而如何编写代码来处理这些系统事件 则 是程序员的工作。处理系统事件需要编写一个继承自UIApplicationDelegate接口的类,而 UIApplicationDelegate接 口提供生命周期函数来处理应用程序以及应用程序的系统事件,这些生命周期函数如下表所示:

    1、- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
    {
     NSLog(@"当程序载入后执行");
    }
    说明:当程序载入后执行,应用程序启动入口。只在应用程序启动时执行一次。也就是说在应用程序启动后,要执行的委托调用。application参数用来获取应用程序的状态、变量等,值得注意的是字典参数:(NSDictionary *)launchOptions,该参数存储程序启动的原因。
     
    若用户直接启动,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 = [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)
        {
        }


    2、-  (void)applicationWillResignActive:(UIApplication *)application
    {
    NSLog(@"应用程序将要进入非活动状态,即将进入后台");
    }
    在应用程序将要由活动状态切换到非活动状态时候,要执行的委托调用,如 按下 home 按钮,返回主屏幕,或全屏之间切换应用程序等。                                        
    说明:当应用程序将要进入非活动状态时执行,在此期间,应用程序不接收消息或事件,比如来电话了。

    3、- (void)applicationDidEnterBackground:(UIApplication *)application
    {
          NSLog(@"如果应用程序支持后台运行,则应用程序已经进入后台运行"); 
    }

    说明:当程序被推送到后台的时候调用。所以要设置后台继续运行,则在这个函数里面设置即可


    4、-  (void)applicationWillEnterForeground:(UIApplication *)application
    {
          NSLog(@"应用程序将要进入活动状态,即将进入前台运行");
    }
    说明:当程序从后台将要重新回到前台时候调用,这个刚好跟上面的那个方法相反。

    5、- (void)applicationDidBecomeActive:(UIApplication *)application
    {
         NSLog(@"应用程序已进入前台,处于活动状态");
    }
    说明:当应用程序进入活动状态时执行,这个刚好跟上面那个方法相反 。

    6、-  (void)applicationWillTerminate:(UIApplication *)application
    {
         NSLog(@"应用程序将要退出,通常用于保存数据和一些退出前的清理工作"); 
    }
    说明:当程序将要退出是被调用,通常是用来保存数据和一些退出前的清理工作。这个需要要设置UIApplicationExitsOnSuspend的键值。

    7、-  (void)applicationDidReceiveMemoryWarning:(UIApplication *)application
    {
        NSLog(@"系统内存不足,需要进行清理工作");
    }
    说明:iPhone设备只有有限的内存,如果为应用程序分配了太多内存操作系统会终止应用程序的运行,在终止前会执行这个方法,通常可以在这里进行内存清理工作防止程序被终止。

    8、-(void)applicationSignificantTimeChange:(UIApplication *)application
    {
        NSLog(@"当系统时间发生改变时执行");
    }
    说明:当系统时间发生改变时执行

    9、-  (void)application:(UIApplication)application  willChangeStatusBarFrame:(CGRect)newStatusBarFrame
    {
       NSLog(@"StatusBar框将要变化");
    }
    说明:当StatusBar框将要变化时执行

    10、-  (void)application:(UIApplication*)application willChangeStatusBarOrientation:
    (UIInterfaceOrientation)newStatusBarOrientation duration:(NSTimeInterval)duration
    {
    }
    说明:当StatusBar框方向将要变化时执行

    11、- (BOOL)application:(UIApplication*)application handleOpenURL:(NSURL*)url
    {
    }
    说明:当通过url执行

    12、-  (void)application:(UIApplication*)application  didChangeStatusBarOrientation:(UIInterfaceOrientation)oldStatusBarOrientation
    {
    }
    说明:当StatusBar框方向变化完成后执行

    13、-  (void)application:(UIApplication*)application didChangeSetStatusBarFrame:(CGRect)oldStatusBarFrame
    {
    }
    说明:当StatusBar框变化完成后执行

    另外还有一些协议方法需要知道:
    Handling Remote Notifications  (处理远程消息)

    -(void) application:(UIApplication *) applicationdidReceiveRemoteNotification:(NSDictonary *) userinfo
    说明:当一个运行着的应用程序收到一个远程的通知 发送到委托去...
    -(void) application:(UIApplication *) applicationdidRegisterForRemoteNotificationsWithDeviceToken:(NSData *) deviceToken
    说明:当一个应用程序成功的注册一个推送服务(APS) 发送到委托去...
    -(void) application:(UIApplication *) applicationdidFailToRegisterForRemoteNotificationsWithError:(NSError *) error
    说明:当 APS无法成功的完成向 程序进程推送时 发送到委托去...

    Handling Local Notification (处理本地消息)

    -(void) application:(UIApplication *) applicationdidReceiveLocalNotification:(UILocalNotification *)notification
    说明:当一个运行着的应用程序收到一个本地的通知 发送到委托去...

    Responding to Content Protections Changes(响应受保护内容的改变)

    -applicationProtectedDataWillBecomeUnavailable:
    说明:通知委托,受保护的文件当前变为不可用的
    -applicationProtectedDataWillBecomeAvailable:
    说明:通知委托  受保护的文件当前变为可用
     
  • 相关阅读:
    Windows Azure Storage (17) Azure Storage读取访问地域冗余(Read Access – Geo Redundant Storage, RA-GRS)
    SQL Azure (15) SQL Azure 新的规格
    Azure China (5) 管理Azure China Powershell
    Azure China (4) 管理Azure China Storage Account
    Azure China (3) 使用Visual Studio 2013证书发布Cloud Service至Azure China
    Azure China (2) Azure China管理界面初探
    Azure China (1) Azure公有云落地中国
    SQL Azure (14) 将云端SQL Azure中的数据库备份到本地SQL Server
    [New Portal]Windows Azure Virtual Machine (23) 使用Storage Space,提高Virtual Machine磁盘的IOPS
    Android数据库升级、降级、创建(onCreate() onUpgrade() onDowngrade())的注意点
  • 原文地址:https://www.cnblogs.com/seeworld/p/5936354.html
Copyright © 2011-2022 走看看