搞定了環境配置,我們趕快開始ArcGIS for iOS開發吧,按慣例首先建立一個“Hello World Map”程式,使用在上一節中我們建立好的項目。
第一步:配置介面。
找到“ViewController_iPhone/iPad.xib”(分別針對了iPhone和iPad不同的布局),在內容視窗中可以看到只有一個空白的View視圖,右下側的工具視窗切換到組件對象,其中列舉了Cocoa Touch庫的全部可視化組件,定位到“View”對象,將其直接拖到內容視窗裡,一個新的子視圖就添加成功了,同時還添加了Constraints(Xcode4.5的新特性,寬高布局限制),把新添加的視圖重新命名為“Map
View”。
圖3-1 添加地圖視圖
選中“Map View”視圖,在右上側的屬性視窗切換到“inspector”項,修改其繼承類為“AGSMapView”。
圖3-2 修改Map View的繼承類為AGSMapView
然後“Command + s”儲存。
第二步:添加代碼。
1) 標頭檔“ViewController.h”,添加ArcGIS標頭檔引用,並聲明一個地圖控制項的屬性,代碼如下:
#import <UIKit/UIKit.h>#import <ArcGIS/ArcGIS.h> @interface TMViewController : UIViewController@property(nonatomic,strong)IBOutletAGSMapView *mapView;@end
* @property關鍵字:公用屬性標記,相當與“Get-Set”構造,4.0以前的版本中與synthesizes成對使用,4.0之後不再需要synthesizes。
* IBOutlet關鍵字:介面 “插座”標記(以前的介面編輯工具Interface Builder,4.0後被整合進了Xcode,“插座”,表示與介面元素串連的屬性對象。與之呼應的還有一個IBAction,表示介面元素的事件響應。
不想敲太多這種機械代碼的話,還可以在介面視圖中完成,選中要串連的介面對象,右鍵拖動到代碼視窗,會彈出一個小對話方塊,輸入屬性名稱mapView,確定後會自動產生這個屬性。
圖3-3 自動產生屬性
2) 開啟類檔案“ViewController.m” ,在viewDidLoad方法中添加如下代碼:
- (void)viewDidLoad{ [superviewDidLoad]; // //基礎底圖,使用的是北京捷泰科技有限公司提供的線上地圖,更多地圖請登陸ArcGIS Online中國網址查詢(http://www.arcgisonline.cn) NSString *str_URL = @"http://www.arcgisonline.cn/ArcGIS/rest/services/ChinaOnlineCommunity/MapServer"; NSURL *url_Tiled = [NSURLURLWithString:str_URL]; AGSTiledMapServiceLayer *tiledLyr = [AGSTiledMapServiceLayertiledMapServiceLayerWithURL:url_Tiled]; [self.mapViewaddMapLayer:tiledLyrwithName:@"TiledLayer"]; //動態圖層,使用ArcGIS Online的全球人口資料 NSString *str_URL_1 = @"http://sampleserver1.arcgisonline.com/ArcGIS/rest/services/Demographics/ESRI_Population_World/MapServer"; NSURL *url_Dynamic =[NSURLURLWithString:str_URL_1]; AGSDynamicMapServiceLayer *dynamicLyr =[AGSDynamicMapServiceLayerdynamicMapServiceLayerWithURL:url_Dynamic]; UIView<AGSLayerView>*dynamicLyrView = [self.mapViewaddMapLayer:dynamicLyrwithName:@"PopulationLayer"]; //設定動態圖層透明度 dynamicLyrView.alpha = 0.3; //設定地圖初始化顯示範圍為中國 AGSEnvelope *chinaEnv = [AGSEnvelopeenvelopeWithXmin:7800000.00 ymin:44000.00 xmax:15600000.00 ymax:7500000.00 spatialReference:self.mapView.spatialReference]; [self.mapViewzoomToEnvelope:chinaEnvanimated:YES];}
第三步:綁定介面與代碼。
Xcode裡綁定介面元素與代碼對象的操作方法很藝術,選中介面視圖的File’s Owner,右上側屬性視窗切換到“Connections”項,“Outlets”裡有一個mapView對象,這就是我們在ViewController.h中聲明的地圖控制項屬性。拖動其右側的空心小圓圈,牽引到左側介面對象“Map View” 上,綁定成功後,小圓圈就變成實心了的,再次儲存。
圖3-3 綁定地圖控制項與代碼對象
第四步:儲存工程,“Command+ r ”運行並調試“HelloWorld Map”。
圖3-4 在iPhone5模擬器中運行“Hello World Map”
*REST和JSON大家都應該很熟悉了,ArcGIS Server發布的服務支援SOAP、REST兩種結構,而Web和移動API中都使用其REST服務介面,比如上文中提到的地圖服務:http://yourServer/ArcGIS/rest/services/Demographics/ESRI_Population_World/MapServer。資料互動使用的是更為靈活高效的JSON格式,ArcGIS架構中整合了第三方庫json-framework來負責中介層的資料轉換,開發人員一般不用操心。
推薦閱讀:1、ArcGIS
Runtime SDK for iOS開發系列教程(4)——如何讓你的iOS應用具有GIS能力:http://www.cnblogs.com/esrichina/archive/2012/11/05/2750569.html2、ArcGIS
Runtime SDK for iOS開發系列教程(2)——MapViewDemo解析:http://www.cnblogs.com/esrichina/archive/2012/09/01/2666647.html