SHOEISHA iD

※旧SEメンバーシップ会員の方は、同じ登録情報(メールアドレス&パスワード)でログインいただけます

CodeZine編集部では、現場で活躍するデベロッパーをスターにするためのカンファレンス「Developers Summit」や、エンジニアの生きざまをブーストするためのイベント「Developers Boost」など、さまざまなカンファレンスを企画・運営しています。

iOS16の新機能に触れてみよう

iOS16/SwiftUI4で高度になった地図機能に触れてみよう

iOS16の新機能に触れてみよう 第3回

  • X ポスト
  • このエントリーをはてなブックマークに追加

MKMapViewでの3Dマップの利用

 3Dマップは、OSに既定でインストールされている地図アプリのみで利用できました。iOS16以降では、MKMapViewが3Dマップに対応し、開発者が作成するアプリで3Dマップが利用できるようになりました。

マップの種類を指定する

 preferredConfigurationプロパティで行います。マップの種類を指定する構造体は、MKStandardMapConfiguration(標準)、MKHybridMapConfiguration(ハイブリッド)、MKImageryMapConfiguration(衛星画像)の3種類です。

 MKMapConfiguration.ElevationStyle(標高のレベル)、MKStandardMapConfiguration.EmphasisStyle(地図上のオブジェクトを強調するか)の2つのオブジェクトで設定します。

マップの種類の詳細を指定する構造体
構造体 概要
MKMapConfiguration.ElevationStyle 標高を地図に反映するか(標準の地図のみ) 0:しない(既定)、1:する
MKStandardMapConfiguration.EmphasisStyl 地図上のオブジェクトを強調するか 0:しない(既定)、1:する

 これら3つの要素で地図の種類を決められますので、その3つに応じたプロパティを持つクラスをMapSettingの名前で作成します。

[リスト4]MapTypeSample/ContentView.swift抜粋
class MapSetting: ObservableObject {
    @Published var mapType = 0
    @Published var elevation = 0
    @Published var emphasis = 0
}

 作成したMapSettingクラスをMapView構造体にEnvironmentObject型のプロパティとして設けます。Viewを更新する際に、プロパティの値に応じて地図の種類を切り替える処理を作成します。

[リスト5]MapTypeSample/ContentView.swift抜粋
struct MapView: UIViewRepresentable {
    @EnvironmentObject var mapSetting: MapSetting
    # 略
    // View更新処理
    func updateUIView(_ uiView: MKMapView, context: Context) {
        switch self.mapSetting.mapType {
        case 0:  // 標準の地図
            uiView.preferredConfiguration = MKStandardMapConfiguration(
                elevationStyle: MKMapConfiguration.ElevationStyle(rawValue: mapSetting.elevation)!,
                emphasisStyle: MKStandardMapConfiguration.EmphasisStyle(rawValue: mapSetting.emphasis)! )
        # 以下、同様にハイブリッド/衛星画像を指定
        # 略
        }
    }
}

 ContentView側では、MapSettingクラスをObservedObject型のプロパティとして設けます。PickerでMapSettingクラスの各プロパティの値を変更できるようにします。

[リスト6]MapTypeSample/ContentView.swift抜粋
struct ContentView: View {
    @ObservedObject var mapSetting = MapSetting()
    
    var body: some View {
        ZStack {
            MapView().environmentObject(mapSetting).edgesIgnoringSafeArea(.all)    // -------- ①
        }.overlay(alignment: .bottom) {
            VStack {
                // 地図の種別設定
                Picker("Map Type", selection: $mapSetting.mapType) {    // -------- ②
                    Text("Standard").tag(0)
                    Text("Hybrid").tag(1)
                    Text("Image").tag(2)
                }.pickerStyle(SegmentedPickerStyle())
                    .onChange(of: mapSetting.mapType) {
                        mapSetting.mapType = $0
                    }.padding([.top, .leading, .trailing], 16)
                
                // 標高スタイル、地図上のオブジェクトに関しても同様の処理を作成
                // 略
            }.background(.gray)
        }
    }
}

 ObservedObject型のプロパティとMapView内に設けたプロパティを接続します(①)。(②)以降では、Pickerでプロパティの各値を指定できるようにします。このことによって、バインディング変数を通してPickerで選択した値が地図の種類に反映されるようにできます。

地図の種類
地図の種類

 iOS16以前の地図と比べると、ハイブリッドと衛星画像の場合は標高差が分かる画像に変わりました。

3Dマップを確認する

 3Dマップは地図を2本指で上にドラッグする動作で表示できます。シミュレーターの場合は、オプションとシフトのキーを同時に押したままマウスを上に動かすことで、3Dマップを表示できます。

3Dマップの確認
3Dマップの確認

 当然ですが、3Dマップが表示されるのは3Dデータが存在する地図の部分です。都市部以外では3Dマップが表示されないこともあります。

次のページ
選択した地点から周りを見回せる「Look Around」

この記事は参考になりましたか?

  • X ポスト
  • このエントリーをはてなブックマークに追加
iOS16の新機能に触れてみよう連載記事一覧

もっと読む

この記事の著者

WINGSプロジェクト 片渕 彼富(カタフチ カノトミ)

WINGSプロジェクトについて> 有限会社 WINGSプロジェクトが運営する、テクニカル執筆コミュニティ(代表 山田祥寛)。主にWeb開発分野の書籍/記事執筆、翻訳、講演等を幅広く手がける。2018年11月時点での登録メンバは55名で、現在も執筆メンバを募集中。興味のある方は、どしどし応募頂きたい。著書記事多数。 RSS Twitter: @yyamada(公式)、@yyamada/wings(メンバーリスト) Facebook

※プロフィールは、執筆時点、または直近の記事の寄稿時点での内容です

山田 祥寛(ヤマダ ヨシヒロ)

静岡県榛原町生まれ。一橋大学経済学部卒業後、NECにてシステム企画業務に携わるが、2003年4月に念願かなってフリーライターに転身。Microsoft MVP for Visual Studio and Development Technologies。執筆コミュニティ「WINGSプロジェクト」代表。主な著書に「独習シリーズ(Java・C#・Python・PHP・Ruby・JSP&サーブレットなど)」「速習シリーズ(ASP.NET Core・Vue.js・React・TypeScript・ECMAScript、Laravelなど)」「改訂3版JavaScript本格入門」「これからはじめるReact実践入門」「はじめてのAndroidアプリ開発 Kotlin編 」他、著書多数

※プロフィールは、執筆時点、または直近の記事の寄稿時点での内容です

この記事は参考になりましたか?

この記事をシェア

  • X ポスト
  • このエントリーをはてなブックマークに追加
CodeZine(コードジン)
https://codezine.jp/article/detail/17010 2023/01/16 11:00

おすすめ

アクセスランキング

アクセスランキング

イベント

CodeZine編集部では、現場で活躍するデベロッパーをスターにするためのカンファレンス「Developers Summit」や、エンジニアの生きざまをブーストするためのイベント「Developers Boost」など、さまざまなカンファレンスを企画・運営しています。

新規会員登録無料のご案内

  • ・全ての過去記事が閲覧できます
  • ・会員限定メルマガを受信できます

メールバックナンバー

アクセスランキング

アクセスランキング