最初にmapboxのサイトでアカウントを作成しログイン
MapBox SDKのページを開く
https://docs.mapbox.com/ios/maps/overview/
インストールボタンをクリック
data:image/s3,"s3://crabby-images/69df8/69df839b934d2a3daa5b934dfa63f9bef828369a" alt=""
ダウンロードボタンをクリック
data:image/s3,"s3://crabby-images/2f002/2f002b2ea57299d8dc1351a44416201d4130a9ee" alt=""
mapbox-ios-sdk-5.4.0-dynamic.zipをダウンロード
data:image/s3,"s3://crabby-images/414fc/414fc28e146655e542646a0dfd4555fdfd33c1b8" alt=""
XCODEを起動してSingle View Appのプロジェクトを作成
data:image/s3,"s3://crabby-images/2766a/2766acc61844b12ccdb53566fb685bab6575cf37" alt=""
ダウンロードしたmapbox-ios-sdk-5.4.0-dynamic.zipを展開し中のMapbox.frameworkをEmbedded Binariesにドラッグして参照を追加
data:image/s3,"s3://crabby-images/f93cd/f93cda526c9519890825be18b3fd0b2f52ce449c" alt=""
TARGETSのBuild Phases画面を開き、+(追加)ボタンを押す
data:image/s3,"s3://crabby-images/384ac/384ac41b636bfecefe4690d4075759ebc71a8639" alt=""
Run Scriptを追加しMapboxのサイトに従い設定
data:image/s3,"s3://crabby-images/cccfc/cccfced7898c61e75124f1caa04ab6b5e9e5f175" alt=""
data:image/s3,"s3://crabby-images/de48e/de48e4e2acc941642728d71c93885f9508b63937" alt=""
info.listにMGLMapboxAccessTokenを追加しキーを入力
data:image/s3,"s3://crabby-images/4f9d1/4f9d1b11e0a33298c2095ba832fc48c353fa94fb" alt=""
ViewController.mを編集
#import "ViewController.h"
@import Mapbox;
@interface ViewController () <MGLMapViewDelegate>
@property (nonatomic) MGLMapView *mapView;
@end
地図を表示
ViewControllerのviewDidLoadを以下に従って編集
- (void)viewDidLoad {
[super viewDidLoad];
NSURL *url = [NSURL URLWithString:@"mapbox://styles/mapbox/streets-v11"];
self.mapView = [[MGLMapView alloc] initWithFrame:self.view.bounds styleURL:url];
self.mapView.autoresizingMask = UIViewAutoresizingFlexibleWidth | UIViewAutoresizingFlexibleHeight;
[self.mapView setCenterCoordinate:CLLocationCoordinate2DMake(35.73353,139.712118)
zoomLevel:12
animated:NO];
self.mapView.delegate = self;
[self.view addSubview:self.mapView];
[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(offlinePackProgressDidChange:) name:MGLOfflinePackProgressChangedNotification object:nil];
[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(offlinePackDidReceiveError:) name:MGLOfflinePackErrorNotification object:nil];
[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(offlinePackDidReceiveMaximumAllowedMapboxTiles:) name:MGLOfflinePackMaximumMapboxTilesReachedNotification object:nil];
}
池袋を中心に地図を表示
data:image/s3,"s3://crabby-images/8d67b/8d67b31071835acf6e25ada336c5f2cba67464d8" alt=""
デフォルトのAnnotationを表示
- (void)mapViewDidFinishLoadingMap:(MGLMapView *)mapView {
MGLPointAnnotation *hello = [[MGLPointAnnotation alloc] init];
hello.coordinate = CLLocationCoordinate2DMake(35.73353,139.712118);
hello.title = @"カーネル";
hello.subtitle = @"Welcome to my marker";
[mapView addAnnotation:hello];
}
- (MGLAnnotationImage *)mapView:(MGLMapView *)mapView viewForAnnotation:(id <MGLAnnotation>)annotation {
return nil;
}
- (BOOL)mapView:(MGLMapView *)mapView annotationCanShowCallout:(id <MGLAnnotation>)annotation {
return NO;
}
data:image/s3,"s3://crabby-images/37d22/37d225f029fe0b79a8509562105c71695ce4486e" alt=""
関数:annotationCanShowCalloutの戻り値にYESを返すとAnnotationをクリックするとTooltipを表示する
data:image/s3,"s3://crabby-images/37f07/37f076b593eb41a244a51aa6900973627ca54109" alt=""
デフォルトのAnnotationではなくMGLAnnotationViewを使ってカスタムAnnotationを表示
viewForAnnotationでnilではなく、MGLAnnotationViewを返す
- (MGLAnnotationImage *)mapView:(MGLMapView *)mapView viewForAnnotation:(id <MGLAnnotation>)annotation {
// 100はannotationを区別するキー。テストなので固定
MGLAnnotationView *annotationView = [mapView dequeueReusableAnnotationViewWithIdentifier:@"100"];
if (!annotationView) {
annotationView = [[MGLAnnotationView alloc] initWithReuseIdentifier:@"100"];
annotationView.frame = CGRectMake(0, 0, 30, 30);
annotationView.layer.cornerRadius = annotationView.frame.size.width / 2;
annotationView.layer.borderColor = [UIColor whiteColor].CGColor;
annotationView.layer.borderWidth = 4.0;
annotationView.backgroundColor = [UIColor colorWithRed:0.03 green:0.80 blue:0.69 alpha:1.0];
}
return annotationView;
}
data:image/s3,"s3://crabby-images/2b497/2b497de2dd26c12b095e1509e3fd85c03eae6320" alt=""
MGLAnnotationViewを選択するとdidSelectAnnotationViewイベントが発生する
- (void)mapView:(MGLMapView *)mapView didSelectAnnotationView:(MGLAnnotationView *)annotationView {
NSLog(@"didSelectAnnotationView");
}
Annotationに画像を表示
viewForAnnotationではnilを返すように戻し、imageForAnnotationでMGLAnnotationImageを返すように変更
- (MGLAnnotationImage *)mapView:(MGLMapView *)mapView viewForAnnotation:(id <MGLAnnotation>)annotation {
return nil;
}
- (MGLAnnotationImage *)mapView:(MGLMapView *)mapView imageForAnnotation:(id <MGLAnnotation>)annotation {
MGLAnnotationImage *annotationImage = [mapView dequeueReusableAnnotationImageWithIdentifier:@"100"];
if (!annotationImage) {
UIImage *image = [UIImage imageNamed:@"place8.png"];
image = [image imageWithAlignmentRectInsets:UIEdgeInsetsMake(0, 0, image.size.height/2, 0)];
annotationImage = [MGLAnnotationImage annotationImageWithImage:image reuseIdentifier:@"100"];
}
return annotationImage;
}
data:image/s3,"s3://crabby-images/f9f69/f9f69adaad48df1c9b97075376d38cc4742f2bee" alt=""
背景を国土地理院のタイル(ラスタ)に変更
baseman.jsonを作成(ファイル名は任意)
このファイルの内容はmapbox-gl-native for ios で地理院地図を表示してみるのそのまんまです
{
"version": 8,
"name": "Raster Tiles",
"sources": {
"gsiStd": {
"type": "raster",
"tiles": [
"http://cyberjapandata.gsi.go.jp/xyz/std/{z}/{x}/{y}.png"
],
"tileSize": 256
}
},
"layers": [{
"id": "gsiStd",
"type": "raster",
"source": "gsiStd",
"paint": {
"raster-fade-duration": 100
}
}]
}
baseman.jsonをプロジェクトに追加
data:image/s3,"s3://crabby-images/e774f/e774f01c04eeb6631894c532f51570806bf5eaf9" alt=""
MGLMapViewのコンストラクタに渡すstyleURLを変更
- (void)viewDidLoad {
[super viewDidLoad];
NSURL *url = [[NSBundle mainBundle] URLForResource:@"basemap" withExtension:@"json"];
self.mapView = [[MGLMapView alloc] initWithFrame:self.view.bounds styleURL:url];
self.mapView.autoresizingMask = UIViewAutoresizingFlexibleWidth | UIViewAutoresizingFlexibleHeight;
[self.mapView setCenterCoordinate:CLLocationCoordinate2DMake(35.73353,139.712118)
zoomLevel:12
animated:NO];
self.mapView.delegate = self;
[self.view addSubview:self.mapView];
以下省略
}
data:image/s3,"s3://crabby-images/8e780/8e780443ddb3f08da23aaa83d4b8d369b3f6f2c3" alt=""