UIApplication总结Version0.6

作者: 石丘 | 来源:发表于2015-08-03 20:13 被阅读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

    相关文章

      网友评论

        本文标题:UIApplication总结Version0.6

        本文链接:https://www.haomeiwen.com/subject/lbyvqttx.html