由于剛剛開始學(xué)習(xí)接觸IOS 星星散散的記一些隨筆,會比較散亂...
IOS程序調(diào)用時總會調(diào)用
application:didFinishLaunchingWithOptions
Launch options為NSDictionary類型的對象 ?里面保存了程序啟動的原因
1.直接啟動: LauchOptions內(nèi)無數(shù)據(jù)
2.其他應(yīng)用程序通過OpenURL:啟動,UIApplicationLauchOptionsURLkey對應(yīng)的對象為啟動URL(NSURL).UIApplicationLauchOptionsSourceApplicationKey對應(yīng)啟動的源應(yīng)用程序的bundle ID(NSString);
3.若遠(yuǎn)程通知啟動,則UIApplicationLauchOptionsRemoteNotificationKey對應(yīng)的是啟動應(yīng)用程序遠(yuǎn)程通知信息UserInfo(NSDictionary);
4.若由本地通知啟動,則UIApplicationLauchOptionsLocalNotificationKey對應(yīng)的是為啟動應(yīng)用程序的本地通知對象(UILocalNotification);
5.其他Key還有
UIApplicationLaunchOptionsAnnotationKey;
UIApplicationLaunchOptionsLocationKey;
UIApplicationLaunchOptionsNewsstandDownloadsKey;
IOS中的AppDelegate.m/h文件很重要,它對Application的整個生命周期進(jìn)行管理。
Application詳解
IOS 中的 AppDelegate.m/h 文件是很重要的呢,因?yàn)樗菍?Application 的整個生命周期進(jìn)行管理的。
先明白,每個iPhone應(yīng)用程序都有一個UIApplication,UIApplication是iPhone應(yīng)用程序的開始并且負(fù)責(zé)初始化并顯 示 UIWindow,并負(fù)責(zé)加載應(yīng)用程序的第一個UIView到UIWindow窗體中。UIApplication的另一個任務(wù)是幫助管理應(yīng)用程序的 生命 周期,而UIApplication通過一個名字為UIApplicationDelegate的代理類來履行這個任務(wù)。盡管 UIApplication 會負(fù)責(zé)接收事件,而UIApplicationDelegate則決定應(yīng)用程序如何去響應(yīng)這些事 件,UIApplicationDelegate可以處理 的事件包括應(yīng)用程序的生命周期事件(比如程序啟動和關(guān)閉)、系統(tǒng)事件(比如來電、記事項(xiàng)警 告),本文會介紹如何加載應(yīng)用程序的UIView到 UIWindow以及如何利用UIApplicationDelegate處理系統(tǒng)事件。
通 常對于UIApplication讀者是沒必要修改它的,只需要知道UIApplication接收系統(tǒng)事件即可,而如何編寫代碼來處理這些系統(tǒng)事件 則 是程序員的工作。處理系統(tǒng)事件需要編寫一個繼承自UIApplicationDelegate接口的類,而 UIApplicationDelegate接 口提供生命周期函數(shù)來處理應(yīng)用程序以及應(yīng)用程序的系統(tǒng)事件,這些生命周期函數(shù)如下表所示:
1、- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{
NSLog(@"當(dāng)程序載入后執(zhí)行");
}
說明:當(dāng)程序載入后執(zhí)行,應(yīng)用程序啟動入口。只在應(yīng)用程序啟動時執(zhí)行一次。也就是說在應(yīng)用程序啟動后,要執(zhí)行的委托調(diào)用。application參數(shù)用來獲取應(yīng)用程序的狀態(tài)、變量等,值得注意的是字典參數(shù):(NSDictionary *)launchOptions,該參數(shù)存儲程序啟動的原因。
若用戶直接啟動,lauchOptions內(nèi)無數(shù)據(jù);
若由其他應(yīng)用程序通過openURL:啟動,則UIApplicationLaunchOptionsURLKey對應(yīng)的對象為啟動 URL(NSURL),UIApplicationLaunchOptionsSourceApplicationKey對應(yīng)啟動的源應(yīng)用程序的 bundle ID (NSString);
若由本地通知啟動,則UIApplicationLaunchOptionsLocalNotificationKey對應(yīng)的是為啟動應(yīng)用程序的的本地通知對象(UILocalNotification);
若由遠(yuǎn)程通知啟動,則UIApplicationLaunchOptionsRemoteNotificationKey對應(yīng)的是啟動應(yīng)用程序的的遠(yuǎn)程通知信息userInfo(NSDictionary);
其他key還有UIApplicationLaunchOptionsAnnotationKey,UIApplicationLaunchOptionsLocationKey,
UIApplicationLaunchOptionsNewsstandDownloadsKey。
如果要在啟動時,做出一些區(qū)分,那就需要在下面的代碼做處理。比如:應(yīng)用可以被某個其它應(yīng)用調(diào)起(作為該應(yīng)用的子應(yīng)用),要實(shí)現(xiàn)單點(diǎn)登錄,那就需要在啟動代碼的地方做出合理的驗(yàn)證,并跳過登錄。
例子:
- (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(@"應(yīng)用程序?qū)⒁M(jìn)入非活動狀態(tài),即將進(jìn)入后臺");
}
在應(yīng)用程序?qū)⒁苫顒訝顟B(tài)切換到非活動狀態(tài)時候,要執(zhí)行的委托調(diào)用,如 按下 home 按鈕,返回主屏幕,或全屏之間切換應(yīng)用程序等。
說明:當(dāng)應(yīng)用程序?qū)⒁M(jìn)入非活動狀態(tài)時執(zhí)行,在此期間,應(yīng)用程序不接收消息或事件,比如來電話了。
3、- (void)applicationDidEnterBackground:(UIApplication *)application
{
NSLog(@"如果應(yīng)用程序支持后臺運(yùn)行,則應(yīng)用程序已經(jīng)進(jìn)入后臺運(yùn)行");
}
說明:當(dāng)程序被推送到后臺的時候調(diào)用。所以要設(shè)置后臺繼續(xù)運(yùn)行,則在這個函數(shù)里面設(shè)置即可
4、-? (void)applicationWillEnterForeground:(UIApplication *)application
{
NSLog(@"應(yīng)用程序?qū)⒁M(jìn)入活動狀態(tài),即將進(jìn)入前臺運(yùn)行");
}
說明:當(dāng)程序從后臺將要重新回到前臺時候調(diào)用,這個剛好跟上面的那個方法相反。
5、- (void)applicationDidBecomeActive:(UIApplication *)application
{
NSLog(@"應(yīng)用程序已進(jìn)入前臺,處于活動狀態(tài)");
}
說明:當(dāng)應(yīng)用程序進(jìn)入活動狀態(tài)時執(zhí)行,這個剛好跟上面那個方法相反 。
6、-? (void)applicationWillTerminate:(UIApplication *)application
{
NSLog(@"應(yīng)用程序?qū)⒁顺觯ǔS糜诒4鏀?shù)據(jù)和一些退出前的清理工作");
}
說明:當(dāng)程序?qū)⒁顺鍪潜徽{(diào)用,通常是用來保存數(shù)據(jù)和一些退出前的清理工作。這個需要要設(shè)置UIApplicationExitsOnSuspend的鍵值。
7、-? (void)applicationDidReceiveMemoryWarning:(UIApplication *)application
{
NSLog(@"系統(tǒng)內(nèi)存不足,需要進(jìn)行清理工作");
}
說明:iPhone設(shè)備只有有限的內(nèi)存,如果為應(yīng)用程序分配了太多內(nèi)存操作系統(tǒng)會終止應(yīng)用程序的運(yùn)行,在終止前會執(zhí)行這個方法,通??梢栽谶@里進(jìn)行內(nèi)存清理工作防止程序被終止。
8、-(void)applicationSignificantTimeChange:(UIApplication *)application
{
NSLog(@"當(dāng)系統(tǒng)時間發(fā)生改變時執(zhí)行");
}
說明:當(dāng)系統(tǒng)時間發(fā)生改變時執(zhí)行
9、-? (void)application:(UIApplication)application? willChangeStatusBarFrame:(CGRect)newStatusBarFrame
{
NSLog(@"StatusBar框?qū)⒁兓?);
}
說明:當(dāng)StatusBar框?qū)⒁兓瘯r執(zhí)行
10、-? (void)application:(UIApplication*)application willChangeStatusBarOrientation:
(UIInterfaceOrientation)newStatusBarOrientation duration:(NSTimeInterval)duration
{
}
說明:當(dāng)StatusBar框方向?qū)⒁兓瘯r執(zhí)行
11、- (BOOL)application:(UIApplication*)application handleOpenURL:(NSURL*)url
{
}
說明:當(dāng)通過url執(zhí)行
12、-? (void)application:(UIApplication*)application? didChangeStatusBarOrientation:(UIInterfaceOrientation)oldStatusBarOrientation
{
}
說明:當(dāng)StatusBar框方向變化完成后執(zhí)行
13、-? (void)application:(UIApplication*)application didChangeSetStatusBarFrame:(CGRect)oldStatusBarFrame
{
}
說明:當(dāng)StatusBar框變化完成后執(zhí)行
另外還有一些協(xié)議方法需要知道:
Handling Remote Notifications? (處理遠(yuǎn)程消息)
-(void) application:(UIApplication *) applicationdidReceiveRemoteNotification:(NSDictonary *) userinfo
說明:當(dāng)一個運(yùn)行著的應(yīng)用程序收到一個遠(yuǎn)程的通知 發(fā)送到委托去...
-(void) application:(UIApplication *) applicationdidRegisterForRemoteNotificationsWithDeviceToken:(NSData *) deviceToken
說明:當(dāng)一個應(yīng)用程序成功的注冊一個推送服務(wù)(APS) 發(fā)送到委托去...
-(void) application:(UIApplication *) applicationdidFailToRegisterForRemoteNotificationsWithError:(NSError *) error
說明:當(dāng) APS無法成功的完成向 程序進(jìn)程推送時 發(fā)送到委托去...
Handling Local Notification (處理本地消息)
-(void) application:(UIApplication *) applicationdidReceiveLocalNotification:(UILocalNotification *)notification
說明:當(dāng)一個運(yùn)行著的應(yīng)用程序收到一個本地的通知 發(fā)送到委托去...
Responding to Content Protections Changes(響應(yīng)受保護(hù)內(nèi)容的改變)
-applicationProtectedDataWillBecomeUnavailable:
說明:通知委托,受保護(hù)的文件當(dāng)前變?yōu)椴豢捎玫?/p>
-applicationProtectedDataWillBecomeAvailable:
說明:通知委托? 受保護(hù)的文件當(dāng)前變?yōu)榭捎?/p>