ストリートビュー

コレクションでコンテンツを整理 必要に応じて、コンテンツの保存と分類を行います。
プラットフォームを選択: Android iOS JavaScript

Google マップのストリートビューでは、ストリート レベルの 360 度画像を使って世界中の場所を探索できます。世界中のランドマークを探索したり、自然の景観を表示したり、旅行に出かけたり、ビジネス以外の場所を紹介したりできます。

概要

Google ストリートビューは、対象地域全体について、指定された道路からの 360 度のパノラマビューを提供します。この SDK で利用できるカバレッジは、iOS 向け Google マップ アプリhttps://maps.google.com/ の場合と同じです。ストリートビューの詳細やインタラクティブ エリアでサポートされるエリアについては、ストリートビューについてをご覧ください。

Maps SDK for iOS には、Google マップのストリートビューで使用される画像を取得および操作するためのストリートビュー サービスが用意されています。ストリートビュー画像はパノラマとして返され、ストリートビュー ビューア(GMSPanoramaView タイプのオブジェクト)から表示されます。

ストリートビュー パノラマ

各ストリートビューのパノラマ画像は、単一地点からの 360 度ビューを提供する 1 枚の画像または画像のセットです。画像は正距円筒図法(Plate Carrée)に準拠し、360 度の水平ビュー(周囲全体)と 180 度の垂直ビュー(真上から真下)が含まれています。結果として得られる 360 度のパノラマは、球体上の 2 次元表面に画像をラップした球体への投影を定義します。

ストリートビュー パノラマは、GMSPanoramaView オブジェクトで表示できます。このオブジェクトでは、パノラマが球体としてレンダリングされ、その中央にカメラが配置されます。カメラの向きや、ビューアをカスタマイズするプロパティは、プログラムで制御できます。

ストリートビュー データへのアクセス

ストリートビューのパノラマ画像は、2 つのメタデータのどちらかで特定することができます。

panoramaID
ストリートビュー パノラマの一意の ID。この panoramaID は今後変更される可能性があるため、長期的には、またはハードコードされた参照としては適していません。panoramaID は、さまざまなストリートビュー画像にプログラムでアクセスできるようにする場合に最適です。
coordinate
この画像の正確な位置。CLLocationCoordinate2D として表されます。パノラマ 場所を永続的に保存するには coordinate を使用します。または、地図上でのユーザー アクションをストリートビュー画像に変換します。

panoramaIDcoordinate はどちらも GMSPanorama オブジェクトのプロパティとして保存されます。coordinate または panoramaID を使用して、GMSPanoramaService から GMSPanorama をリクエストできます。結果として得られるオブジェクトには、メタデータと、付近のパノラマへのリンクの配列の両方が含まれます。

パノラマの位置を設定する

ストリートビュー パノラマの位置は、座標に基づいて設定できます。

  • moveNearCoordinate メソッドは、座標付近のパノラマ画像をリクエストします。

  • moveNearCoordinate:radius メソッドも同様ですが、座標周辺の検索半径をメートル単位で指定できます。

  • moveNearCoordinate:source メソッドではソースを指定できます。source は、ストリートビューの検索を屋外のパノラマのみに制限する場合に役立ちます。デフォルトでは、場所のパノラマは内側か外側のどちらかです。なお、指定された場所の屋外のパノラマが存在しない場合があります。

  • moveNearCoordinate:radius:source メソッドを使用すると、半径とソースの両方を指定できます。

ストリートビュー画像の表示

ストリートビュービューアを追加する

ビューアを追加するための基本的なステップは次のとおりです。

  1. (1 回)スタートガイドの手順に沿って SDK を入手し、キーを入手して、必要なフレームワークを追加します。
  2. ViewController を作成または更新します。パノラマ画像を表示する際は、必ず loadView メソッド内でパノラマを作成してください。
  3. GMSPanoramaView initWithFrame: メソッドを使用して、GMSPanoramaView クラスを作成し、インスタンス化します。これをビュー コントローラの唯一のビューとして使用する場合、CGRectZero を地図のフレームとして使用すると、地図のサイズが自動的に変更されます。
  4. ビュー コントローラのビューとして GMSPanoramaView オブジェクトを設定します(例: self.view = panoView;)。
  5. ストリートビュー画像の場所を設定するには、moveNearCoordinate: などのメソッドを使用します。

次の例では、アプリにストリートビュー ビューアを追加しています。

Swift

import GoogleMaps

class StreetView: UIViewController {

  override func loadView() {
    let panoView = GMSPanoramaView(frame: .zero)
    self.view = panoView

    panoView.moveNearCoordinate(CLLocationCoordinate2D(latitude: -33.732, longitude: 150.312))
  }
}
      

Objective-C

#import "StreetView.h"
@import GoogleMaps;

@interface StreetView ()

@end

@implementation StreetView

- (void)loadView {
  GMSPanoramaView *panoView = [[GMSPanoramaView alloc] initWithFrame:CGRectZero];
  self.view = panoView;

  [panoView moveNearCoordinate:CLLocationCoordinate2DMake(-33.732, 150.312)];
}

@end
      

ビューアのカスタマイズ

利用できる操作を制限して、ビューアをカスタマイズできます。デフォルトでは、パン、ズーム、隣接するパノラマへの移動はすべて有効になっています。個々の操作は GMSPanoramaView のプロパティで制御します。これらのプロパティは、ユーザー制御のジェスチャーを有効または無効にします。操作を無効にしても、プログラムによる変更は可能です。

orientationGestures
ユーザーがタップやドラッグでカメラの向きを変更できるかどうか。カメラの向きの変更を無効にするには、NO に設定します。
zoomGestures
ユーザーがピンチ操作でズームできるかどうか。ズームを無効にするには NO に設定します。
navigationGestures
表示するパノラマをユーザーが変更できるかどうか。ユーザーは、ナビゲーション リンクをシングルタップするか、ビューをダブルタップしてパノラマを変更できます。[NO] に設定すると、ナビゲーションの変更が無効になります。

setAllGesturesEnabled: メソッドを使用して、すべてのジェスチャーを一度に有効または無効にできます。

Swift

panoView.setAllGesturesEnabled(false)
      

Objective-C

[panoView setAllGesturesEnabled:NO];
      

URL スキームを使用したストリートビューのリリース

Google ストリートビューの画像は、iOS 向け Google マップ アプリ内から表示できます。comgooglemaps URL スキームを使用してストリートビューの Google Maps for iOS アプリケーションを起動するには、mapmode パラメータを streetview に設定します。ストリートビューを起動する URL の例を次に示します。詳細については、URL スキームのドキュメントをご覧ください。

comgooglemaps://?center=46.414382,10.013988&mapmode=streetview

ストリートビューの位置情報と視点(POV)

GMSPanoramaCamera を使用すると、方向、ピッチ、ズームを組み合わせてストリートビュー カメラの視点を設定できます。

次のスニペットは、カメラの方向を南向きにし、わずかに下を向けています。

Swift

panoView.camera = GMSPanoramaCamera(heading: 180, pitch: -10, zoom: 1)
      

Objective-C

panoView.camera = [GMSPanoramaCamera cameraWithHeading:180
                                                 pitch:-10
                                                  zoom:1];
      

向き

ストリートビューでの位置情報は、どの画像にカメラを向けるかを定義しますが、その画像でのカメラの向きは定義しません。 向きを示すため、GMSOrientation オブジェクトでは 2 つのプロパティを定義します。

  • heading は、カメラ中心の回転角度を、真北からの相対角度で定義します。方位は時計回りで測定します。真北が 0、東が 90、南が 180、西が 270 です。
  • pitch(デフォルトは 0)は、カメラの初期デフォルト ピッチからの「上」または「下」向きの角度を定義します。通常は水平です(常に水平とは限りません。(たとえば、山で撮影された画像は、水平ではないデフォルトのピッチで表示されます)。ピッチ角度は、見上げる方向を正の値(デフォルトのピッチと直行する真上方向が +90 度)で、下を向く方向を負の値(デフォルトのピッチと直交する真下の方向が -90 度)として計測します。

Zoom

ストリートビューでは、ズームレベルを使用して画像の詳細レベルを変更できます。 ズームレベルはプログラムで設定できます。また、ユーザーはズームインしてピンチ操作でビューアのレベルを変更できます。

カメラの移動

GMSPanoramaView を作成し、設定済みのカメラまたはデフォルトのカメラがある場合、次のいずれかの方法でカメラを変更できます。カメラを変更する場合は、取得したカメラの移動をアニメーション化できます。アニメーションは、現在のカメラ属性と新しいカメラ属性の間に補間されます。

GMSPanoramaCamera オブジェクトを変更し、GMSPanoramaViewcamera プロパティで設定できます。これにより、アニメーションなしで、新しい視点にカメラがスナップされます。GMSCameraPosition は、向きとズームの任意の組み合わせを構成するために作成できます。

Swift

panoView.camera = GMSPanoramaCamera(heading: 180, pitch: -10, zoom: 1)
      

Objective-C

panoView.camera = [GMSPanoramaCamera cameraWithHeading:180
                                                 pitch:-10
                                                  zoom:1];
      

遷移をアニメーション化するには、GMSPanoramaViewanimateToCamera:animationDuration: メソッドを呼び出します。さらに、Core Animation を使ってカメラをコントロールすることもできます。これは、GMSPanoramaView GMSPanoramaLayer のカスタム CALayer で使用可能になります。

ストリートビュー内のマーカー

GMSPanoramaView オブジェクトでは、地図上のマーカーを表示できます。対応するプロパティを設定することで、同じ GMSMarker オブジェクトを GMSMapView オブジェクトまたは GMSPanoramaView オブジェクトで使用できます。

Swift

// Create a marker at the Eiffel Tower
let position = CLLocationCoordinate2D(latitude: 48.858, longitude: 2.294)
let marker = GMSMarker(position: position)

// Add the marker to a GMSPanoramaView object named panoView
marker.panoramaView = panoView

// Add the marker to a GMSMapView object named mapView
marker.map = mapView
      

Objective-C

// Create a marker at the Eiffel Tower
CLLocationCoordinate2D position = CLLocationCoordinate2DMake(48.858,2.294);
GMSMarker *marker = [GMSMarker markerWithPosition:position];

// Add the marker to a GMSPanoramaView object named panoView
marker.panoramaView = panoView;

// Add the marker to a GMSMapView object named mapView
marker.map = mapView;
      

マーカーのサイズは、マーカーの位置と GMSCameraView の位置との間の距離の関数に応じて拡大縮小されます。この距離が大きすぎると、マーカーが小さくなりすぎて表示されなくなります。

panoramaView プロパティを nil に設定して、GMSPanoramaView から削除します。

Swift

marker.panoramaView = nil
      

Objective-C

marker.panoramaView = nil;
      

イベント

ストリートビュー パノラマで発生したイベント(ユーザーがパノラマをタップしたときなど)をリッスンできます。イベントをリッスンするには、GMSPanoramaViewDelegate プロトコルを実装する必要があります。全体的なイベントガイドGMSPanoramaViewDelegate のメソッドのリストをご覧ください。