由于剛剛開始學習接觸IOS 星星散散的記一些隨筆,會比較散亂...
IOS程序調(diào)用時總會調(diào)用
application:didFinishLaunchingWithOptions
Launch options為NSDictionary類型的對象 ?里面保存了程序啟動的原因
1.直接啟動: LauchOptions內(nèi)無數(shù)據(jù)
2.其他應用程序通過OpenURL:啟動捌浩,UIApplicationLauchOptionsURLkey對應的對象為啟動URL(NSURL).UIApplicationLauchOptionsSourceApplicationKey對應啟動的源應用程序的bundle ID(NSString);
3.若遠程通知啟動啄糙,則UIApplicationLauchOptionsRemoteNotificationKey對應的是啟動應用程序遠程通知信息UserInfo(NSDictionary);
4.若由本地通知啟動笛臣,則UIApplicationLauchOptionsLocalNotificationKey對應的是為啟動應用程序的本地通知對象(UILocalNotification);
5.其他Key還有
UIApplicationLaunchOptionsAnnotationKey;
UIApplicationLaunchOptionsLocationKey;
UIApplicationLaunchOptionsNewsstandDownloadsKey;
IOS中的AppDelegate.m/h文件很重要,它對Application的整個生命周期進行管理隧饼。
Application詳解
IOS 中的 AppDelegate.m/h 文件是很重要的呢沈堡,因為它是對 Application 的整個生命周期進行管理的。
先明白燕雁,每個iPhone應用程序都有一個UIApplication诞丽,UIApplication是iPhone應用程序的開始并且負責初始化并顯 示 UIWindow,并負責加載應用程序的第一個UIView到UIWindow窗體中拐格。UIApplication的另一個任務是幫助管理應用程序的 生命 周期僧免,而UIApplication通過一個名字為UIApplicationDelegate的代理類來履行這個任務。盡管 UIApplication 會負責接收事件捏浊,而UIApplicationDelegate則決定應用程序如何去響應這些事 件懂衩,UIApplicationDelegate可以處理 的事件包括應用程序的生命周期事件(比如程序啟動和關閉)、系統(tǒng)事件(比如來電、記事項警 告)勃痴,本文會介紹如何加載應用程序的UIView到 UIWindow以及如何利用UIApplicationDelegate處理系統(tǒng)事件。
通 常對于UIApplication讀者是沒必要修改它的热康,只需要知道UIApplication接收系統(tǒng)事件即可沛申,而如何編寫代碼來處理這些系統(tǒng)事件 則 是程序員的工作。處理系統(tǒng)事件需要編寫一個繼承自UIApplicationDelegate接口的類姐军,而 UIApplicationDelegate接 口提供生命周期函數(shù)來處理應用程序以及應用程序的系統(tǒng)事件铁材,這些生命周期函數(shù)如下表所示:
1、- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{
NSLog(@"當程序載入后執(zhí)行");
}
說明:當程序載入后執(zhí)行奕锌,應用程序啟動入口著觉。只在應用程序啟動時執(zhí)行一次。也就是說在應用程序啟動后惊暴,要執(zhí)行的委托調(diào)用饼丘。application參數(shù)用來獲取應用程序的狀態(tài)、變量等辽话,值得注意的是字典參數(shù):(NSDictionary *)launchOptions肄鸽,該參數(shù)存儲程序啟動的原因。
若用戶直接啟動油啤,lauchOptions內(nèi)無數(shù)據(jù);
若由其他應用程序通過openURL:啟動典徘,則UIApplicationLaunchOptionsURLKey對應的對象為啟動 URL(NSURL),UIApplicationLaunchOptionsSourceApplicationKey對應啟動的源應用程序的 bundle ID (NSString);
若由本地通知啟動益咬,則UIApplicationLaunchOptionsLocalNotificationKey對應的是為啟動應用程序的的本地通知對象(UILocalNotification)逮诲;
若由遠程通知啟動,則UIApplicationLaunchOptionsRemoteNotificationKey對應的是啟動應用程序的的遠程通知信息userInfo(NSDictionary)幽告;
其他key還有UIApplicationLaunchOptionsAnnotationKey,UIApplicationLaunchOptionsLocationKey,
UIApplicationLaunchOptionsNewsstandDownloadsKey梅鹦。
如果要在啟動時,做出一些區(qū)分评腺,那就需要在下面的代碼做處理帘瞭。比如:應用可以被某個其它應用調(diào)起(作為該應用的子應用),要實現(xià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(@"應用程序?qū)⒁M入非活動狀態(tài)媒殉,即將進入后臺");
}
在應用程序?qū)⒁苫顒訝顟B(tài)切換到非活動狀態(tài)時候,要執(zhí)行的委托調(diào)用摔敛,如 按下 home 按鈕廷蓉,返回主屏幕,或全屏之間切換應用程序等马昙。
說明:當應用程序?qū)⒁M入非活動狀態(tài)時執(zhí)行桃犬,在此期間刹悴,應用程序不接收消息或事件,比如來電話了攒暇。
3土匀、- (void)applicationDidEnterBackground:(UIApplication *)application
{
NSLog(@"如果應用程序支持后臺運行,則應用程序已經(jīng)進入后臺運行");
}
說明:當程序被推送到后臺的時候調(diào)用形用。所以要設置后臺繼續(xù)運行就轧,則在這個函數(shù)里面設置即可
4、-? (void)applicationWillEnterForeground:(UIApplication *)application
{
NSLog(@"應用程序?qū)⒁M入活動狀態(tài)田度,即將進入前臺運行");
}
說明:當程序從后臺將要重新回到前臺時候調(diào)用妒御,這個剛好跟上面的那個方法相反。
5镇饺、- (void)applicationDidBecomeActive:(UIApplication *)application
{
NSLog(@"應用程序已進入前臺乎莉,處于活動狀態(tài)");
}
說明:當應用程序進入活動狀態(tài)時執(zhí)行,這個剛好跟上面那個方法相反 兰怠。
6梦鉴、-? (void)applicationWillTerminate:(UIApplication *)application
{
NSLog(@"應用程序?qū)⒁顺觯ǔS糜诒4鏀?shù)據(jù)和一些退出前的清理工作");
}
說明:當程序?qū)⒁顺鍪潜徽{(diào)用揭保,通常是用來保存數(shù)據(jù)和一些退出前的清理工作肥橙。這個需要要設置UIApplicationExitsOnSuspend的鍵值。
7秸侣、-? (void)applicationDidReceiveMemoryWarning:(UIApplication *)application
{
NSLog(@"系統(tǒng)內(nèi)存不足存筏,需要進行清理工作");
}
說明:iPhone設備只有有限的內(nèi)存,如果為應用程序分配了太多內(nèi)存操作系統(tǒng)會終止應用程序的運行味榛,在終止前會執(zhí)行這個方法椭坚,通常可以在這里進行內(nèi)存清理工作防止程序被終止搏色。
8善茎、-(void)applicationSignificantTimeChange:(UIApplication *)application
{
NSLog(@"當系統(tǒng)時間發(fā)生改變時執(zhí)行");
}
說明:當系統(tǒng)時間發(fā)生改變時執(zhí)行
9、-? (void)application:(UIApplication)application? willChangeStatusBarFrame:(CGRect)newStatusBarFrame
{
NSLog(@"StatusBar框?qū)⒁兓?);
}
說明:當StatusBar框?qū)⒁兓瘯r執(zhí)行
10频轿、-? (void)application:(UIApplication*)application willChangeStatusBarOrientation:
(UIInterfaceOrientation)newStatusBarOrientation duration:(NSTimeInterval)duration
{
}
說明:當StatusBar框方向?qū)⒁兓瘯r執(zhí)行
11垂涯、- (BOOL)application:(UIApplication*)application handleOpenURL:(NSURL*)url
{
}
說明:當通過url執(zhí)行
12、-? (void)application:(UIApplication*)application? didChangeStatusBarOrientation:(UIInterfaceOrientation)oldStatusBarOrientation
{
}
說明:當StatusBar框方向變化完成后執(zhí)行
13航邢、-? (void)application:(UIApplication*)application didChangeSetStatusBarFrame:(CGRect)oldStatusBarFrame
{
}
說明:當StatusBar框變化完成后執(zhí)行
另外還有一些協(xié)議方法需要知道:
Handling Remote Notifications? (處理遠程消息)
-(void) application:(UIApplication *) applicationdidReceiveRemoteNotification:(NSDictonary *) userinfo
說明:當一個運行著的應用程序收到一個遠程的通知 發(fā)送到委托去...
-(void) application:(UIApplication *) applicationdidRegisterForRemoteNotificationsWithDeviceToken:(NSData *) deviceToken
說明:當一個應用程序成功的注冊一個推送服務(APS) 發(fā)送到委托去...
-(void) application:(UIApplication *) applicationdidFailToRegisterForRemoteNotificationsWithError:(NSError *) error
說明:當 APS無法成功的完成向 程序進程推送時 發(fā)送到委托去...
Handling Local Notification (處理本地消息)
-(void) application:(UIApplication *) applicationdidReceiveLocalNotification:(UILocalNotification *)notification
說明:當一個運行著的應用程序收到一個本地的通知 發(fā)送到委托去...
Responding to Content Protections Changes(響應受保護內(nèi)容的改變)
-applicationProtectedDataWillBecomeUnavailable:
說明:通知委托耕赘,受保護的文件當前變?yōu)椴豢捎玫?/p>
-applicationProtectedDataWillBecomeAvailable:
說明:通知委托? 受保護的文件當前變?yōu)榭捎?/p>