轉自:http://blog.csdn.net/huang2009303513/article/details/39501225
我們來討論一下,在iOS開發中,如何實現從app1打開app2。
基本的思路就是,可以為app2定義一個URL,在app1中通過打開這個URL來打開app2,在此過程中,可以傳送一些參數。下面來討論一下具體的實現過程。
1. 在app2的info.plist中定義URL,就是在文件中添加URL types一項。可按下圖進行添加。
2. 在app1的代碼中打開剛才定義的URL,代碼如下:
- NSURL *url = [NSURL URLWithString:@"myapp://test?para1=1¶2=2"];
- [[UIApplication sharedApplication] openURL:url];
當然,這個URL的形式可以是其他形式的,只要以"myapp://"開始即可。
這樣,就可以在app1中打開app2.
打開之后,會調用app2的AppDelegate的
- - (BOOL)application:(UIApplication *)application openURL:(NSURL *)url sourceApplication:(NSString *)sourceApplication annotation:(id)annotation
由於URL是自己定義的,所以會存在URL重復的情況。經過測試發現,如果試圖打開這個URL,那么會打開先安裝的那個應用。
- NSString *deviceID = [[UIDevice currentDevice] uniqueIdentifier];//設備id
- // NSString *deviceID = [[UIApplication sharedApplication] uuid];
- NSString *systemVersion = [[UIDevice currentDevice] systemVersion];//系統版本
- NSString *systemModel = [[UIDevice currentDevice] model];//是iphone 還是 ipad
- NSDictionary *dic = [[NSBundle mainBundle] infoDictionary];//獲取info-plist
- NSString *appName = [dic objectForKey:@"CFBundleIdentifier"];//獲取Bundle identifier
- NSString *appVersion = [dic valueForKey:@"CFBundleVersion"];//獲取Bundle Version
- NSDictionary *userInfo = [[NSDictionary alloc] initWithObjectsAndKeys:
- deviceID, @"deviceID",
- systemVersion, @"systemVersion",
- systemModel, @"systemModel",
- appName, @"appName",
- appVersion, @"appVersion",nil];
很多時候,我們不需要關心這個類,我們很少繼承這個類,偶爾會調用這個類的api來實現一些功能,但是不可否認,這個類是iOS編程中很重要的一個概念,所以我這里寫這個文章來總結以下這個類的信息,如果寫的不對的地方,請留言,多謝。
UIApplication的核心作用是提供了iOS程序運行期間的控制和協作工作。
每一個程序在運行期必須有且僅有一個UIApplication(或則其子類)的一個實例。回想一下我在前面的文章“main函數研究”的文章中提到的main函數的代碼,可以看出,在程序開始運行的時候,UIApplicationMain函數是程序進入點,這個函數做了很多工作,其中一個重要的工作就是創建一個UIApplication的單例實例。在你的代碼中你,你可以通過調用[UIApplication sharedApplication]來得到這個單例實例的指針。
UIApplication的一個主要工作是處理用戶事件,它會起一個隊列,把所有用戶事件都放入隊列,逐個處理,在處理的時候,它會發送當前事件到一個合適的處理事件的目標控件。此外,UIApplication實例還維護一個在本應用中打開的window列表(UIWindow實例),這樣它就可以接觸應用中的任何一個UIView對象。UIApplication實例會被賦予一個代理對象,以處理應用程序的生命周期事件(比如程序啟動和關閉)、系統事件(比如來電、記事項警告)等等。
新建一個任意類型的iOS應用工程,加入我們在Class Prefix輸入是TC,我們可以看到工程中生成一個類:
TCAppDelegate :UIResponder <UIApplicationDelegate>
這里這個類的基類是UIResponder,和4.2以前生成的工程是不同的,以前是繼承自NSObject。不論如何,本類實現了一個名叫UIApplicationDelegate的接口,這個表明這個類就是這個工程中UIApplication實例的代理類。
在main函數中,
@autoreleasepool {
returnUIApplicationMain(argc, argv, nil,NSStringFromClass([TCAppDelegateclass]));
}
這里傳入了代理類到UIApplicationMain函數中,UIApplicationMain函數在生成唯一個UIApplication的時候就可以把代理類的實例指針告訴這個單例對象了。
可以通過如下代碼獲UIApplication代理對象:
TCAppDelegate *myDelegate = (TCAppDelegate *)[UIApplicationsharedApplication].delegate;
在UIApplication接收到系統事件和生命周期事件時,會把相應的事件傳遞給UIApplicationDelegate進行處理,下表所列的生命周期函數大都是可選的,但為了應用程序的健壯性程序員應該實現它們。
UIApplicationDelegate Event-Handling Methods |
Method Signature |
1:application:didChangeStatusBarFrame: |
- (void)application:(UIApplication*)application didChangeSetStatusBarFrame:(CGRect)oldStatusBarFrame |
2:application:didChangeStatusBarOrientation: |
- (void)application:(UIApplication*)application didChangeStatusBarOrientation:(UIInterfaceOrientation)oldStatusBarOrientation |
3:application:handleOpenURL: |
- (BOOL)application:(UIApplication*)application handleOpenURL:(NSURL*)url |
4:application:willChangeStatusBarOrientation:duration: |
- (void)application:(UIApplication*)application willChangeStatusBarOrientation: (UIInterfaceOrientation)newStatusBarOrientation |
5:application:willChangeStatusBarFrame |
- (void)application:(UIApplication)application willChangeStatusBarFrame:(CGRect)newStatusBarFrame |
6:applicationDidBecomeActive: |
- (void)applicationDidBecomeActive:(UIApplication*)application |
7:applicationDidFinishLaunching: |
- (void)applicationDidFinishLaunching:(UIApplication*)application |
8:applicationDidReceiveMemoryWarning: |
- (void)applicationDidReceiveMemoryWarning:(UIApplication*)application |
9:applicationSignificantTimeChange: |
- (void)applicationSignificantTimeChange:(UIApplication*)application |
10:applicationWillResignActive: |
- (void)applicationWillResignActive:(UIApplication*)application |
11:applicationWillTerminate: |
- (void)applicationWillTerminate:(UIApplication*)application |
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執行
12、- (void)application:(UIApplication*)application didChangeStatusBarOrientation:(UIInterfaceOrientation)oldStatusBarOrientation
說明:當StatusBar框方向變化完成后執行
13、- (void)application:(UIApplication*)application didChangeSetStatusBarFrame:(CGRect)oldStatusBarFrame
說明:當StatusBar框變化完成后執行
iPhone中的應用程序很容易受到打擾,比如一個來電可能導致應用程序失去焦點,如果這個時候接聽了電話,那么應用程序會轉到后台運行。還有很多其它類似的事件會導致iPhone應用程序失去焦點,在應用程序失去焦點前會調用委托類的applicationWillResignActive()方法,而應用程序再次獲取到焦點的時候會調用applicationDidBecomeActive()方法。比如在運行應用程序的時候鎖屏會調用委托類的applicationWillResignActive()方法,而當屏幕被解鎖的時候,又會調用applicationDidBecomeActive()方法。
另外一個非常重要的方法就是applicationDidReceiveMemoryWarning(),因為iPhone設備只有有限的內存,如果為應用程序分配了太多內存操作系統會終止應用程序的運行,但在終止之前操作系統會通過先調用委托類的applicationDidReceiveMemoryWarning()方法警告應用程序,在UIApplication接收到這個事件后它會傳遞給委托類的applicationDidReceiveMemoryWarning()方法,委托類在這個方法內可以進行釋放內存的操作以防止操作系統強制終止應用程序的運行。
下面是這個類的一些功能:
1.設置icon上的數字圖標
//設置主界面icon上的數字圖標,在2.0中引進, 缺省為0
[UIApplicationsharedApplication].applicationIconBadgeNumber = 4;
2.設置搖動手勢的時候,是否支持redo,undo操作
//搖動手勢,是否支持redo undo操作。
//3.0以后引進,缺省YES
[UIApplicationsharedApplication].applicationSupportsShakeToEdit =YES;
3.判斷程序運行狀態
//判斷程序運行狀態,在2.0以后引入
/*
UIApplicationStateActive,
UIApplicationStateInactive,
UIApplicationStateBackground
*/
if([UIApplicationsharedApplication].applicationState ==UIApplicationStateInactive){
NSLog(@"程序在運行狀態");
}
4.阻止屏幕變暗進入休眠狀態
//阻止屏幕變暗,慎重使用,缺省為no 2.0
[UIApplicationsharedApplication].idleTimerDisabled =YES;
慎重使用本功能,因為非常耗電。
5.顯示聯網狀態
//顯示聯網標記 2.0
[UIApplicationsharedApplication].networkActivityIndicatorVisible =YES;
6.在map上顯示一個地址
NSString* addressText =@"1 Infinite Loop, Cupertino, CA 95014";
// URL encode the spaces
addressText = [addressTextstringByAddingPercentEscapesUsingEncoding:NSASCIIStringEncoding];
NSString* urlText = [NSStringstringWithFormat:@"http://maps.google.com/maps?q=%@", addressText];
[[UIApplicationsharedApplication]openURL:[NSURLURLWithString:urlText]];
7.發送電子郵件
NSString *recipients =@"mailto:first@example.com?cc=second@example.com,third@example.com&subject=Hello from California!";
NSString *body =@"&body=It is raining in sunny California!";
NSString *email = [NSStringstringWithFormat:@"%@%@", recipients, body];
email = [emailstringByAddingPercentEscapesUsingEncoding:NSUTF8StringEncoding];
[[UIApplicationsharedApplication]openURL:[NSURLURLWithString:email]];
8.打電話到一個號碼
// Call Google 411
[[UIApplicationsharedApplication]openURL:[NSURLURLWithString:@"tel://8004664411"]];
9.發送短信
// Text to Google SMS
[[UIApplicationsharedApplication]openURL:[NSURLURLWithString:@"sms://466453"]];
10.打開一個網址
// Lanuch any iPhone developers fav site
[[UIApplicationsharedApplication]openURL:[NSURLURLWithString:@"http://itunesconnect.apple.com"]];