ios 交流群:264706196
參考:
http://www.cnblogs.com/wendingding/p/3766347.html
http://blog.sina.com.cn/s/blog_859ab336010166nd.html
簡單介紹
- UIApplication對象是應用程序的象征,一個UIApplication對象就代表一個應用程序。
- 每一個應用都有自己的UIApplication對象,而且是單例的,如果試圖在程序中新建一個UIApplication對象,那么將報錯提示。
- 通過[UIApplication sharedApplication]可以獲得這個單例對象
- 一個iOS程序啟動后創建的第一個對象就是UIApplication對象,且只有一個(通過代碼獲取兩個UIApplication對象,打印地址可以看出地址是相同的)。
- 利用UIApplication對象,能進行一些應用級別的操作
應用級別的操作示例
- 設置應用程序圖標右上角的紅色提醒數字(如QQ消息的時候,圖標上面會顯示1,2,3條新信息等。)
@property(nonatomic) NSInteger applicationIconBadgeNumber;
代碼實現和效果:
- (void)viewDidLoad
{
[super viewDidLoad];
//創建并添加一個按鈕
UIButton *btn=[[UIButton alloc]initWithFrame:CGRectMake(100, 100, 60, 30)];
[btn setTitle:@"按鈕" forState:UIControlStateNormal];
[btn setBackgroundColor:[UIColor brownColor]];
[btn addTarget:self action:@selector(onClick) forControlEvents:UIControlEventTouchUpInside];
[self.view addSubview:btn];
}
-(void)onClick
{
NSLog(@"按鈕點擊事件");
//通過sharedApplication獲取該程序的UIApplication對象
UIApplication *app=[UIApplication sharedApplication];
app.applicationIconBadgeNumber=123;
}
- 設置聯網指示器的可見性
@property(nonatomic,getter=isNetworkActivityIndicatorVisible) BOOL networkActivityIndicatorVisible;
代碼和效果:
app.networkActivityIndicatorVisible=YES;
- 管理狀態欄
從iOS7開始,系統提供了2種管理狀態欄的方式
a) 通過UIViewController管理(每一個UIViewController都可以擁有自己不同的狀態欄).
在iOS7中,默認情況下,狀態欄都是由UIViewController管理的,UIViewController實現下列方法就可以輕松管理狀態欄的可見性和樣式
狀態欄的樣式 - (UIStatusBarStyle)preferredStatusBarStyle;
狀態欄的可見性 -(BOOL)prefersStatusBarHidden;
#pragma mark-設置狀態欄的樣式
-(UIStatusBarStyle)preferredStatusBarStyle
{
//設置為白色
//return UIStatusBarStyleLightContent;
//默認為黑色
return UIStatusBarStyleDefault;
}
#pragma mark-設置狀態欄是否隱藏(否)
-(BOOL)prefersStatusBarHidden
{
return NO;
}
b) 通過UIApplication管理(一個應用程序的狀態欄都由它統一管理)
如果想利用UIApplication來管理狀態欄,首先得修改Info.plist的設置
//通過sharedApplication獲取該程序的UIApplication對象
UIApplication *app=[UIApplication sharedApplication];
app.applicationIconBadgeNumber=123;
//設置指示器的聯網動畫
app.networkActivityIndicatorVisible=YES;
//設置狀態欄的樣式
//app.statusBarStyle=UIStatusBarStyleDefault;//默認(黑色)
//設置為白色+動畫效果
[app setStatusBarStyle:UIStatusBarStyleLightContent animated:YES];
//設置狀態欄是否隱藏
app.statusBarHidden=YES;
//設置狀態欄是否隱藏+動畫效果
[app setStatusBarHidden:YES withAnimation:UIStatusBarAnimationFade];
c) 補充
既然兩種都可以對狀態欄進行管理,那么什么時候該用什么呢?
如果狀態欄的樣式只設置一次,那就用UIApplication來進行管理;如果狀態欄是否隱藏,樣式不一樣那就用控制器進行管理。UIApplication來進行管理有額外的好處,可以提供動畫效果。
- openURL:方法
UIApplication有個功能十分強大的openURL:方法
-(BOOL)openURL:(NSURL*)url;
openURL:方法的部分功能有
//打電話
UIApplication *app = [UIApplicationsharedApplication]; [app openURL:[NSURLURLWithString:@"tel://10086"]];
//發短信
[app openURL:[NSURLURLWithString:@"sms://10086"]];
//發郵件
[app openURL:[NSURLURLWithString:@"mailto://12345@qq.com"]];
//打開一個網頁資源
[app openURL:[NSURLURLWithString:@"http://ios.itcast.cn"]];
打開其他app程序 openURL方法,可以打開其他APP。
URL補充:
URL:統一資源定位符,用來唯一的表示一個資源。
URL格式:協議頭://主機地址/資源路徑
網絡資源:http/ftp等
表示百度上一張圖片的地址
http://www.baidu.com/images/20140603/abc.png
本地資源:
file:///users/apple/desktop/abc.png(主機地址省略)
UIApplication Delegate
簡單說明
所有的移動操作系統都有個致命的缺點:app很容易受到打擾。比如一個來電或者鎖屏會導致app進入后臺甚至被終止。
還有很多其它類似的情況會導致app受到干擾,在app受到干擾時,會產生一些系統事件,這時UIApplication會通知它的delegate對象,讓delegate代理來處理這些系統事件。
作用:當被打斷的時候,通知代理進入到后臺。
每次新建完項目,都有個帶有“AppDelegate”字眼的類,它就是UIApplication的代理,NJAppDelegate默認已經遵守了UIApplicationDelegate協議,已經是UIApplication的代理。
代理方法
#import "YYAppDelegate.h"
@implementation YYAppDelegate
// 當應用程序啟動完畢的時候就會調用(系統自動調用)
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{
NSLog(@"didFinishLaunchingWithOptions");
return YES;
}
// 即將失去活動狀態的時候調用(失去焦點, 不可交互)
- (void)applicationWillResignActive:(UIApplication *)application
{
NSLog(@"ResignActive");
}
// 重新獲取焦點(能夠和用戶交互)
- (void)applicationDidBecomeActive:(UIApplication *)application
{
NSLog(@"BecomeActive");
}
// 應用程序進入后臺的時候調用
// 一般在該方法中保存應用程序的數據, 以及狀態
- (void)applicationDidEnterBackground:(UIApplication *)application
{
NSLog(@"Background");
}
// 應用程序即將進入前臺的時候調用
// 一般在該方法中恢復應用程序的數據,以及狀態
- (void)applicationWillEnterForeground:(UIApplication *)application
{
NSLog(@"Foreground");
}
// 應用程序即將被銷毀的時候會調用該方法
// 注意:如果應用程序處于掛起狀態的時候無法調用該方法
- (void)applicationWillTerminate:(UIApplication *)application
{
}
// 應用程序接收到內存警告的時候就會調用
// 一般在該方法中釋放掉不需要的內存
- (void)applicationDidReceiveMemoryWarning:(UIApplication *)application
{
NSLog(@"MemoryWarning");
}
@end
應用程序的五個狀態
- Not running:應用還沒有啟動,或者應用正在運行但是途中被系統停止。
- Inactive:當前應用正在前臺運行,但是并不接收事件(當前或許正在執行其它代碼)。一般每當應用要從一個狀態切換到另一個不同的狀態時,中途過渡會短暫停留在此狀態。唯一在此狀態停留時間比較長的情況是:當用戶鎖屏時,或者系統提示用戶去響應某些(諸如電話來電、有未讀短信等)事件的時候。
- Active:當前應用正在前臺運行,并且接收事件。這是應用正在前臺運行時所處的正常狀態。
- Background:應用處在后臺,并且還在執行代碼。大多數將要進入Suspended狀態的應用,會先短暫進入此狀態。然而,對于請求需要額外的執行時間的應用,會在此狀態保持更長一段時間。另外,如果一個應用要求啟動時直接進入后臺運行,這樣的應用會直接從Not running狀態進入Background狀態,中途不會經過Inactive狀態。比如沒有界面的應用。注此處并不特指沒有界面的應用,其實也可以是有界面的應用,只是如果要直接進入background狀態的話,該應用界面不會被顯示。
- Suspended:應用處在后臺,并且已停止執行代碼。系統自動的將應用移入此狀態,且在此舉之前不會對應用做任何通知。當處在此狀態時,應用依然駐留內存但不執行任何程序代碼。當系統發生低內存告警時,系統將會將處于Suspended狀態的應用清除出內存以為正在前臺運行的應用提供足夠的內存。