Google Street View fornisce viste panoramiche a 360 gradi da strade designate in tutta la sua area di copertura.
Questo video mostra come utilizzare il servizio Street View per offrire ai tuoi utenti un'esperienza reale di un indirizzo sulla mappa, fornendo loro un contesto significativo sulla destinazione o su qualsiasi luogo che li interessa.
La copertura disponibile tramite la versione 2 dell'API Android di Google Maps è la stessa dell'app Google Maps sul tuo dispositivo Android. Per scoprire di più su Street View e visualizzare le aree supportate su una mappa interattiva, visita la pagina Informazioni su Street View.
La classe StreetViewPanorama
modella il panorama di Street View nella tua applicazione. Nell'interfaccia utente, un panorama è rappresentato da un oggetto StreetViewPanoramaFragment
o StreetViewPanoramaView
.
Esempi di codice
Il repository ApiDemos su GitHub include esempi che mostrano l'utilizzo di Street View.
Esempi di Kotlin:
- StreetViewPanoramaBasicDemoActivity: le nozioni di base sull'utilizzo di Street View
- StreetViewPanoramaEventsDemoActivity: ascolto degli eventi
- StreetViewPanoramaNavigationDemoActivity: controlla programmaticamente i panorami di Street View
- StreetViewPanoramaOptionsDemoActivity: modifica dell'interfaccia utente e delle opzioni dei gesti
- StreetViewPanoramaViewDemoActivity: utilizzo di
StreetViewPanoramaView
(anziché di un frammento) - SplitStreetViewPanoramaAndMapDemoActivity: utilizzo di un'attività che mostra una visualizzazione di Street View e una mappa
Esempi Java:
- StreetViewPanoramaBasicDemoActivity: le nozioni di base sull'utilizzo di Street View
- StreetViewPanoramaEventsDemoActivity: ascolto degli eventi
- StreetViewPanoramaNavigationDemoActivity: controlla programmaticamente i panorami di Street View
- StreetViewPanoramaOptionsDemoActivity: modifica dell'interfaccia utente e delle opzioni dei gesti
- StreetViewPanoramaViewDemoActivity: utilizzo di
StreetViewPanoramaView
(anziché di un frammento) - SplitStreetViewPanoramaAndMapDemoActivity: crea un'attività che mostra una vista di Street View e una mappa
Panoramica di Street View in Maps SDK for Android
Maps SDK for Android fornisce un servizio Street View per ottenere e manipolare le immagini utilizzate in Google Street View. Le immagini vengono restituite come panorami.
Ogni panorama di Street View è un'immagine o un insieme di immagini che fornisce una vista completa a 360 gradi da una singola posizione. Le immagini devono essere conformi alla proiezione equirettangolare (piastra quadrata), che contiene una visuale orizzontale a 360 gradi (un'immagine completa) e una visuale verticale a 180 gradi (dall'alto verso il basso). Il panorama a 360 gradi risultante definisce una proiezione su una sfera con l'immagine avvolta sulla superficie bidimensionale della sfera.
StreetViewPanorama
fornisce un visualizzatore che mostra il panorama come una sfera con una fotocamera al centro. Puoi utilizzare il pulsante StreetViewPanoramaCamera
per controllare lo zoom e l'orientamento (inclinazione e orientamento) della videocamera.
Inizia
Configura un progetto
Segui la guida introduttiva per configurare un progetto Maps SDK for Android.
Verificare la disponibilità di un panorama di Street View prima di aggiungerlo
La libreria client dell'SDK Google Play Services include alcuni esempi di Street View che puoi importare nel tuo progetto e utilizzare come base per lo sviluppo. Consulta l'introduzione per le linee guida sull'importazione dei sample.
La libreria di utilità Maps SDK for Android è una libreria open source di classi utili per una serie di applicazioni. Nel repository GitHub è inclusa l'utilità per i metadati di Street View.
Questa utility controlla se una località è supportata da
Street View. Per evitare errori durante l'aggiunta di un panorama di Street View a un'app per Android, chiama questa utilità per i metadati e aggiungi un panorama di Street View solo se la risposta è OK
.
Utilizzare l'API
Segui le istruzioni riportate di seguito per aggiungere un panorama di Street View a un frammento Android. Questo è il modo più semplice per aggiungere Street View alla tua applicazione. Poi, scopri di più su frammenti, visualizzazioni e personalizzazione del panorama.
Aggiungere un panorama di Street View
Per aggiungere un panorama di Street View come questo:
In sintesi:
- Aggiungi un oggetto Fragment all'attività
che gestirà il panorama di Street View. Il modo più semplice per farlo è aggiungere un elemento
<fragment>
al file di layout perActivity
. - Implementa l'interfaccia
OnStreetViewPanoramaReadyCallback
e utilizza il metodo callbackonStreetViewPanoramaReady(StreetViewPanorama)
per ottenere un handle per l'oggettoStreetViewPanorama
. - Chiama
getStreetViewPanoramaAsync()
sul frammento per registrare il callback.
Di seguito sono riportati ulteriori dettagli su ogni passaggio.
Aggiungere un frammento
Aggiungi un elemento <fragment>
al file di layout dell'attività per definire un oggetto
Fragment. In questo elemento, imposta l'attributo class
su com.google.android.gms.maps.StreetViewPanoramaFragment
(o SupportStreetViewPanoramaFragment
).
Ecco un esempio di frammento in un file di layout:
<fragment android:name="com.google.android.gms.maps.StreetViewPanoramaFragment" android:id="@+id/streetviewpanorama" android:layout_width="match_parent" android:layout_height="match_parent"/>
Aggiungere il codice di Street View
Per utilizzare il panorama di Street View all'interno della tua app, devi implementare l'interfaccia OnStreetViewPanoramaReadyCallback
e impostare un'istanza del callback su un oggetto StreetViewPanoramaFragment
o StreetViewPanoramaView
. Questo tutorial utilizza un StreetViewPanoramaFragment
, perché è il modo più semplice per aggiungere Street View alla tua app. Il primo passaggio consiste nell'implementare l'interfaccia di callback:
Kotlin
class StreetViewActivity : AppCompatActivity(), OnStreetViewPanoramaReadyCallback { // ... }
Java
class StreetViewActivity extends AppCompatActivity implements OnStreetViewPanoramaReadyCallback { // ... }
Nel metodo onCreate()
di Activity
, imposta il file di layout come visualizzazione dei contenuti. Ad esempio, se il file di layout
ha il nome main.xml
, utilizza questo codice:
Kotlin
override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContentView(R.layout.activity_street_view) val streetViewPanoramaFragment = supportFragmentManager .findFragmentById(R.id.street_view_panorama) as SupportStreetViewPanoramaFragment streetViewPanoramaFragment.getStreetViewPanoramaAsync(this) }
Java
@Override protected void onCreate(@Nullable Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_street_view); SupportStreetViewPanoramaFragment streetViewPanoramaFragment = (SupportStreetViewPanoramaFragment) getSupportFragmentManager() .findFragmentById(R.id.street_view_panorama); streetViewPanoramaFragment.getStreetViewPanoramaAsync(this); }
Ottieni un handle del frammento chiamando
FragmentManager.findFragmentById()
,
passandogli l'ID risorsa dell'elemento <fragment>
.
Tieni presente che l'ID risorsa R.id.streetviewpanorama
viene aggiunto automaticamente al progetto Android quando viene compilato il file di layout.
Quindi utilizza getStreetViewPanoramaAsync()
per impostare il callback sul frammento.
Kotlin
val streetViewPanoramaFragment = supportFragmentManager .findFragmentById(R.id.street_view_panorama) as SupportStreetViewPanoramaFragment streetViewPanoramaFragment.getStreetViewPanoramaAsync(this)
Java
SupportStreetViewPanoramaFragment streetViewPanoramaFragment = (SupportStreetViewPanoramaFragment) getSupportFragmentManager() .findFragmentById(R.id.street_view_panorama); streetViewPanoramaFragment.getStreetViewPanoramaAsync(this);
Utilizza il metodo di callback
onStreetViewPanoramaReady(StreetViewPanorama)
per recuperare un'istanza non null di
StreetViewPanorama
, pronta per essere utilizzata.
Kotlin
override fun onStreetViewPanoramaReady(streetViewPanorama: StreetViewPanorama) { val sanFrancisco = LatLng(37.754130, -122.447129) streetViewPanorama.setPosition(sanFrancisco) }
Java
@Override public void onStreetViewPanoramaReady(StreetViewPanorama streetViewPanorama) { LatLng sanFrancisco = new LatLng(37.754130, -122.447129); streetViewPanorama.setPosition(sanFrancisco); }
Scopri di più sulla configurazione dello stato iniziale
A differenza di una mappa, non è possibile configurare lo stato iniziale del panorama di Street View tramite XML. Tuttavia, puoi configurare il panorama in modo programmatico passando un oggetto StreetViewPanoramaOptions
contenente le opzioni specificate.
- Se utilizzi un
StreetViewPanoramaFragment
, utilizza il metodo di fabbrica staticoStreetViewPanoramaFragment.newInstance(StreetViewPanoramaOptions options)
per creare il frammento e passare le opzioni configurate personalizzate. - Se utilizzi un
StreetViewPanoramaView
, utilizza il costruttoreStreetViewPanoramaView(Context, StreetViewPanoramaOptions)
e passa le opzioni configurate personalizzate.
Kotlin
val sanFrancisco = LatLng(37.754130, -122.447129) val view = StreetViewPanoramaView( this, StreetViewPanoramaOptions().position(sanFrancisco) )
Java
LatLng sanFrancisco = new LatLng(37.754130, -122.447129); StreetViewPanoramaView view = new StreetViewPanoramaView(this, new StreetViewPanoramaOptions().position(sanFrancisco));
Scopri di più su StreetViewPanoramaFragment
StreetViewPanoramaFragment
è una sottoclasse della classe Fragment Android e consente di inserire un panorama di Street View in un frammento Android. Gli oggetti StreetViewPanoramaFragment
fungono da contenitori per il panorama e forniscono l'accesso all'oggetto StreetViewPanorama
.
StreetViewPanoramaView
StreetViewPanoramaView
, una sottoclasse della classe Android
View
, ti consente di inserire un panorama di Street View
in un View
Android. Un View
rappresenta una regione rettangolare dello schermo ed è un componente di base fondamentale per le applicazioni e i widget Android.
Come un StreetViewPanoramaFragment
, StreetViewPanoramaView
funge da contenitore per il panorama, esponendo le funzionalità di base tramite l'oggetto StreetViewPanorama
. Gli utenti di questo tipo di classe devono inoltrare tutti i metodi di ciclo di vita dell'attività (ad esempio onCreate()
, onDestroy()
, onResume()
e onPause())
) ai metodi corrispondenti nella classe StreetViewPanoramaView
.
Personalizzare la funzionalità controllata dall'utente
Per impostazione predefinita, quando l'utente visualizza il panorama di Street View, sono disponibili le seguenti funzionalità: panoramica, zoom e spostamento ai panorami adiacenti. Puoi attivare e disattivare i gesti controllati dall'utente tramite i metodi su StreetViewPanorama
. Le modifiche programmatiche sono comunque possibili quando il gesto è disattivato.
Impostare la posizione del panorama
Per impostare la posizione del panorama di Street View, chiama
StreetViewPanorama.setPosition()
, passando un LatLng
.
Puoi anche passare radius
e source
come parametri facoltativi.
Un raggio è utile se vuoi ampliare o restringere l'area in cui Street View cercherà una panoramica corrispondente. Un raggio
di 0 significa che il panorama deve essere collegato esattamente al LatLng
specificato.
Il raggio predefinito è 50 metri. Se nell'area di corrispondenza è presente più di un panorama, l'API restituirà la migliore corrispondenza.
Un'origine è utile se vuoi limitare Street View a cercare solo panorami all'aperto. Per impostazione predefinita, i panorami di Street View possono trovarsi all'interno di luoghi come musei, edifici pubblici, bar e attività commerciali. Tieni presente che i panorami esterni potrebbero non esistere per la località specificata.
Kotlin
val sanFrancisco = LatLng(37.754130, -122.447129) // Set position with LatLng only. streetViewPanorama.setPosition(sanFrancisco) // Set position with LatLng and radius. streetViewPanorama.setPosition(sanFrancisco, 20) // Set position with LatLng and source. streetViewPanorama.setPosition(sanFrancisco, StreetViewSource.OUTDOOR) // Set position with LaLng, radius and source. streetViewPanorama.setPosition(sanFrancisco, 20, StreetViewSource.OUTDOOR)
Java
LatLng sanFrancisco = new LatLng(37.754130, -122.447129); // Set position with LatLng only. streetViewPanorama.setPosition(sanFrancisco); // Set position with LatLng and radius. streetViewPanorama.setPosition(sanFrancisco, 20); // Set position with LatLng and source. streetViewPanorama.setPosition(sanFrancisco, StreetViewSource.OUTDOOR); // Set position with LaLng, radius and source. streetViewPanorama.setPosition(sanFrancisco, 20, StreetViewSource.OUTDOOR);
In alternativa, puoi impostare la posizione in base a un ID panorama passando un valore panoId
a StreetViewPanorama.setPosition()
.
Per recuperare l'ID panorama per le panoramiche adiacenti, utilizza prima
getLocation()
per recuperare un StreetViewPanoramaLocation
.
Questo oggetto contiene l'ID del panorama corrente e un array di oggetti StreetViewPanoramaLink
, ciascuno dei quali contiene l'ID di un panorama collegato a quello corrente.
Kotlin
streetViewPanorama.location.links.firstOrNull()?.let { link: StreetViewPanoramaLink -> streetViewPanorama.setPosition(link.panoId) }
Java
StreetViewPanoramaLocation location = streetViewPanorama.getLocation(); if (location != null && location.links != null) { streetViewPanorama.setPosition(location.links[0].panoId); }
Zoom avanti e indietro
Puoi modificare il livello di zoom in modo programmatico impostando
StreetViewPanoramaCamera.zoom
.
Se imposti lo zoom su 1,0, l'immagine verrà ingrandita
di un fattore 2.
Il seguente snippet utilizza StreetViewPanoramaCamera.Builder()
per creare una nuova fotocamera con l'inclinazione e l'orientamento della fotocamera esistente, aumentando al contempo lo zoom del 50%.
Kotlin
val zoomBy = 0.5f val camera = StreetViewPanoramaCamera.Builder() .zoom(streetViewPanorama.panoramaCamera.zoom + zoomBy) .tilt(streetViewPanorama.panoramaCamera.tilt) .bearing(streetViewPanorama.panoramaCamera.bearing) .build()
Java
float zoomBy = 0.5f; StreetViewPanoramaCamera camera = new StreetViewPanoramaCamera.Builder() .zoom(streetViewPanorama.getPanoramaCamera().zoom + zoomBy) .tilt(streetViewPanorama.getPanoramaCamera().tilt) .bearing(streetViewPanorama.getPanoramaCamera().bearing) .build();
Impostare l'orientamento della fotocamera (punto di vista)
Puoi determinare l'orientamento della videocamera di Street View impostando la direzione e l'inclinazione su StreetViewPanoramaCamera
.
- bearing
- La direzione in cui è rivolta la videocamera, specificata in gradi in senso orario dal nord geografico, intorno al luogo in cui si trova la videocamera. Il nord vero è 0, est è 90, sud è 180 e ovest è 270.
- inclinazione
- L'asse Y si inclina verso l'alto o verso il basso. L'intervallo va da -90 a 0 a 90, con -90 rivolto verso il basso, 0 centrato sull'orizzonte e 90 rivolto verso l'alto. La varianza viene misurata dal pitch predefinito iniziale della videocamera, che spesso (ma non sempre) è orizzontale piatto. Ad esempio, un'immagine scattata su una collina avrà probabilmente un'inclinazione predefinita non orizzontale.
Il seguente snippet utilizza StreetViewPanoramaCamera.Builder()
per creare una nuova fotocamera con lo zoom e l'inclinazione della fotocamera esistente, modificando al contempo l'orientamento di 30 gradi a sinistra.
Kotlin
val panBy = 30f val camera = StreetViewPanoramaCamera.Builder() .zoom(streetViewPanorama.panoramaCamera.zoom) .tilt(streetViewPanorama.panoramaCamera.tilt) .bearing(streetViewPanorama.panoramaCamera.bearing - panBy) .build()
Java
float panBy = 30; StreetViewPanoramaCamera camera = new StreetViewPanoramaCamera.Builder() .zoom(streetViewPanorama.getPanoramaCamera().zoom) .tilt(streetViewPanorama.getPanoramaCamera().tilt) .bearing(streetViewPanorama.getPanoramaCamera().bearing - panBy) .build();
Il seguente snippet inclina la fotocamera verso l'alto di 30 gradi.
Kotlin
var tilt = streetViewPanorama.panoramaCamera.tilt + 30 tilt = if (tilt > 90) 90f else tilt val previous = streetViewPanorama.panoramaCamera val camera = StreetViewPanoramaCamera.Builder(previous) .tilt(tilt) .build()
Java
float tilt = streetViewPanorama.getPanoramaCamera().tilt + 30; tilt = (tilt > 90) ? 90 : tilt; StreetViewPanoramaCamera previous = streetViewPanorama.getPanoramaCamera(); StreetViewPanoramaCamera camera = new StreetViewPanoramaCamera.Builder(previous) .tilt(tilt) .build();
Animare i movimenti della fotocamera
Per animare i movimenti della fotocamera, chiama
StreetViewPanorama.animateTo()
.
L'animazione esegue l'interpolazione tra gli attributi attuali della fotocamera e quelli della nuova fotocamera. Se vuoi passare direttamente alla videocamera senza animazione,
puoi impostare la durata su 0.
Kotlin
// Keeping the zoom and tilt. Animate bearing by 60 degrees in 1000 milliseconds. val duration: Long = 1000 val camera = StreetViewPanoramaCamera.Builder() .zoom(streetViewPanorama.panoramaCamera.zoom) .tilt(streetViewPanorama.panoramaCamera.tilt) .bearing(streetViewPanorama.panoramaCamera.bearing - 60) .build() streetViewPanorama.animateTo(camera, duration)
Java
// Keeping the zoom and tilt. Animate bearing by 60 degrees in 1000 milliseconds. long duration = 1000; StreetViewPanoramaCamera camera = new StreetViewPanoramaCamera.Builder() .zoom(streetViewPanorama.getPanoramaCamera().zoom) .tilt(streetViewPanorama.getPanoramaCamera().tilt) .bearing(streetViewPanorama.getPanoramaCamera().bearing - 60) .build(); streetViewPanorama.animateTo(camera, duration);
L'immagine seguente mostra il risultato quando l'animazione indicata sopra viene pianificata per essere eseguita ogni 2000 millisecondi utilizzando Handler.postDelayed()
: