zoukankan      html  css  js  c++  java
  • ArcGIS Runtime SDK for iOS开发系列教程(2)——MapViewDemo解析

          安装完ArcGIS Runtime SDK for iOS后,系统会自带一个支持ArcGIS Runtime SDK的项目MapViewDemo。路径为:${HOME}/Library/SDKs/ArcGIS/Samples/MapViewDemo

          打开MapViewDemo文件夹下的MapViewDemo.xcodeproj项目文件,可以在Xcode中看到项目文件结构如图

                                                                                     图1 MapViewDemo文件结构

    下面我们来介绍下MapViewDemo中文件结构

    1.ArcGIS.bundle(包)是一个内部结构按照标准规则组织的ArcGIS资源目录(使用方法如:ArcGIS.bundle/GpsDisplay.png)。解压后可以看到以下资源:

                                                                                    图2 ArcGIS.bundle包含的资源

    其中Resources目录是应用程序本地化的一些设置

                                                                            图3 ArcGIS.bundle中用于应用程序本地化的资源

          其实,iOS的应用也都是通过bundle进行封装的,只不过对应的bundle类型为Application而已。Finder会把这个bundle当做一个文件显示给我们,因为这个bundle自身也是一个package,而Mac系统会把所有的package当做一个文件显示给用户,从而防止用户误操作导致程序文件损坏或丢失。

    2.Classes文件夹,用来存放我们编写的代码,包括所有的Objective-C类,也可以通过创建子文件夹进行分类。该demo中包含两个类:MapViewDemoViewController(视图控制类)和MapViewDemoAppDelegate(应用程序代理类)。

          在每一个IOS应用程序都有一个实现UIApplicationDelegate协议的AppDelegate类,用来通过从iOS接收消息的方式来跟踪应用程序的状态变化。如,在开始的时候就运行– applicationDidFinishLaunching方法,在结束的时候运行– applicationWillTerminate方法。它还可以让你确定什么时候接电话,或者什么时候内存将满等。

    3.Other Sources文件夹,用来存放Objective—C类之外的源代码文件。通常,它包含了MapViewDemo_Prefix.pch和main.m文件。

          *.pch文件表示预编译头文件(precompiled header),包含了项目中所使用的来自外部框架的一组头文件。Xcode会预编译包含在此文件中的头文件,以减少项目编译时间。

          main.m文件包含应用程序的main()方法,一般不需要修改。

    4.Resources文件夹,用来存放应用程序的非代码文件。如:应用程序图标文件、图片资源、声音影片资源、文本文件等。

          由于IOS应用程序在自己的沙盒中运行,因此需要将应用程序所需的文件资源保存在此处。

          MapViewDemoViewController.xib文件是应用程序的界面视图文件,可以使用Interface Builder(用于应用程序界面设计的工具)进行编辑,如拖放控件等。

          MainWindow.xib是应用程序界面构建的主文件,默认不需要修改。

          MapViewDemo-Info.plist包含应用程序相关配置信息的属性列表。

          Resources-iPad是构建iPad设备应用界面所需的文件。

    5.Frameworks,是应用程序需要使用到的框架或者库文件。可以包含代码、图像、声音文件等资源,5中框出来的框架和库就是MapViewDemo这个项目需要用的框架和库文件。

          其中*.a为静态库、*.dylib为动态库。

          该文件夹下添加的任何框架和库都将连链接到应用程序中,并且代码将能够使用包含在该框架或者库中的对象、函数和资源。

    6.Products,存放项目编译时生成的应用程序。

          MapViewDemo.app是该项目的唯一产品,红色表明无法找到该文件,需要连接设备编译

    以上就是MapViewDemo这个项目包含的文件以及他们的作用,下面我们运行看看效果,在虚拟机中使用window键+R运行项目,效果如下图

            接下来,我们来看MapViewDemo中的代码部分

            每一个Objective-C类都包含两部分,类声明(*.h)和类实现(*.m)

            其中,应用程序代理类MapViewDemoAppDelegate的声明如下:

           Objective-C中使用@interface和@end关键字来声明一个类,以上MapViewDemoAppDelegate类是一个实现了实现UIApplicationDelegate协议的NSObject类,并定义了用于界面构建的输出口UIWindow和视图控制器MapViewDemoViewController。

           #import表示头文件包含,IBOutlet是输出口关键字,retain、nonatomic跟内存管理相关。

           关于Objective-C的语法后面专门来讲,大家也可以参考网络上关于Objective-C的资源。     

           MapViewDemoAppDelegate的实现

          Objective-C中使用@implementation和@end关键字来实现一个类。

          @synthesize关键字类似于对象的setter,getter 方法。

          在应用程序入口applicationDidFinishLauching函数中,实现界面创建,使用addSubView的方法将视图控制器中的界面元素添加到视图中并设置显示。

          dealloc用于应用程序关闭时对象销毁。

          视图控制器类的声明

           MapViewDemoViewController:UIViewController<AGSMapViewLayerDelegate>{}表明MapViewDemoViewController是继承与视图控制类,并实现了AGSMapViewLayerDelegate协议。AGSMapView、AGSDynamicMapServiceLayer等就是ArcGIS Runtime SDK提供的用于访问ArcGIS的GIS功能的Objective-C类,类似于Flex等其他平台的API的对象。

           Objective-C中使用IBAction来声明一个方法。

           -(IBAction)opacitySliderValueChanged(id)sender;是MapViewDemoViewController类的一个方法,用于拖动滑块改变动态图层的透明度。

           视图控制器类实现

             如果你使用过基于REST接口的ArcGIS API,是不是感觉非常熟悉呢,在IOS中这个接口的使用都是类似。

             我们不难理解,在视图创建完成后应用程序完成了切片图层的初始化、动态图层初始化以及在视图中加载、投影、显示范围设置等操作。

             -(IBAction) opacitySliderValueChanged:(id)sender{self.dynamicLayerView.alpha=((UISlider *)sende).value;}用于实现拖动滑块改变图层透明度的操作

             -(void) mapViewDidLoad:(AGSMapView*)mapView{[self.mapview.gps.start];} 用于实现AGSMapViewLayerDelegate协议中的mapViewDidLoad:方法,作用就是在地图加载完成后,开启ArcGIS Runtime SDK自带的GPS定位功能。

            总结:本讲主要向大家介绍ArcGIS Runtime SDK for iOS自带例子的文件结构与代码逻辑,下一讲我们将给大介绍Objective-C语法基础,欢迎大家继续关注!

  • 相关阅读:
    echarts模拟highcharts实现折线图的虚实转换
    Chrome开发者工具详解 (5):Application、Security、Audits面板
    Chrome 开发者工具详解(4):Profiles 面板
    Chrome开发者工具详解(3):Timeline面板
    Chrome 开发者工具详解(2):Network 面板
    Chrome开发者工具详解(1):Elements、Console、Sources面板
    移动前端开发之 viewport 的深入理解
    响应式图片
    JS中的函数节流
    总结oninput、onchange与onpropertychange事件的用法和区别 书写搜索的神奇代码
  • 原文地址:https://www.cnblogs.com/esrichina/p/2666647.html
Copyright © 2011-2022 走看看