data:image/s3,"s3://crabby-images/b55e1/b55e13ad366234419070a9680d7a5227b4923f31" alt=""
MacBookが手に入ったので早速マップ表示するiPhoneアプリを作ってみることにした。
とりあえず現在地表示。
やりかた
1.Xcodeプロジェクト作成
何はともあれ iPhoneアプリを作るのでXcode起動してプロジェクト作成。data:image/s3,"s3://crabby-images/f3902/f3902e255ca7a872c60bb300aea852e588db9594" alt=""
data:image/s3,"s3://crabby-images/9ccf6/9ccf641a7d5b22f2d77689dfbb998ffae05d7540" alt=""
どんなアプリケーションにするか聞いてくるので、今回はSingle View Applicationを選択。
data:image/s3,"s3://crabby-images/53bae/53bae912c3186deba5c8f0263cc76975c8895add" alt=""
プロジェクト名は適当にMapKitSampleとかにした。
「Use Storyboards」にチェック(画面レイアウトするのに使うっぽい)
「Use Automatic Reference Counting」にチェック(コンパイラがオブジェクトの管理してくれるっぽい)
data:image/s3,"s3://crabby-images/7621e/7621e5731bf8f1617e26d267ee4e21b34bd27057" alt=""
プロジェクトフォルダ作る場所を適当に選んでCreate
data:image/s3,"s3://crabby-images/fc6ea/fc6eafa4b95cff7d69922f3d0f9b6b9d70fc9625" alt=""
プロジェクトできた。わーい。
data:image/s3,"s3://crabby-images/14929/14929cafdd4215e65763878923cf901343803c58" alt=""
とりあえず、SimulatorがiPadになってるからiPhoneに変更
data:image/s3,"s3://crabby-images/119a5/119a512ccc8e8a0a4f83a6fbad4d3c8a15079997" alt=""
2.必要なFrameworkの追加
画面中央の「Summary」のところを下にスクロールしていくと「Linked Frameworks and Libraries」があるので、「+」ボタンで追加。data:image/s3,"s3://crabby-images/9ed66/9ed66570d148ae974b464d090ccc96c5281a76e7" alt=""
今回必要なのはMapKitとCoreLocationってやつなので、順に追加する。
data:image/s3,"s3://crabby-images/0f620/0f6208cd0ec2e9a1ca97e4d5bf48e8941e23882b" alt=""
両方追加するとこんな感じ。
data:image/s3,"s3://crabby-images/594e9/594e93319ecf1c6146893224ba5436bfaef11be5" alt=""
3.画面にMapViewを貼り付ける
MainStoryboard_iPhone.storyboardを選択して画面レイアウトを表示する。data:image/s3,"s3://crabby-images/a7d17/a7d1791376cde2e7a317f17745bec2bfe9668f79" alt=""
右下の〜Viewとかがあるところを下にスクロールしていくとMapViewがあるのでドラッグドロップで貼り付ける。
これでもうマップ表示できるみたい。あら簡単。
data:image/s3,"s3://crabby-images/64210/6421078baa2a875ba80016c18f16b8db2296b04c" alt=""
4.コード書く
今回は現在地を表示するって決めたので、ちょっとだけコード書く。ViewController.hを選択してソースを開く。
Frameworkを読み込むために下記コードを追加する。(なんかソースの表示がおかしくなっちゃう。)
#import
data:image/s3,"s3://crabby-images/4b728/4b7289ddc6781cf9e7b3aaae780f161f38d60edf" alt=""
良い感じに書けたら、その下のViewController.mを選択してソースを開く。
下記コードを追加する。
MKMapView *_mapView; - (void)viewDidLoad { [super viewDidLoad]; // 地図の表示 _mapView = [[MKMapView alloc] init]; _mapView.frame = self.view.bounds; _mapView.mapType = MKMapTypeStandard; _mapView.showsUserLocation = YES; [self.view addSubview:_mapView]; [_mapView.userLocation addObserver:self forKeyPath:@"location" options:0 context:NULL]; } - (void)observeValueForKeyPath:(NSString *)keyPath ofObject:(id)object change:(NSDictionary *)change context:(void *)context { // 地図の中心座標に現在地を設定 _mapView.centerCoordinate = _mapView.userLocation.location.coordinate; // 表示倍率の設定 MKCoordinateSpan span = MKCoordinateSpanMake(0.01, 0.01); MKCoordinateRegion region = MKCoordinateRegionMake(_mapView.userLocation.coordinate, span); [_mapView setRegion:region animated:YES]; }
data:image/s3,"s3://crabby-images/9d56c/9d56cf7cbe8caa592807e97bb4ff3df9c0084787" alt=""
これも良い感じに書けたら完成。
左上の再生ボタンを押すとiPhoneのSimulatorが起動して実行される。
data:image/s3,"s3://crabby-images/91cbb/91cbba753c9d7ad6ffd9de9717ec01defce1d9d3" alt=""
とってもいい感じに出来ました。
Objective-Cは全然わかんないけどaideal.jpさんのお陰で出来ました。
http://aidealjp.blog.fc2.com/blog-entry-23.html
調べてるうちにわかったけど、MapKitとGoogleMapは違うんだね。
次はGoogle Maps SDK for iOSを使ってやってみようかな。