Condividi tramite


Usare il modulo Indoor Maps di Mappe di Azure con stili personalizzati (anteprima)

Nota

Ritiro di Creator di Mappe di Azure

Il servizio per la creazione di piante dell'interno Creator di Mappe di Azure è ora deprecato e verrà ritirato il 30/09/25. Per altre informazioni, vedere Annuncio di fine vita di Creator di Mappe di Azure.

L'SDK Web di Mappe di Azure include un modulo Indoor Maps che consente di eseguire il rendering di mappe interne create nei servizi Creator di Mappe di Azure.

Quando si crea una mappa interna usando Creator di Mappe di Azure, vengono applicati stili predefiniti. Ora Creator di Mappe di Azure supporta anche la personalizzazione degli stili dei diversi elementi delle mappe interne usando l'API Rest Style o l'editor di stili visivi.

Prerequisiti

La configurazione della mappa alias (o mapConfigurationId) è necessaria per eseguire il rendering di mappe interne con stili personalizzati tramite il modulo Indoor Maps di Mappe di Azure.

Incorporare il modulo Piante di interni

È possibile installare e incorporare il modulo Interni di Mappe di Azure in una delle due modalità riportate di seguito.

Per usare la versione Rete di distribuzione dei contenuti di Microsoft Azure ospitata a livello globale del modulo Indoor Maps di Azure, vedere i riferimenti script e stylesheet seguenti nell'elemento <head> del file HTML:

<link rel="stylesheet" href="https://atlas.microsoft.com/sdk/javascript/indoor/0.2/atlas-indoor.min.css" type="text/css"/>
<script src="https://atlas.microsoft.com/sdk/javascript/indoor/0.2/atlas-indoor.min.js"></script>

In alternativa, è possibile scaricare il modulo Interni di Mappe di Azure. Il modulo Interni di Mappe di Azure contiene una libreria client per accedere ai servizi di Mappe di Azure. I passaggi seguenti illustrano come installare e caricare il modulo Interno nell'applicazione Web.

  1. Installare il pacchetto azure-maps-indoor più recente.

    >npm install azure-maps-indoor
    
  2. Importare il modulo JavaScript Indoor Maps di Azure in un file di origine:

    import * as indoor from "azure-maps-indoor";
    

    È anche necessario incorporare il foglio di stile CSS, affinché i diversi controlli siano visualizzati correttamente. Se si sta usando un gestore JavaScript per unire le dipendenze e creare il pacchetto del codice, vedere la documentazione relativa al gestore su come eseguire l’operazione. Per webpack, viene comunemente eseguita tramite una combinazione di style-loader e css-loader con la documentazione disponibile in style-loader.

    Per iniziare, installare style-loader e css-loader:

    npm install --save-dev style-loader css-loader
    

    All'interno del file di origine, importare atlas-indoor.min.css:

    import "azure-maps-indoor/dist/atlas-indoor.min.css";
    

    Aggiungere quindi i caricatori alla parte relativa alle regole del modulo della configurazione webpack:

    module.exports = {
      module: {
        rules: [
          {
            test: /\.css$/i,
            use: ["style-loader", "css-loader"]
          }
        ]
      }
    };
    

    Per maggiori informazioni, vedere Come usare il pacchetto npm del controllo mappa di Mappe di Azure.

Impostare il dominio e creare un'istanza dell'oggetto Mappa

Impostare il dominio della mappa con un prefisso corrispondente alla posizione della risorsa Creator, US o EU, ad esempio:

atlas.setDomain('us.atlas.microsoft.com');

Per altre informazioni, vedere Ambito geografico del servizio Mappe di Azure.

Successivamente, creare un'istanza dell’oggetto Mappa con l'oggetto di configurazione della mappa impostato sulla proprietà alias o mapConfigurationId della configurazione della mappa, quindi impostare styleAPIVersion su 2023-03-01-preview.

L'oggetto Map verrà usato nel passaggio successivo per creare un'istanza dell'oggetto Indoor Manager. Il codice seguente illustra come creare un'istanza dell’oggetto Mappa con mapConfiguration, styleAPIVersion ed eseguire il mapping del set di domini:

const subscriptionKey = "<Your Azure Maps Subscription Key>";
const region = "<Your Creator resource region: us or eu>"  
const mapConfiguration = "<map configuration alias or ID>"  
atlas.setDomain(`${region}.atlas.microsoft.com`);

const map = new atlas.Map("map-id", {
  //use your facility's location
  center: [-122.13315, 47.63637],
  //or, you can use bounds: [# west, # south, # east, # north] and replace # with your Map bounds
  authOptions: { 
      authType: 'subscriptionKey',
      subscriptionKey: subscriptionKey
  },
  zoom: 19,

  mapConfiguration: mapConfiguration,
  styleAPIVersion: '2023-03-01-preview'
});

Creare un'istanza di Indoor Manager

Per caricare lo stile delle mappe interne delle tessere, è necessario creare un'istanza di Indoor Manager. Creare un'istanza di Indoor Manager specificando l'oggetto Mappa. Il codice dovrebbe essere simile al seguente frammento di codice JavaScript:

const indoorManager = new atlas.indoor.IndoorManager(map, {
});

Controllo di selezione del livello di interni

Il controllo di selezione del livello di interni consente di modificare il livello della mappa di cui è stato eseguito il rendering. Facoltativamente, è possibile inizializzare il controllo di selezione del livello di interni tramite Indoor Manager. Di seguito è riportato il codice per inizializzare il controllo di selezione del livello:

const levelControl = new atlas.control.LevelControl({ position: "top-right" });
indoorManager.setOptions({ levelControl });

Eventi interni

Il modulo Interni di Mappe di Azure supporta gli eventi dell'oggetto Map. I listener degli eventi dell'oggetto Map vengono richiamati quando viene modificato un livello o una struttura. Se si vuole eseguire il codice dopo la modifica di un livello o una struttura, inserire il codice all'interno del listener di eventi. Il codice riportato di seguito mostra come è possibile aggiungere listener di eventi all'oggetto Map.

map.events.add("levelchanged", indoorManager, (eventData) => {

  //code that you want to run after a level has been changed
  console.log("The level has changed: ", eventData);
});

map.events.add("facilitychanged", indoorManager, (eventData) => {

  //code that you want to run after a facility has been changed
  console.log("The facility has changed: ", eventData);
});

La variabile eventData contiene le informazioni sul livello o sulla struttura che ha richiamato rispettivamente l'evento levelchanged o facilitychanged. Quando un livello cambia, l'oggetto eventData contiene facilityId, il nuovo levelNumber e altri metadati. Quando una struttura cambia, l'oggetto eventData contiene il nuovo facilityId, il nuovo levelNumber e altri metadati.

Esempio: stili personalizzati: utilizzare la configurazione della mappa in WebSDK (anteprima)

Quando si crea una mappa interna usando Creator di Mappe di Azure, vengono applicati stili predefiniti. Creator di Mappe di Azure ora supporta anche la personalizzazione degli stili interni. Per maggiori informazioni, vedere Creare stili personalizzati per le mappe interne. Creator offre anche un editor di stili visivi.

  1. Seguire l'articolo Creare stili personalizzati per mappe interne per la creazione di stili personalizzati. Prendere nota dell'alias di configurazione della mappa dopo aver salvato le modifiche.

  2. Usare l'opzione Rete per la distribuzione di contenuti di Azure per installare il modulo Interni di Mappe di Azure.

  3. Creare un nuovo file HTML

  4. Nell'intestazione HTML, fare riferimento al modulo JavaScript Indoor Maps di Azure e al foglio di stile.

  5. Impostare il dominio della mappa con un prefisso corrispondente a una posizione della risorsa Creator: atlas.setDomain('us.atlas.microsoft.com'); se la risorsa Creator è stata creata nella regione degli Stati Uniti o atlas.setDomain('eu.atlas.microsoft.com'); se la risorsa Creator è stata creata nella regione dell’EU.

  6. Inizializzare un oggetto Map. L'oggetto Map supporta le opzioni seguenti:

    • Subscription key è la chiave di sottoscrizione di Mappe di Azure.
    • center definisce una latitudine e una longitudine per la posizione del centro della pianta di interni. Fornire un valore per center se non si vuole fornire un valore per bounds. Il formato deve essere visualizzato come center: [-122.13315, 47.63637].
    • bounds è la forma rettangolare più piccola che racchiude i dati della mappa del set di tessere. Impostare un valore per bounds se non si vuole impostare un valore per center. È possibile trovare i limiti della mappa chiamando l'API dell'elenco di set di tessere. L'API dell'elenco di set di tessere restituisce bbox, che è possibile analizzare e assegnare a bounds. Il formato dovrebbe essere visualizzato come bounds: [# west, # south, # east, # north].
    • mapConfiguration l'ID o l'alias della configurazione della mappa che definisce gli stili personalizzati che si desidera mostrare sulla mappa, usare l'ID di configurazione della mappa o l'alias dal passaggio 1.
    • style consente di impostare lo stile iniziale dalla configurazione della mappa mostrata. Se non impostato, viene usata la configurazione predefinita della configurazione della mappa corrispondente allo stile.
    • zoom consente di specificare i livelli di zoom minimo e massimo per la mappa.
    • styleAPIVersion: pass '2023-03-01-preview' (obbligatorio quando gli Stili Personalizzati sono in anteprima pubblica)
  7. Successivamente, creare il modulo Manager interno con il controllo Selezione livello interno di cui si è creata un’istanza, come parte delle opzioni di Manager interno.

  8. Aggiungere i listener di eventi dell'oggetto Map.

Suggerimento

Viene fatto riferimento alla configurazione della mappa tramite mapConfigurationId o alias. Ogni volta che si modifica o cambia una configurazione della mappa, il relativo ID cambia mentre l’alias rimane invariato. È consigliabile fare riferimento alla configurazione della mappa nelle applicazioni tramite il relativo alias. Per maggiori informazioni, vedere Configurazione della mappa nell'articolo dei concetti.

Il file dovrebbe ora essere simile al codice HTML seguente:

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="utf-8" />
    <meta name="viewport" content="width=device-width, user-scalable=no" />
    <title>Indoor Maps App</title>
    
    <link rel="stylesheet" href="https://atlas.microsoft.com/sdk/javascript/mapcontrol/3/atlas.min.css" type="text/css" />
    <link rel="stylesheet" href="https://atlas.microsoft.com/sdk/javascript/indoor/0.2/atlas-indoor.min.css" type="text/css"/>

    <script src="https://atlas.microsoft.com/sdk/javascript/mapcontrol/3/atlas.min.js"></script>
    <script src="https://atlas.microsoft.com/sdk/javascript/indoor/0.2/atlas-indoor.min.js"></script>
      
    <style>
      html,
      body {
        width: 100%;
        height: 100%;
        padding: 0;
        margin: 0;
      }

      #map-id {
        width: 100%;
        height: 100%;
      }
    </style>
  </head>

  <body>
    <div id="map-id"></div>
    <script>
      const subscriptionKey = "<Your Azure Maps Subscription Key>";
      const mapConfig = "<Your map configuration id or alias>";
      const region = "<Your Creator resource region: us or eu>"    
      atlas.setDomain(`${region}.atlas.microsoft.com`);

      const map = new atlas.Map("map-id", {
        //use your facility's location
        center: [-122.13315, 47.63637],
        //or, you can use bounds: [# west, # south, # east, # north] and replace # with your Map bounds
        authOptions: { 
            authType: 'subscriptionKey',
            subscriptionKey: subscriptionKey
        },
        zoom: 19,

        mapConfiguration: mapConfig,
        styleAPIVersion: '2023-03-01-preview'
      });

      const levelControl = new atlas.control.LevelControl({
        position: "top-right",
      });

      const indoorManager = new atlas.indoor.IndoorManager(map, {
        levelControl: levelControl, //level picker
      });

      map.events.add("levelchanged", indoorManager, (eventData) => {
        //put code that runs after a level has been changed
        console.log("The level has changed:", eventData);
      });

      map.events.add("facilitychanged", indoorManager, (eventData) => {
        //put code that runs after a facility has been changed
        console.log("The facility has changed:", eventData);
      });
    </script>
  </body>
</html>

Per visualizzare la pianta di interni, caricarla in un Web browser. Dovrebbe avere un aspetto simile all'immagine seguente. Se si seleziona la caratteristica vano scale, il selettore di livello compare nell'angolo superiore destro.

immagine della pianta di interni

Per una demo live di una mappa interna con il codice sorgente disponibile, vedere Indoor Maps Creator in [campioni di Mappe di Azure].

Passaggi successivi

Per informazioni sulle API correlate al modulo Interni di Mappe di Azure, vedere:

Altre informazioni su come aggiungere altri dati alla mappa: