Il monitoraggio degli oggetti tiene traccia degli oggetti rilevati in un video di input. Per effettuare una richiesta di monitoraggio oggetti, chiama il metodo annotate
e specifica OBJECT_TRACKING
nel campo features
.
Per le entità e le posizioni spaziali rilevate in un video o in segmenti di video, una richiesta di monitoraggio degli oggetti annota il video con le etichette appropriate per queste entità e posizioni spaziali. Ad esempio, un video di veicoli che attraversano un semaforo potrebbe produrre etichette come "auto", "camion", "bicicletta", "pneumatici", "luci", "finestrino" e così via. Ogni etichetta può includere una serie di riquadri di delimitazione, ognuno riquadro di delimitazione ha un segmento di tempo associato contenente un offset temporale che indica l'offset di durata dall'inizio del video. L'annotazione contiene anche informazioni aggiuntive sull'entità, tra cui un ID entità che puoi utilizzare per trovare ulteriori informazioni sull'entità nell'API Google Knowledge Graph Search.
Monitoraggio degli oggetti e rilevamento delle etichette
Il monitoraggio degli oggetti è diverso dal rilevamento delle etichette. Il rilevamento delle etichette fornisce etichette senza riquadri di delimitazione, mentre il monitoraggio degli oggetti fornisce le etichette dei singoli oggetti presenti in un determinato video insieme al riquadro di delimitazione di ogni istanza dell'oggetto in ogni intervallo di tempo.
Più istanze dello stesso tipo di oggetto vengono assegnate a istanze diverse
del messaggio ObjectTrackingAnnotation
, in cui tutte le occorrenze di una determinata
traccia dell'oggetto vengono mantenute nella propria istanza di ObjectTrackingAnnotation
. Ad esempio, se in un video compaiono un'auto rossa e un'auto blu per 5 secondi, la richiesta di monitoraggio deve restituire due istanze di ObjectTrackingAnnotation
. La prima istanza conterrà
le posizioni di una delle due auto, ad esempio quella rossa, mentre la
seconda conterrà le posizioni dell'altra auto.
Richiedere il monitoraggio degli oggetti per un video su Cloud Storage
Gli esempi riportati di seguito mostrano il rilevamento degli oggetti in un file che si trova in Cloud Storage.
REST
Invia la richiesta di elaborazione
Di seguito viene mostrato come inviare una richiesta POST
al metodo
annotate
.
L'esempio utilizza il token di accesso per un account di servizio configurato per il progetto utilizzando Google Cloud CLI. Per istruzioni sull'installazione di Google Cloud CLI, sulla configurazione di un progetto con un service account e sull'ottenimento di un token di accesso, consulta la guida rapida di Video Intelligence.
Prima di utilizzare i dati della richiesta, apporta le seguenti sostituzioni:
- INPUT_URI: STORAGE_URI
Ad esempio:
"inputUri": "gs://cloud-videointelligence-demo/assistant.mp4",
- PROJECT_NUMBER: L'identificatore numerico del tuo progetto Google Cloud
Metodo HTTP e URL:
POST https://videointelligence.googleapis.com/v1/videos:annotate
Corpo JSON della richiesta:
{ "inputUri": "STORAGE_URI", "features": ["OBJECT_TRACKING"] }
Per inviare la richiesta, espandi una di queste opzioni:
Dovresti ricevere una risposta JSON simile alla seguente:
{ "name": "projects/PROJECT_NUMBER/locations/LOCATION_ID/operations/OPERATION_ID" }
Se la richiesta riesce, l'API Video Intelligence restituisce il name
dell'operazione. Quanto sopra mostra un esempio di risposta, in cui PROJECT_NUMBER
è il numero del tuo progetto e OPERATION_ID
è l'ID dell'operazione
a lunga esecuzione creata per la richiesta.
Visualizzare i risultati
Per ottenere i risultati della richiesta, invia un GET
utilizzando il nome dell'operazione restituito dalla chiamata a videos:annotate
, come mostrato nell'esempio seguente.
Prima di utilizzare i dati della richiesta, apporta le seguenti sostituzioni:
- OPERATION_NAME: il nome dell'operazione restituito dall'API Video Intelligence. Il nome dell'operazione ha il formato
projects/PROJECT_NUMBER/locations/LOCATION_ID/operations/OPERATION_ID
- PROJECT_NUMBER: L'identificatore numerico del tuo progetto Google Cloud
Metodo HTTP e URL:
GET https://videointelligence.googleapis.com/v1/OPERATION_NAME
Per inviare la richiesta, espandi una di queste opzioni:
Dovresti ricevere una risposta JSON simile alla seguente:
Scaricare i risultati delle annotazioni
Copia l'annotazione dalla sorgente al bucket di destinazione: (vedi Copiare file e oggetti)
gcloud storage cp gcs_uri gs://my-bucket
Nota: se l'URI GCS di output viene fornito dall'utente, l'annotazione viene archiviata in questo URI GCS.
Go
Java
Node.js
Per eseguire l'autenticazione in Video Intelligence, configura le Credenziali predefinite dell'applicazione. Per ulteriori informazioni, consulta Configura l'autenticazione per un ambiente di sviluppo locale.
Python
Linguaggi aggiuntivi
C#: Segui le istruzioni di configurazione di C# nella pagina delle librerie client e poi visita la documentazione di riferimento di Video Intelligence per .NET.
PHP: Segui le istruzioni di configurazione di PHP nella pagina delle librerie client e poi visita la documentazione di riferimento di Video Intelligence per PHP.
Ruby: Segui le istruzioni di configurazione di Ruby nella pagina delle librerie client e poi visita la documentazione di riferimento di Video Intelligence per Ruby.
Richiedere il monitoraggio degli oggetti per il video da un file locale
Gli esempi riportati di seguito mostrano il monitoraggio degli oggetti in un file archiviato localmente.
REST
Invia la richiesta di elaborazione
Per eseguire l'annotazione su un file video locale, codifica in Base64 i contenuti del file video.
Includi i contenuti codificati in base64 nel campo inputContent
della richiesta.
Per informazioni su come codificare in Base64 i contenuti di un file video, consulta la sezione
Codifica Base64.
Di seguito viene mostrato come inviare una richiesta POST
al metodo
videos:annotate
. L'esempio utilizza il token di accesso per un account di servizio configurato per il progetto utilizzando Google Cloud CLI. Per
istruzioni sull'installazione di Google Cloud CLI, sulla configurazione di un progetto con un service
account e sull'ottenimento di un token di accesso, consulta la
guida rapida di Video Intelligence.
Prima di utilizzare i dati della richiesta, apporta le seguenti sostituzioni:
- inputContent: BASE64_ENCODED_CONTENT
Ad esempio:"UklGRg41AwBBVkkgTElTVAwBAABoZHJsYXZpaDgAAAA1ggAAxPMBAAAAAAAQCAA..."
- PROJECT_NUMBER: L'identificatore numerico del tuo progetto Google Cloud
Metodo HTTP e URL:
POST https://videointelligence.googleapis.com/v1/videos:annotate
Corpo JSON della richiesta:
{ "inputContent": "BASE64_ENCODED_CONTENT", "features": ["OBJECT_TRACKING"] }
Per inviare la richiesta, espandi una di queste opzioni:
Dovresti ricevere una risposta JSON simile alla seguente:
Se la richiesta ha esito positivo, Video Intelligence restituisce name
per l'operazione. Di seguito è riportato un esempio di risposta, in cui PROJECT_NUMBER
è il numero del tuo progetto e OPERATION_ID
è l'ID dell'operazione a lunga esecuzione creata per la richiesta.
Visualizzare i risultati
Per ottenere i risultati della richiesta, devi inviare un GET
utilizzando il nome dell'operazione restituito dalla chiamata a videos:annotate
, come mostrato nell'esempio seguente.
Prima di utilizzare i dati della richiesta, apporta le seguenti sostituzioni:
- OPERATION_NAME: il nome dell'operazione restituito dall'API Video Intelligence. Il nome dell'operazione ha il formato
projects/PROJECT_NUMBER/locations/LOCATION_ID/operations/OPERATION_ID
- PROJECT_NUMBER: L'identificatore numerico del tuo progetto Google Cloud
Metodo HTTP e URL:
GET https://videointelligence.googleapis.com/v1/OPERATION_NAME
Per inviare la richiesta, espandi una di queste opzioni:
Dovresti ricevere una risposta JSON simile alla seguente:
Go
Java
Node.js
Per eseguire l'autenticazione in Video Intelligence, configura le Credenziali predefinite dell'applicazione. Per ulteriori informazioni, consulta Configura l'autenticazione per un ambiente di sviluppo locale.
Python
Linguaggi aggiuntivi
C#: Segui le istruzioni di configurazione di C# nella pagina delle librerie client e poi visita la documentazione di riferimento di Video Intelligence per .NET.
PHP: Segui le istruzioni di configurazione di PHP nella pagina delle librerie client e poi visita la documentazione di riferimento di Video Intelligence per PHP.
Ruby: Segui le istruzioni di configurazione di Ruby nella pagina delle librerie client e poi visita la documentazione di riferimento di Video Intelligence per Ruby.