iOS 入门 —— MapKit Basics

更新,,,
今天,学习了view中的MapKit,实现了基本的地图工具调用。数据库

Functions 功能

  • pickerView 实现滚动选择地点
  • 每个pickerView中的item有一个对应的经纬坐标
  • 选到一个地点,上方的地图即切换到相应的位置
  • 地图使用 SegmentedControl 实现显示模式切换swift

    • standard,标准模式
    • satellite,卫星模式

Implements 具体实现

storyBoard

- 按照以前所学,咱们知道,要在右下角选择界面组件,这里咱们搜索map.
- 选择Map Kit View,拖入主界面
- 找到SegmentedControl拖入界面,两个值分别改成Standard 和 Satellite 
- 找到pickerView 拖入界面
完成图以下:

clipboard.png

ViewController

- 首先对pickerView初始化,将pickerView 中的每一个元素设为城市名
func pickerView(_ pickerView: UIPickerView, numberOfRowsInComponent component: Int) -> Int {
        return cityList.count
    }

    func pickerView(_ pickerView: UIPickerView, titleForRow row: Int, forComponent component: Int) -> String? {
        return cityList[row].name
    }
    
    func pickerView(_ pickerView: UIPickerView, didSelectRow row: Int, inComponent component: Int) {
        let selectedCity = cityList[row]
        let lat = selectedCity.lat
        let long = selectedCity.long
        let span = MKCoordinateSpanMake(0.075, 0.075)
        let region = MKCoordinateRegion(center: CLLocationCoordinate2DMake(lat, long), span: span)
        myMap.setRegion(region, animated: true)
    }
- 建立城市类,这里使用swift里的struct
import Foundation

struct city {
    var name: String
    var lat: Double
    var long: Double
- 而后,咱们须要见一个链表来存储城市, 这里新建4个;
- 新建城市对象以及城市的属性,插入链表
var cityList = [city]()
    
    func loadCity() {
        let shanghai = city(name: "Shanghai", lat: 31.2304, long: 121.4737)
        let LA = city(name: "Los Angeles", lat: 34.0522, long: -118.2437)
        let NY = city(name: "New York", lat: 40.7128, long: -74.0059)
        let Beijing = city(name: "Beijing", lat: 39.9042, long: 116.4074)
        // append cities into list
        cityList.append(shanghai)
        cityList.append(LA)
        cityList.append(NY)
        cityList.append(Beijing)
        
    }
- 再对segmentControl设定方法
@IBAction func changeMapView(_ sender: Any) {
        switch mapType.selectedSegmentIndex {
        case 0:
            myMap.mapType = MKMapType.standard
        case 1:
            myMap.mapType = MKMapType.satellite
        default:
            myMap.mapType = MKMapType.standard
        }
    }

好,如今来测试app

[image:835C8A90-C849-429E-BB8C-560E2B216962-15699-0000EB0EF90D9A34/Screen Shot 2017-09-17 at 19.32.11.png]工具

这是洛杉矶的standard地图,学习

clipboard.png

这是北京的satellite地图 ^_^测试

这就完成了简单的功能demo,后续,还能够加更多城市,甚至链接数据库,搜索出全球的城市,并定位该地获得地图。spa

Reference

App school for Xcode and iOS 10 Development Freecode

Copyright © 2017 zhiwei xu. All rights reserved.
相关文章
相关标签/搜索