Submit Search
Upload
Mapkitframework io9week
•
2 likes
•
3,466 views
Yuki Hirai
Follow
iOS 9 週連続 Boot Camp 5週目で発表した資料です。
Read less
Read more
Mobile
Report
Share
Report
Share
1 of 48
Download now
Download to read offline
Recommended
GTMF 2015: Autodesk Maya;大人気!カスタム・グラフエディタと便利ツールをPythonで!! | ダイキン工業株式会社
GTMF 2015: Autodesk Maya;大人気!カスタム・グラフエディタと便利ツールをPythonで!! | ダイキン工業株式会社
Game Tools & Middleware Forum
Xcodeショートカット
Xcodeショートカット
Keita Otsuka
watchOS 2でゲーム作ってみた話
watchOS 2でゲーム作ってみた話
Kohki Miki
初めての単体テスト
初めての単体テスト
Basuke Suzuki
Xcodeを便利に使って爆速開発する #yxcm
Xcodeを便利に使って爆速開発する #yxcm
Hiramatsu Ryosuke
Unity ネイティブプラグインの作成について
Unity ネイティブプラグインの作成について
Tatsuhiko Yamamura
RxDataSourceをNSDiffableDataSourceへ置き換える際のTips集紹介
RxDataSourceをNSDiffableDataSourceへ置き換える際のTips集紹介
Fumiya Sakai
試して感覚を掴んでみるUICollectionViewCompositionalLayout & Combine
試して感覚を掴んでみるUICollectionViewCompositionalLayout & Combine
Fumiya Sakai
Recommended
GTMF 2015: Autodesk Maya;大人気!カスタム・グラフエディタと便利ツールをPythonで!! | ダイキン工業株式会社
GTMF 2015: Autodesk Maya;大人気!カスタム・グラフエディタと便利ツールをPythonで!! | ダイキン工業株式会社
Game Tools & Middleware Forum
Xcodeショートカット
Xcodeショートカット
Keita Otsuka
watchOS 2でゲーム作ってみた話
watchOS 2でゲーム作ってみた話
Kohki Miki
初めての単体テスト
初めての単体テスト
Basuke Suzuki
Xcodeを便利に使って爆速開発する #yxcm
Xcodeを便利に使って爆速開発する #yxcm
Hiramatsu Ryosuke
Unity ネイティブプラグインの作成について
Unity ネイティブプラグインの作成について
Tatsuhiko Yamamura
RxDataSourceをNSDiffableDataSourceへ置き換える際のTips集紹介
RxDataSourceをNSDiffableDataSourceへ置き換える際のTips集紹介
Fumiya Sakai
試して感覚を掴んでみるUICollectionViewCompositionalLayout & Combine
試して感覚を掴んでみるUICollectionViewCompositionalLayout & Combine
Fumiya Sakai
20121201yidev hirobe iPad miniでRetina
20121201yidev hirobe iPad miniでRetina
Kazuya Hirobe
20120219i phonedeveloperworkshoppublished
20120219i phonedeveloperworkshoppublished
Yoichiro Sakurai
Titanium もくもく会第6回 Kii Cloud と TiGPUImageView
Titanium もくもく会第6回 Kii Cloud と TiGPUImageView
濱田 章吾
2012 05-19第44回cocoa勉強会発表資料
2012 05-19第44回cocoa勉強会発表資料
OCHI Shuji
iOS 9 Bootcamp #6 UIKit
iOS 9 Bootcamp #6 UIKit
Shingo Hiraya
Xamarin.Forms概要
Xamarin.Forms概要
Hironov OKUYAMA
Pin-point rebuildable and non-rebuild custom widget
Pin-point rebuildable and non-rebuild custom widget
cch-robo
既存アプリのiOS8対応 #ios8yahoo
既存アプリのiOS8対応 #ios8yahoo
Yahoo!デベロッパーネットワーク
iOS WebView App
iOS WebView App
hagino 3000
Swiftyを試す
Swiftyを試す
幸雄 村上
アップルのテンプレートは有害と考えられる
アップルのテンプレートは有害と考えられる
Brian Gesiak
LT発表資料
LT発表資料
murajun1978
I phonedevws20121028ci filter
I phonedevws20121028ci filter
ZuQ9Nn
Geo x html5 on MapsAPI three minutes cooking
Geo x html5 on MapsAPI three minutes cooking
Kentaro Ishimaru
個人開発したモバイルアプリを紹介したパワポ資料です。転職活動時にポートフォリオとして使用しました。
個人開発したモバイルアプリを紹介したパワポ資料です。転職活動時にポートフォリオとして使用しました。
ssusere75907
20130924 Picomon CRH勉強会
20130924 Picomon CRH勉強会
Yukihiro Kitazawa
iOSのUI構築小技集(小さなとこから始められる編)
iOSのUI構築小技集(小さなとこから始められる編)
Fumiya Sakai
よこへな3 15発表資料 最近ViewController をどんな感じで書いているか
よこへな3 15発表資料 最近ViewController をどんな感じで書いているか
Yuichiro Suzuki
Yolp30分クッキング 2012北海道
Yolp30分クッキング 2012北海道
Yahoo!デベロッパーネットワーク
UIImagePickerController よもやま話
UIImagePickerController よもやま話
Kei Kusakari
More Related Content
Similar to Mapkitframework io9week
20121201yidev hirobe iPad miniでRetina
20121201yidev hirobe iPad miniでRetina
Kazuya Hirobe
20120219i phonedeveloperworkshoppublished
20120219i phonedeveloperworkshoppublished
Yoichiro Sakurai
Titanium もくもく会第6回 Kii Cloud と TiGPUImageView
Titanium もくもく会第6回 Kii Cloud と TiGPUImageView
濱田 章吾
2012 05-19第44回cocoa勉強会発表資料
2012 05-19第44回cocoa勉強会発表資料
OCHI Shuji
iOS 9 Bootcamp #6 UIKit
iOS 9 Bootcamp #6 UIKit
Shingo Hiraya
Xamarin.Forms概要
Xamarin.Forms概要
Hironov OKUYAMA
Pin-point rebuildable and non-rebuild custom widget
Pin-point rebuildable and non-rebuild custom widget
cch-robo
既存アプリのiOS8対応 #ios8yahoo
既存アプリのiOS8対応 #ios8yahoo
Yahoo!デベロッパーネットワーク
iOS WebView App
iOS WebView App
hagino 3000
Swiftyを試す
Swiftyを試す
幸雄 村上
アップルのテンプレートは有害と考えられる
アップルのテンプレートは有害と考えられる
Brian Gesiak
LT発表資料
LT発表資料
murajun1978
I phonedevws20121028ci filter
I phonedevws20121028ci filter
ZuQ9Nn
Geo x html5 on MapsAPI three minutes cooking
Geo x html5 on MapsAPI three minutes cooking
Kentaro Ishimaru
個人開発したモバイルアプリを紹介したパワポ資料です。転職活動時にポートフォリオとして使用しました。
個人開発したモバイルアプリを紹介したパワポ資料です。転職活動時にポートフォリオとして使用しました。
ssusere75907
20130924 Picomon CRH勉強会
20130924 Picomon CRH勉強会
Yukihiro Kitazawa
iOSのUI構築小技集(小さなとこから始められる編)
iOSのUI構築小技集(小さなとこから始められる編)
Fumiya Sakai
よこへな3 15発表資料 最近ViewController をどんな感じで書いているか
よこへな3 15発表資料 最近ViewController をどんな感じで書いているか
Yuichiro Suzuki
Yolp30分クッキング 2012北海道
Yolp30分クッキング 2012北海道
Yahoo!デベロッパーネットワーク
UIImagePickerController よもやま話
UIImagePickerController よもやま話
Kei Kusakari
Similar to Mapkitframework io9week
(20)
20121201yidev hirobe iPad miniでRetina
20121201yidev hirobe iPad miniでRetina
20120219i phonedeveloperworkshoppublished
20120219i phonedeveloperworkshoppublished
Titanium もくもく会第6回 Kii Cloud と TiGPUImageView
Titanium もくもく会第6回 Kii Cloud と TiGPUImageView
2012 05-19第44回cocoa勉強会発表資料
2012 05-19第44回cocoa勉強会発表資料
iOS 9 Bootcamp #6 UIKit
iOS 9 Bootcamp #6 UIKit
Xamarin.Forms概要
Xamarin.Forms概要
Pin-point rebuildable and non-rebuild custom widget
Pin-point rebuildable and non-rebuild custom widget
既存アプリのiOS8対応 #ios8yahoo
既存アプリのiOS8対応 #ios8yahoo
iOS WebView App
iOS WebView App
Swiftyを試す
Swiftyを試す
アップルのテンプレートは有害と考えられる
アップルのテンプレートは有害と考えられる
LT発表資料
LT発表資料
I phonedevws20121028ci filter
I phonedevws20121028ci filter
Geo x html5 on MapsAPI three minutes cooking
Geo x html5 on MapsAPI three minutes cooking
個人開発したモバイルアプリを紹介したパワポ資料です。転職活動時にポートフォリオとして使用しました。
個人開発したモバイルアプリを紹介したパワポ資料です。転職活動時にポートフォリオとして使用しました。
20130924 Picomon CRH勉強会
20130924 Picomon CRH勉強会
iOSのUI構築小技集(小さなとこから始められる編)
iOSのUI構築小技集(小さなとこから始められる編)
よこへな3 15発表資料 最近ViewController をどんな感じで書いているか
よこへな3 15発表資料 最近ViewController をどんな感じで書いているか
Yolp30分クッキング 2012北海道
Yolp30分クッキング 2012北海道
UIImagePickerController よもやま話
UIImagePickerController よもやま話
Mapkitframework io9week
1.
MapKit Framework!! iOS 9
週連続 Bootcamp 5週目 Hirai Yuki @ Classmethod, Inc.
2.
自己紹介 • 平井 祐樹
@ クラスメソッド株式会社 • iOSアプリエンジニア • 最近はRuby on Rails • http://dev.classmethod.jp/author/hirai-yuki/ • https://github.com/hirai-yuki
3.
iOS 9 で追加された MapKit
の新機能
4.
MapKit の新機能 • Flyoverでマップを表示できる •
ピンの色をカスタマイズできる • 吹き出しをカスタマイズできる • スケールバーを表示できる • コンパスを表示できる • 交通状況を表示できる • 乗換案内機能をサポート • CLGeocoder/MKLocalSearch で Time zone をサポート
5.
地味だー
6.
MapKit Framework の 使い方について
iOS 9 での 変更点を(少し)踏まえて 解説します!
7.
受託あるある
8.
店舗マップ画面が欲しい!
9.
店舗マップ画面の仕様 • マップは標準(2D)地図と航空写真(Flyover)を切り替えられるようにする • コンパス・スケールバーをマップに表示する •
店舗を表すピンをマップに表示する • 店舗ピンはお店のロゴマークで • ピンがタップされたら吹き出しに店舗名と店舗画像を表示する • マップの初期表示位置は店舗ピンをすべて表示する • 現在位置から店舗までの経路案内を行う
10.
こんな感じ
11.
ソースコード • https://github.com/hirai-yuki/ShopMapSample
12.
店舗マップ画面の仕様 • マップは標準(2D)地図と航空写真(Flyover)を切り替えられるようにする • コンパス・スケールバーをマップに表示する •
店舗を表すピンをマップに表示する • 店舗ピンはお店のロゴマークで • ピンがタップされたら吹き出しに店舗名と店舗画像を表示する • マップの初期表示位置は店舗ピンをすべて表示する • 現在位置から店舗までの経路案内を行う
13.
MKMapType Satellite HybridStandard
14.
MKMapType • Standard • Satellite •
Hybrid • SatelliteFlyover <- New! • HybridFlyover <- New!
15.
SatelliteFlyover
16.
HybridFlyover • ラベルも表記
17.
MKMapType self.mapView.mapType = MKMapTypeHybridFlyover;
18.
19.
店舗マップ画面の仕様 • マップは標準(2D)地図と航空写真(Flyover)を切り替えられるようにする • コンパス・スケールバーをマップに表示する •
店舗を表すピンをマップに表示する • 店舗ピンはお店のロゴマークで • ピンがタップされたら吹き出しに店舗名と店舗画像を表示する • マップの初期表示位置は店舗ピンをすべて表示する • 現在位置から店舗までの経路案内を行う
20.
コンパスを表示する • showsCompass <-
New!
21.
スケールバーを表示する • showsScale <-
New!
22.
交通状況の表示 • showsTrafics <-
New! • 日本未対応っぽい
23.
店舗マップ画面の仕様 • マップは標準(2D)地図と航空写真(Flyover)を切り替えられるようにする • コンパス・スケールバーをマップに表示する •
店舗を表すピンをマップに表示する • 店舗ピンはお店のロゴマークで • ピンがタップされたら吹き出しに店舗名と店舗画像を表示する • マップの初期表示位置は店舗ピンをすべて表示する • 現在位置から店舗までの経路案内を行う
24.
25.
店舗ピンの表示 1. 店舗用注釈クラスを作成する(注釈 =
ピン) 2. データを準備する 3. 店舗用注釈ビューを作成する
26.
注釈オブジェクト • MKAnnotaion プロトコルに準拠したオブジェクト •
地図座標/タイトル/サブタイトルを保持する • 上記以外の情報が不要なら MKPointAnnotation を 使う • そうでないなら MKAnnotation に準拠したクラスを 定義する
27.
#import <Foundation/Foundation.h> #import <MapKit/MapKit.h> @interface
CLMShopAnnotation : NSObject <MKAnnotation> @property (nonatomic, readonly) CLLocationCoordinate2D coordinate; @property (nonatomic, readonly, copy, nullable) NSString *title; @property (nonatomic, readonly, nullable) UIImage *image; - (nonnull instancetype)initWithCoordinate:(CLLocationCoordinate2D)coordinate title:(nullable NSString *)title image:(nullable UIImage *)image; @end 1. 店舗用注釈クラスを作成する
28.
1. 店舗用注釈クラスを作成する
29.
2. データを準備する // MKShopAnnotationインスタンスの配列を生成 NSArray
*shops = @[ [[CLMShopAnnotation alloc] initWithCoordinate:CLLocationCoordinate2DMake(<緯度>, <経度>) title:@"クラスメソッド本店" image:[UIImage imageNamed:@"cm"]], ・・・ ]; // MKShopAnnotationインスタンスの配列をマップビューに追加 [self.mapView addAnnotations:shops];
30.
3. 店舗用注釈ビューを作成する • MKAnnotationView
またはその派生クラス • マップビューのデリゲートメソッドを定義して注釈ビュー を返す • 標準的なピン:MKPinAnnotationView • 独自の画像を使う:MKAnnotationView • もっとやる:MKAnnotationView のサブクラスを定義
31.
- (MKAnnotationView *)mapView:(MKMapView
*)mapView viewForAnnotation:(id <MKAnnotation>)annotation { if ([annotation isKindOfClass:[MKUserLocation class]]) { return nil; } else if ([annotation isKindOfClass:[CLMShopAnnotation class]]) { CLMShopAnnotation *shopAnnotation = (CLMShopAnnotation *)annotation; MKAnnotationView *annotationView = [mapView dequeueReusableAnnotationViewWithIdentifier:@"ShopAnnotation"]; if (annotationView) { annotationView.annotation = shopAnnotation; } else { annotationView = [[MKAnnotationView alloc] initWithAnnotation:shopAnnotation reuseIdentifier:@"ShopAnnotation"]; } annotationView.canShowCallout = YES; annotationView.image = [UIImage imageNamed:@"shop_pin"]; UIButton *rightButton = [UIButton buttonWithType:UIButtonTypeDetailDisclosure]; annotationView.rightCalloutAccessoryView = rightButton; annotationView.detailCalloutAccessoryView = [[UIImageView alloc] initWithImage:shopAnnotation.image]; return annotationView; } return nil; } 3. 店舗用注釈ビューを作成する detailCalloutAccessoryView <- New!
32.
店舗マップ画面の仕様 • マップは標準(2D)地図と航空写真(Flyover)を切り替えられるようにする • コンパス・スケールバーをマップに表示する店舗を表すピンをマップに 表示する •
店舗ピンはお店のロゴマークで • ピンがタップされたら吹き出しに店舗名と店舗画像を表示する • マップの初期表示位置は店舗ピンをすべて表示する • 現在位置から店舗までの経路案内を行う
33.
初期表示位置を指定する • - showAnnotations:animate:
を使用 • 引数で指定したピンがすべて表示されるよ う表示位置と縮尺を設定してくれる [self.mapView showAnnotations:self.shops animated:YES];
34.
35.
regionを指定する場合 • MKCoordinateRegion構造体で表される • 縮尺の指定に慣れが必要
36.
MKCoordinateRegion typedef struct { CLLocationCoordinate2D
center; MKCoordinateSpan span; } MKCoordinateRegion; 中心位置 ???
37.
MKCoordinateSpan • ある地点において可視である地図上の範囲 • 単位:度、分、秒 •
大きなスパン:広い範囲(低い拡大率) • 小さなスパン:狭い範囲(高い拡大率) • 緯度1度 ≒ 111km、経度1度 = 緯度によって変わる • MKCoordinateRegionMakeWithDistance で「m」でも作成できる • マップビューでは指定されたスパンが収まるようなズームレベルを暗黙的に設 定し、regionを調節する
38.
MKCoordinateSpan self.mapView.region = MKCoordinateRegionMakeWithDistance(CLLocationCoordinate2DMake(<緯度>, <経度>),
100, 100); iPhone 6s plus iPhone 5s iPhone 4s
39.
店舗マップ画面の仕様 • マップは標準(2D)地図と航空写真(Flyover)を切り替えられるようにする • コンパス・スケールバーをマップに表示する •
店舗を表すピンをマップに表示する • 店舗ピンはお店のロゴマークで • ピンがタップされたら吹き出しに店舗名と店舗画像を表示する • マップの初期表示位置は店舗ピンをすべて表示する • 現在位置から店舗までの経路案内を行う
40.
経路案内 • 2地点間の経路探索にMKDirectionsを使用 • 得られた経路をマップに描画
41.
MKDirectionsによる経路探索 • 出発地(現在地)と目的地のMKMapItemイン スタンスを生成 MKMapItem *source
= [MKMapItem mapItemForCurrentLocation]; MKPlacemark *placemark = [[MKPlacemark alloc] initWithCoordinate:annotation.coordinate addressDictionary:nil]; MKMapItem *destination = [[MKMapItem alloc] initWithPlacemark:placemark];
42.
MKDirectionsによる経路探索 • 出発地と目的地のMKMapItemインスタンスを用 いてMKDirectionsRequestインスタンスを生成 MKDirectionsRequest *request
= [MKDirectionsRequest new]; request.transportType = MKDirectionsTransportTypeAutomobile; request.source = source; request.destination = destination;
43.
MKDirectionsによる経路探索 • 作成したMKDirectionsRequestインスタンスを引数にセットして MKDirectionsインスタンスを生成 • -
calculateDirectionsWithCompletionHandler:メソッドを実行 MKDirections *directions = [[MKDirections alloc] initWithRequest:request]; [directions calculateDirectionsWithCompletionHandler:^(MKDirectionsResponse *response, NSError *error) { ・・・ }];
44.
経路の描画 • MKRouteのpolylineプロパティ MKDirections *directions
= [[MKDirections alloc] initWithRequest:request]; [directions calculateDirectionsWithCompletionHandler:^(MKDirectionsResponse *response, NSError *error) { ・・・ [self.mapView addOverlay:route.polyline level:MKOverlayLevelAboveRoads]; ・・・ }]; - (MKOverlayRenderer *)mapView:(MKMapView *)mapView rendererForOverlay:(id <MKOverlay>)overlay { if ([overlay isKindOfClass:[MKPolyline class]]) { MKPolyline *polyline = overlay; MKPolylineRenderer *renderer = [[MKPolylineRenderer alloc] initWithPolyline:polyline]; renderer.lineWidth = 3.0; renderer.strokeColor = [UIColor colorWithRed:255/255.0 green:81/255.0 blue:81/255.0 alpha:1.0]; return renderer; } return nil; }
45.
46.
まとめ • Flyoverはおもしろそう! • 早く日本も乗換案内と交通状況を対応してほしい
47.
References • 位置情報とマッププログラミングガイド • https://developer.apple.com/jp/documentation/ LocationAwarenessPG.pdf •
AlohaYos/LocalSearch • https://github.com/AlohaYos/LocalSearch • 地図ライブラリ • http://www.asahi-net.or.jp/~YY8A-IMI/20040913/ipad/ map.htm
48.
ご清聴ありがとうございました
Download now