Google Maps की मदद से ग्राउंडिंग करना

Google Maps से जानकारी लेने की सुविधा, Gemini मॉडल को Google Maps के जियोस्पेशल डेटा से कनेक्ट करती है. इससे, आपके ऐप्लिकेशन में जगह की जानकारी के हिसाब से काम करने वाली सुविधाएं बनाई जा सकती हैं.

Google Maps से जानकारी लेने की सुविधा के ये फ़ायदे हैं:

  • जानकारी की सटीकता बढ़ाना: Google के डेटाबेस में 25 करोड़ से ज़्यादा असल जगहों और कारोबारों की जानकारी मौजूद है. इस डेटाबेस के आधार पर जवाब देकर, मॉडल के गलत जवाब देने की समस्या को कम किया जा सकता है.
  • रीयल-टाइम में जानकारी ऐक्सेस करना: लाइव डेटा का इस्तेमाल करके सवालों के जवाब दें. जैसे, कारोबार के मौजूदा समय और ईवी चार्जिंग स्टेशन की रीयल-टाइम स्थिति.
  • विज़ुअल कॉन्टेक्स्ट उपलब्ध कराना: मॉडल के दावे, जगह की जानकारी पर आधारित होते हैं. इन दावों के साथ, इंटरैक्टिव मैप विजेट, फ़ोटो, और Street View को सीधे तौर पर इंटिग्रेट करके, उपयोगकर्ताओं का भरोसा जीतें.

काम करने वाले मॉडल

  • gemini-3.1-pro-preview
  • gemini-3-flash-preview
  • gemini-3.1-flash-lite
  • gemini-2.5-pro
  • gemini-2.5-flash
  • gemini-2.5-flash-lite

यह सुविधा इन भाषाओं में काम करती है

काम करने वाली भाषाएं देखें Gemini मॉडल के लिए.

मॉडल को Google Maps से कनेक्ट करना

इस पेज पर, Gemini API प्रोवाइडर के हिसाब से कॉन्टेंट और कोड देखने के लिए, उस पर क्लिक करें.

GenerativeModel इंस्टेंस बनाते समय, GoogleMaps को tool के तौर पर शामिल करें. इससे मॉडल, जवाब जनरेट करने के लिए इसका इस्तेमाल कर पाएगा.

Swift


import FirebaseAILogic

// Initialize the Gemini Developer API backend service
let ai = FirebaseAI.firebaseAI(backend: .googleAI())

// Example: Coordinates for New York City
let latAndLong = CLLocationCoordinate2D(latitude: 40.7128, longitude: -74.0060)

// (Optional) Define a RetrievalConfig to configure the Grounding with Google Maps tool.
// You can optionally provide a location's coordinates and/or a language code
// for more relevant and personalized Google Maps results.
let retrievalConfig = RetrievalConfig(
    location: latAndLong,
    // Example: Language code for English (US)
    languageCode: "en_US"
)

// Wrap the RetrievalConfig inside a ToolConfig.
let toolConfig = ToolConfig(retrievalConfig: retrievalConfig)

// Create a `GenerativeModel` instance with a model that supports your use case.
let model = ai.generativeModel(
    modelName: "GEMINI_MODEL_NAME",
    // Provide Google Maps as a tool that the model can use to generate its response.
    tools: [Tool.googleMaps()],
    // Add the configuration for the Grounding with Google Maps tool
    // (if this optional config was defined above).
    toolConfig: toolConfig
)

let response = try await model.generateContent("restaurants near me?")
print(response.text ?? "No text in response.")

// Make sure to comply with the "Grounding with Google Maps" usage requirements,
// which includes how you meet service usage requirements

Kotlin


// (Optional) Define a RetrievalConfig to configure the Grounding with Google Maps tool.
// You can optionally provide a location's coordinates and/or a language code
// for more relevant and personalized Google Maps results.
val retrievalConfig = RetrievalConfig(
    // Example: Coordinates for New York City
    latLng = LatLng(latitude = 40.7128, longitude = -74.0060),
    // Example: Language code for English (US)
    languageCode = "en_US"
)

// Wrap the RetrievalConfig inside a ToolConfig.
val toolConfig = ToolConfig(
    retrievalConfig = retrievalConfig
)

// Initialize the Gemini Developer API backend service
// Create a `GenerativeModel` instance with a model that supports your use case.
val model = Firebase.ai(backend = GenerativeBackend.googleAI()).generativeModel(
    modelName = "GEMINI_MODEL_NAME",
    // Add the configuration for the Grounding with Google Maps tool
    // (if this optional config was defined above).
    toolConfig = toolConfig,
    // Provide Google Maps as a tool that the model can use to generate its response.
    tools = listOf(Tool.googleMaps())
)

val response = model.generateContent("restaurants near me?")
print(response.text)

// Make sure to comply with the "Grounding with Google Maps" usage requirements,
// which includes how you meet service usage requirements

Java


// (Optional) Define a ToolConfig to configure the Grounding with Google Maps tool.
// You can optionally provide a location's coordinates and/or a language code
// for more relevant and personalized Google Maps results.
ToolConfig toolConfig = new ToolConfig(
    null,
    new RetrievalConfig(
        // Example: Coordinates for New York City
        new LatLng(40.7128, -74.0060),
        // Example: Language code for English (US)
       "en_US"
    )
);

// Initialize the Gemini Developer API backend service.
// Create a `GenerativeModel` instance with a model that supports your use case.
GenerativeModel ai = FirebaseAI.getInstance(GenerativeBackend.googleAI())
                .generativeModel("GEMINI_MODEL_NAME",
                        null,
                        null,
                        // Provide Google Maps as a tool that the model can use to generate its response.
                        List.of(Tool.googleMaps()),
                        // Add the configuration for the Grounding with Google Maps tool
                        // (if this optional config was defined above).
                        toolConfig);

// Use the GenerativeModelFutures Java compatibility layer which offers
// support for ListenableFuture and Publisher APIs.
GenerativeModelFutures model = GenerativeModelFutures.from(ai);

ListenableFuture response = model.generateContent("restaurants near me?");
  Futures.addCallback(response, new FutureCallback() {
      @Override
      public void onSuccess(GenerateContentResponse result) {
          String resultText = result.getText();
          System.out.println(resultText);
      }

      @Override
      public void onFailure(Throwable t) {
          t.printStackTrace();
      }
  }, executor);

// Make sure to comply with the "Grounding with Google Maps" usage requirements,
// which includes how you meet service usage requirements

Web


import { initializeApp } from "firebase/app";
import { getAI, getGenerativeModel, GoogleAIBackend } from "firebase/ai";

// TODO(developer) Replace the following with your app's Firebase configuration
// See: https://firebase.google.com/docs/web/learn-more#config-object
const firebaseConfig = {
  // ...
};

// Initialize FirebaseApp
const firebaseApp = initializeApp(firebaseConfig);

// Initialize the Gemini Developer API backend service
const ai = getAI(firebaseApp, { backend: new GoogleAIBackend() });

// (Optional) Define a toolConfig to configure the Grounding with Google Maps tool.
// You can optionally provide a location's coordinates and/or a language code
// for more relevant and personalized Google Maps results.
const toolConfig = {
  retrievalConfig: {
    // Example: Coordinates for New York City
    latLng: {
      latitude: 40.7128,
      longitude: -74.0060
    },
    // Example: Language code for English (US)
    languageCode: 'en-US'
  }
};

// Create a `GenerativeModel` instance with a model that supports your use case
const model = getGenerativeModel(
  ai,
  {
    model: "GEMINI_MODEL_NAME",
    // Provide Google Maps as a tool that the model can use to generate its response.
    // (Optional) Set `enableWidget` to control whether the response contains a `googleMapsWidgetContextToken`.
    tools: [ { googleMaps: { enableWidget: true } } ],
    // Add the configuration for the Grounding with Google Maps tool
    // (if this optional config was defined above).
    toolConfig
  }
);

const result = await model.generateContent("restaurants near me?");

console.log(result.response.text());

// Make sure to comply with the "Grounding with Google Maps" usage requirements,
// which includes how you meet service usage requirements

Dart


import 'package:firebase_core/firebase_core.dart';
import 'package:firebase_ai/firebase_ai.dart';
import 'firebase_options.dart';

// Initialize FirebaseApp.
await Firebase.initializeApp(
  options: DefaultFirebaseOptions.currentPlatform,
);

// (Optional) Define a ToolConfig to configure the Grounding with Google Maps tool.
// You can optionally provide a location's coordinates and/or a language code
// for more relevant and personalized Google Maps results.
final toolConfig = ToolConfig(
  retrievalConfig: RetrievalConfig(
    // Example: Coordinates for New York City
    latLng: LatLng(latitude: 40.712728, longitude: -74.006015),
    // Example: Language code for English (US)
    languageCode: 'en',
  ),
);

// Initialize the Gemini Developer API backend service
// Create a `GenerativeModel` instance with a model that supports your use case.
final model = FirebaseAI.googleAI().generativeModel(
  model: 'GEMINI_MODEL_NAME',
  // Provide Google Maps as a tool that the model can use to generate its response.
  tools: [
    Tool.googleMaps(),
  ],
  // Add the configuration for the Grounding with Google Maps tool
  // (if this optional config was defined above).
  toolConfig: toolConfig,
);

final response = await model.generateContent([Content.text("restaurants near me?")]);
print(response.text);

// Make sure to comply with the "Grounding with Google Maps" usage requirements,
// which includes how you meet service usage requirements

Unity


using Firebase;
using Firebase.AI;

// Initialize the Gemini Developer API backend service
var ai = FirebaseAI.GetInstance(FirebaseAI.Backend.GoogleAI());

// Example: Coordinates for New York City
var latLng = new LatLng(40.7128, -74.0060);

// (Optional) Define a RetrievalConfig to configure the Grounding with Google Maps tool.
// You can optionally provide a location's coordinates and/or a language code
// for more relevant and personalized Google Maps results.
var retrievalConfig = new RetrievalConfig(latLng, languageCode: "en");

// Wrap the RetrievalConfig inside a ToolConfig.
var toolConfig = new ToolConfig(retrievalConfig: retrievalConfig);

// Create a `GenerativeModel` instance with a model that supports your use case
var model = ai.GetGenerativeModel(
  modelName: "GEMINI_MODEL_NAME",
  // Provide Google Maps as a tool that the model can use to generate its response.
  tools: new[] { new Tool(new GoogleMaps()) },
  // Add the configuration for the Grounding with Google Maps tool
  // (if this optional config was defined above).
  toolConfig: toolConfig
);

var response = await model.GenerateContentAsync("restaurants near me?");
UnityEngine.Debug.Log(response.Text ?? "No text in response.");

// Make sure to comply with the "Grounding with Google Maps" usage requirements,
// which includes how you meet service usage requirements

अपने इस्तेमाल के उदाहरण और ऐप्लिकेशन के लिए, मॉडल

बेहतर नतीजे पाने के लिए, 1.0 का तापमान इस्तेमाल करें. यह Gemini 2.5 और उसके बाद के सभी मॉडल के लिए डिफ़ॉल्ट तापमान है. मॉडल के कॉन्फ़िगरेशन में तापमान सेट करने का तरीका जानें.

नतीजों को बेहतर बनाने के सबसे सही तरीके और सलाह

इस सेक्शन में, Google Maps से जानकारी लेने की सुविधा का इस्तेमाल करने के कुछ सामान्य सबसे सही तरीके बताए गए हैं. साथ ही, इसमें जगह की प्रॉपर्टी का फ़ायदा उठाकर, नतीजों को बेहतर बनाने का तरीका भी बताया गया है.Google Maps

सबसे सही तरीके

  • ज़रूरत पड़ने पर ही टूल उपलब्ध कराएं: परफ़ॉर्मेंस और लागत को ऑप्टिमाइज़ करने के लिए, मॉडल को Google Maps से जानकारी लेने की सुविधा का ऐक्सेस सिर्फ़ तब दें, जब इस्तेमाल के उदाहरण में जगह की जानकारी शामिल हो.

  • उपयोगकर्ता की जगह की जानकारी उपलब्ध कराएं: सबसे काम के और पसंद के मुताबिक जवाब पाने के लिए (और जब उपयोगकर्ता की जगह की जानकारी पता हो), Google Maps से जानकारी लेने की सुविधा के कॉन्फ़िगरेशन में, उपयोगकर्ता की जगह की जानकारी (अक्षांश और देशांतर का इस्तेमाल करके) शामिल करें.latLngGoogle Maps

  • आखिरी उपयोगकर्ताओं को जानकारी दें: अपने आखिरी उपयोगकर्ताओं को साफ़ तौर पर बताएं कि Google Maps डेटा का इस्तेमाल उनकी क्वेरी के जवाब देने के लिए किया जा रहा है. आखिरी उपयोगकर्ताओं को Google Maps के सोर्स की जानकारी देना, Google Maps से जानकारी लेने की सुविधा के इस्तेमाल की ज़रूरी शर्त है.

  • (सिर्फ़ Web SDK) Google Maps कॉन्टेक्चुअल विजेट को रेंडर करें: कॉन्टेक्चुअल विजेट को, कॉन्टेक्स्ट टोकन googleMapsWidgetContextToken का इस्तेमाल करके रेंडर किया जाता है. यह टोकन, Gemini API के जवाब में मिलता है. इसका इस्तेमाल, Google Maps से विज़ुअल कॉन्टेंट रेंडर करने के लिए किया जा सकता है. कॉन्टेक्चुअल विजेट के बारे में ज़्यादा जानने के लिए, दस्तावेज़ में विजेट देखें.Google MapsGoogle Maps

प्रॉम्प्ट में जगह की प्रॉपर्टी का इस्तेमाल करना

इस सेक्शन में, जगह की प्रॉपर्टी की सूची दी गई है. इनका इस्तेमाल, जगहों के बारे में बताने के लिए किया जाता है. साथ ही, Google Maps से जानकारी लेने की सुविधा, जवाब जनरेट करने के लिए भी इनका इस्तेमाल करती है.Google Maps इन प्रॉपर्टी का इस्तेमाल करके, यह तय किया जाता है कि Google Maps से जानकारी लेने की सुविधा, किस तरह के सवालों के जवाब दे सकती है.Google Maps

जगह की प्रॉपर्टी के उदाहरण

इस सूची में, जगहों की प्रॉपर्टी के वर्णमाला के क्रम में सैंपल दिए गए हैं. इनका इस्तेमाल, आपका मॉडल जवाब जनरेट करने के लिए कर सकता है.

  • पता
  • कर्बसाइड पिक अप
  • डेबिट कार्ड
  • दूरी
  • मुफ़्त पार्किंग की सुविधा उपलब्ध है
  • लाइव संगीत
  • बच्चों के लिए खाना
  • खुलने का समय
  • पेमेंट के विकल्प (जैसे, नकद या क्रेडिट कार्ड)
  • जगह के बारे में जवाब
  • पालतू जानवर लाने की छूट है
  • बीयर उपलब्ध
  • शाकाहारी खाना मिलता है
  • व्हीलचेयर की सुविधा है
  • वाई-फ़ाई

जगह के बारे में जवाब, Google Maps से जानकारी लेने की सुविधा का जवाब है. यह जवाब, उपयोगकर्ता की समीक्षाओं से मिली जानकारी के आधार पर दिया जाता है.Google Maps

जगह की प्रॉपर्टी का इस्तेमाल करने वाले प्रॉम्प्ट के उदाहरण

यहां दिए गए उदाहरणों में, अलग-अलग तरह की जगहों के बारे में प्रॉम्प्ट में जगह की प्रॉपर्टी का इस्तेमाल किया गया है. Google Maps से जानकारी लेने की सुविधा, आपकी मंशा को समझने के लिए प्रॉपर्टी का इस्तेमाल करती है. इसके बाद, Google Maps में मौजूद जगहों से जुड़े डेटा के आधार पर, काम के जवाब देती है.

  • फ़ैमिली डिनर प्लान करना: यह पता लगाना कि कोई रेस्टोरेंट, परिवार के लिए सही है या नहीं. साथ ही, यह पता लगाना कि रेस्टोरेंट, सुविधाजनक सेवा उपलब्ध कराता है या नहीं.

    • प्रॉम्प्ट का उदाहरण: क्या "द इटैलियन प्लेस" बच्चों के लिए सही है और क्या वहां से टेकआउट की सुविधा मिलती है? उसकी रेटिंग क्या है?
  • किसी दोस्त के लिए ऐक्सेस की सुविधा की जांच करना: यह पता लगाना कि जगह, ऐक्सेस की सुविधा से जुड़ी ज़रूरी शर्तों को पूरा करती है या नहीं.

    • प्रॉम्प्ट का उदाहरण: मुझे एक ऐसे रेस्टोरेंट की ज़रूरत है जहां व्हीलचेयर से आने-जाने की सुविधा हो.
  • देर रात के स्नैक के लिए कोई जगह ढूंढना: कोई ऐसी जगह ढूंढना जो किसी खास समय पर, कोई खास खाना परोसती हो.

    • प्रॉम्प्ट का उदाहरण: क्या "बर्गर जॉइंट" अभी खुला है? क्या वहां डिनर परोसा जाता है? शुक्रवार के लिए, उसके खुलने का समय क्या है?
  • कॉफ़ी के लिए किसी क्लाइंट से मिलना: सुविधाओं, ऑफ़र, और पेमेंट के विकल्पों के आधार पर, यह आकलन करना कि कोई कैफ़े, कारोबार से जुड़ी मीटिंग के लिए सही है या नहीं.

    • प्रॉम्प्ट का उदाहरण: क्या "कैफ़े सेंट्रल" में वाई-फ़ाई की सुविधा है? क्या वहां कॉफ़ी परोसी जाती है? उसका प्राइस लेवल क्या है और क्या वहां क्रेडिट कार्ड से पेमेंट किया जा सकता है?

ध्यान दें कि Google Maps Google Maps से मिली जानकारी के आधार पर दिए गए नतीजों में मौजूद जानकारी, सड़क की असल स्थितियों से अलग हो सकती है.

जानकारी लेने की सुविधा कैसे काम करती हैGoogle Maps

मॉडल को GoogleMaps टूल उपलब्ध कराने पर, मॉडल, जानकारी खोजने, प्रोसेस करने, और उसका हवाला देने का पूरा वर्कफ़्लो अपने-आप मैनेज करता है.

यहां मॉडल का वर्कफ़्लो दिया गया है:

  1. प्रॉम्प्ट मिलता है: आपका ऐप्लिकेशन, Gemini मॉडल को GoogleMaps टूल चालू करके एक प्रॉम्प्ट भेजता है.

  2. प्रॉम्प्ट का विश्लेषण करता है: मॉडल, प्रॉम्प्ट का विश्लेषण करता है और यह तय करता है कि Google Maps उसके जवाब को बेहतर बना सकता है या नहीं. उदाहरण के लिए, अगर प्रॉम्प्ट में जगह की जानकारी शामिल है (जैसे, "मेरे आस-पास की कॉफ़ी शॉप", "सैन फ़्रांसिस्को में मौजूद म्यूज़ियम").

  3. टूल को शुरू करता है: मॉडल, जगह की जानकारी से जुड़ी मंशा को पहचानकर, जानकारी लेने की सुविधा के Google Maps टूल को शुरू करता है.

  4. Google Maps को क्वेरी भेजता हैGoogle Maps: Google Maps से जानकारी लेने की सुविधा, काम की जानकारी के लिए Google Maps से क्वेरी करती है. जैसे, जगहें, समीक्षाएं, फ़ोटो, पते, खुलने का समय.Google MapsGoogle Maps

    Google Maps के ज़्यादा काम के और पसंद के मुताबिक Google Maps नतीजे पाने के लिए, टूल के कॉन्फ़िगरेशन में (या सीधे प्रॉम्प्ट में भी) अक्षांश और देशांतर शामिल किए जा सकते हैं. हालांकि, यह ज़रूरी नहीं है. यह टूल, टेक्स्ट के आधार पर खोज करने वाला टूल है. यह Google Maps पर खोज करने की तरह ही काम करता है. जैसे, स्थानीय क्वेरी ("मेरे आस-पास") के लिए, निर्देशांकों का इस्तेमाल किया जाएगा. वहीं, खास या गैर-स्थानीय क्वेरी पर, जगह की जानकारी का असर पड़ने की संभावना कम होती है.

  5. Google Maps नतीजों को प्रोसेस करता है: मॉडल, Google Maps नतीजों को प्रोसेस करता है और ओरिजनल प्रॉम्प्ट का जवाब तैयार करता है.

  6. Google Maps ग्राउंडेड नतीजा दिखाता है: मॉडल, Google Maps नतीजों के आधार पर, उपयोगकर्ता के लिए काम का और आसान जवाब दिखाता है. इस जवाब में ये चीज़ें शामिल होती हैं:

    • मॉडल का टेक्स्ट जवाब.
    • एक groundingMetadata ऑब्जेक्ट, जिसमें Google Maps नतीजे और सोर्स शामिल होते हैं.
    • (सिर्फ़ Web SDK) इसके अलावा, googleMapsWidgetContextToken भी शामिल हो सकता है. इसकी मदद से, विज़ुअल इंटरैक्शन के लिए, आपके ऐप्लिकेशन में कॉन्टेक्चुअल Google Maps विजेट रेंडर किया जा सकता है. कॉन्टेक्चुअल विजेट के बारे में ज़्यादा जानने के लिए, Google Maps विजेट Google Maps दस्तावेज़ में देखें.

ध्यान दें कि मॉडल को Google Maps को टूल के तौर पर उपलब्ध कराने के लिए, यह ज़रूरी नहीं है कि मॉडल, जवाब जनरेट करने के लिए हमेशा Google Maps टूल का इस्तेमाल करे. ऐसे मामलों में, जवाब में groundingMetadata ऑब्जेक्ट शामिल नहीं होगा. इसलिए, यह Google Maps से मिली जानकारी के आधार पर दिया गया नतीजा नहीं है.Google Maps

Google Maps से मिली जानकारी के आधार पर दिए गए नतीजे को समझना

अगर मॉडल, Google Maps नतीजों के आधार पर जवाब देता है, तो जवाब में groundingMetadata ऑब्जेक्ट शामिल होता है. इसमें स्ट्रक्चर्ड डेटा होता है. यह डेटा, दावों की पुष्टि करने और आपके ऐप्लिकेशन में सोर्स का बेहतर अनुभव देने के लिए ज़रूरी है.

Google Maps Grounded Result में मौजूद groundingMetadata ऑब्जेक्ट में यह जानकारी शामिल होती है:

यहां, groundingMetadata ऑब्जेक्ट शामिल करने वाले जवाब का एक उदाहरण दिया गया है:

{
  "candidates": [
    {
      "content": {
        "parts": [
          {
            "text": "CanteenM is an American restaurant with..."
          }
        ],
        "role": "model"
      },
      "groundingMetadata": {
        "groundingChunks": [
          {
            "maps": {
              "uri": "https://maps.google.com/?cid=13100894621228039586",
              "title": "Heaven on 7th Marketplace",
              "placeId": "places/ChIJ0-zA1vBZwokRon0fGj-6z7U"
            }
          }
        ],
        "groundingSupports": [
          {
            "segment": {
              "startIndex": 0,
              "endIndex": 79,
              "text": "CanteenM is an American restaurant with a 4.6-star rating and is open 24 hours."
            },
            "groundingChunkIndices": [0]
          }
        ],
        "googleMapsWidgetContextToken": "widgetcontent/..."
      }
    }
  ]
}

सेवा के इस्तेमाल की ज़रूरी शर्तें

इस सेक्शन में, Google Maps के लिए, आपके चुने गए Gemini API प्रोवाइडर: Gemini Developer API या Vertex AI Gemini API के लिए, Google Maps से जानकारी लेने की सुविधा के इस्तेमाल की ज़रूरी शर्तों के बारे में बताया गया है. ज़्यादा जानकारी के लिए, सेवा की शर्तें सेक्शन देखें.

उपयोगकर्ताओं को Google Maps सोर्स की जानकारी देना

Google Maps Google Maps से मिली जानकारी के आधार पर दिए गए हर नतीजे के साथ, आपको groundingChunks में सोर्स मिलेंगे. ये सोर्स, हर जवाब के लिए काम के होते हैं. इसके अलावा, यह मेटाडेटा भी मिलता है:

  • सोर्स यूआरआई
  • शीर्षक
  • आईडी

अपने ऐप्लिकेशन में, Google Maps से जानकारी लेने की सुविधा से मिले नतीजे दिखाते समय, आपको Google Maps के जुड़े सोर्स की जानकारी देनी होगी. साथ ही, अपने उपयोगकर्ताओं को यह जानकारी देनी होगी:Google Maps

  • Google Maps सोर्स, जनरेट किए गए उस कॉन्टेंट के ठीक बाद दिखने चाहिए जिसके लिए सोर्स काम के हैं. जनरेट किए गए इस कॉन्टेंट को Google Maps Grounded Result भी कहा जाता है.

  • Google Maps सोर्स, उपयोगकर्ता के एक इंटरैक्शन में दिखने चाहिए.

Google Maps Grounded Result से सोर्स दिखाने के लिए, वैल्यू पाने का तरीका यहां बताया गया है:

Swift

// ...

// Get the model's response
let text = response.text

// Get the grounding metadata
if let candidate = response.candidates.first,
   let groundingMetadata = candidate.groundingMetadata {

  // Get sources
  let groundingChunks = groundingMetadata.groundingChunks
  for chunk in groundingChunks {
    if let maps = chunk.maps {
      let title = maps.title  // for example, "Heaven on 7th Marketplace"
      let url = maps.url  // for example, "https://maps.google.com/?cid=13100894621228039586"
      let placeId = maps.placeId  // for example, "places/ChIJ0-zA1vBZwokRon0fGj-6z7U"
      // TODO(developer): show source in the UI
    }
  }
}

Kotlin

// ...

// Get the model's response
val text = response.text

// Get the grounding metadata
val groundingMetadata = response.candidates.firstOrNull()?.groundingMetadata

// Get sources
val groundingChunks = groundingMetadata?.groundingChunks
groundingChunks?.let { chunks ->
  for (chunk in chunks) {
    val title = chunk.maps?.title  // for example, "Heaven on 7th Marketplace"
    val uri = chunk.maps?.uri  // for example, "https://maps.google.com/?cid=13100894621228039586"
    val placeId = chunk.maps?.placeId  // for example, "places/ChIJ0-zA1vBZwokRon0fGj-6z7U"
    // TODO(developer): show source in the UI
  }
}

Java

// ...

Futures.addCallback(response, new FutureCallback() {
  @Override
  public void onSuccess(GenerateContentResponse result) {
    // Get the model's response
    String text = result.getText();

    // Get the grounding metadata
    GroundingMetadata groundingMetadata =
        result.getCandidates()[0].getGroundingMetadata();

    if (groundingMetadata != null) {
      // Get sources
      List chunks = groundingMetadata.getGroundingChunks();
      if (chunks != null) {
        for(GroundingChunk chunk : chunks) {
          GoogleMapsGroundingChunk maps = chunk.getMaps();
          if (maps != null) {
            String title = maps.getTitle();  // for example, "Heaven on 7th Marketplace"
            String uri = maps.getUri();  // for example, "https://maps.google.com/?cid=13100894621228039586"
            String placeId = maps.getPlaceId();  // for example, "places/ChIJ0-zA1vBZwokRon0fGj-6z7U"
            // TODO(developer): show sources in the UI
          }
        }
      }
    }
  }

  @Override
  public void onFailure(Throwable t) {
    t.printStackTrace();
  }
}, executor);

Web

// ...

// Get the model's text response
const text = result.response.text();

// Get the grounding metadata
const groundingMetadata = result.response.candidates?.[0]?.groundingMetadata;

// Get sources
const groundingChunks = groundingMetadata?.groundingChunks;
if (groundingChunks) {
  for (const chunk of groundingChunks) {
    const title = chunk.maps?.title;  // for example, "Heaven on 7th Marketplace"
    const uri = chunk.maps?.uri;  // for example, "https://maps.google.com/?cid=13100894621228039586"
    const placeId = chunk.maps?.placeId;  // for example, "places/ChIJ0-zA1vBZwokRon0fGj-6z7U"
    // TODO(developer): show sources in the UI
  }
}

Dart

// ...

// Get the model's response
final text = response.text;

// Get the grounding metadata
final groundingMetadata = response.candidates.first.groundingMetadata;

// Get sources
final groundingChunks = groundingMetadata?.groundingChunks;
if (groundingChunks != null) {
  for (var chunk in groundingChunks) {
    final title = chunk.maps?.title;  // for example, "Heaven on 7th Marketplace"
    final uri = chunk.maps?.uri;  // for example, "https://maps.google.com/?cid=13100894621228039586"
    final placeId = chunk.maps?.placeId;  // for example, "places/ChIJ0-zA1vBZwokRon0fGj-6z7U"
    // TODO(developer): show sources in the UI
  }
}

Unity

// ...

// Get the model's response
var text = response.Text;

// Get the grounding metadata
var groundingMetadata = response.Candidates.First().GroundingMetadata;

// Get sources
if (groundingMetadata != null) {
  foreach(GroundingChunk chunk in groundingMetadata?.GroundingChunks) {
    if (chunk.Maps != null) {
      var title = chunk.Maps?.Title;  // for example, "Heaven on 7th Marketplace"
      var uri = chunk.Maps?.Uri;  // for example, "https://maps.google.com/?cid=13100894621228039586"
      var placeId = chunk.Maps?.PlaceId;  // for example, "places/ChIJ0-zA1vBZwokRon0fGj-6z7U"
      // TODO(developer): show sources in the UI
    }
  }
}

groundingChunks में मौजूद हर सोर्स के लिए, लिंक की झलक इन ज़रूरी शर्तों के मुताबिक जनरेट की जानी चाहिए:

जवाब के सोर्स दिखाने वाला प्रॉम्प्ट

सोर्स के व्यू को छोटा किया जा सकता है.

जवाब और सोर्स को छोटा करके दिखाया गया प्रॉम्प्ट

इसके अलावा, लिंक की झलक को ज़्यादा कॉन्टेंट के साथ बेहतर बनाया जा सकता है. जैसे:

कुछ Google Maps डेटा प्रोवाइडर और उनके लाइसेंस की शर्तों के बारे में ज़्यादा जानने के लिए, Google Maps और Google Earth के कानूनी नोटिस देखें.

Google Maps टेक्स्ट एट्रिब्यूशन के दिशा-निर्देश

टेक्स्ट में Google Maps के सोर्स का एट्रिब्यूशन देते समय, इन दिशा-निर्देशों का पालन करें:

  • Google Maps टेक्स्ट में किसी भी तरह का बदलाव न करें:

    • Google Maps टेक्स्ट के कैपिटलाइज़ेशन में बदलाव न करें.
    • Google Maps टेक्स्ट को एक से ज़्यादा लाइनों में रैप न करें.
    • Google Maps टेक्स्ट को किसी दूसरी भाषा में स्थानीय भाषा के मुताबिक न बनाएं.
    • एचटीएमएल एट्रिब्यूट translate="no" का इस्तेमाल करके, ब्राउज़र को Google Maps टेक्स्ट का अनुवाद करने से रोकें.
  • Google Maps टेक्स्ट को इस टेबल में बताए गए तरीके से स्टाइल करें:

    प्रॉपर्टी स्टाइल
    फ़ॉन्ट फ़ैमिली Roboto. फ़ॉन्ट लोड करना ज़रूरी नहीं है.
    फ़ॉलबैक फ़ॉन्ट फ़ैमिली आपके प्रॉडक्ट में पहले से इस्तेमाल किया जा रहा कोई भी sans serif बॉडी फ़ॉन्ट या डिफ़ॉल्ट सिस्टम फ़ॉन्ट को शुरू करने के लिए "Sans-Serif"
    फ़ॉन्ट स्टाइल सामान्य
    फ़ॉन्ट की मोटाई 400
    फ़ॉन्ट का रंग सफ़ेद, काला (#1F1F1F) या स्लेटी (#5E5E5E). बैकग्राउंड के मुकाबले, 4.5:1 का ऐक्सेसिबल कंट्रास्ट बनाए रखें.
    फ़ॉन्ट का साइज़ कम से कम फ़ॉन्ट साइज़: 12sp
    ज़्यादा से ज़्यादा फ़ॉन्ट साइज़: 16sp
    sp के बारे में जानने के लिए, Material Design वेबसाइट पर फ़ॉन्ट साइज़ की इकाइयां देखें.
    स्पेसिंग सामान्य

सीएसएस का उदाहरण

नीचे दी गई सीएसएस, Google Maps टेक्स्ट को सफ़ेद या हल्के बैकग्राउंड पर, सही टाइपोग्राफ़िक स्टाइल और रंग के साथ रेंडर करती है.

@import url('https://fonts.googleapis.com/css2?family=Roboto&display=swap');

.GMP-attribution {
  font-family: Roboto, Sans-Serif;
  font-style: normal;
  font-weight: 400;
  font-size: 1rem;
  letter-spacing: normal;
  white-space: nowrap;
  color: #5e5e5e;
}

कॉन्टेक्स्ट टोकन और जगह के आईडी को कैश में सेव करना

Google Maps Google Maps से मिली जानकारी के आधार पर दिए गए नतीजे में, कॉन्टेक्स्ट टोकन और जगह का आईडी शामिल हो सकता है. जवाब के इस डेटा को कैश में सेव किया जा सकता है, स्टोर किया जा सकता है, और एक्सपोर्ट किया जा सकता है:

  • (सिर्फ़ Web SDK) googleMapsWidgetContextToken
  • placeId

Google Maps से जानकारी लेने की सुविधा की शर्तों में, इस डेटा को कैश में सेव करने पर लगी पाबंदियां लागू नहीं होती हैं.

रोकी गई गतिविधियां और इलाके

Google Maps से जानकारी लेने की सुविधा के लिए, कुछ कॉन्टेंट और गतिविधियों पर अतिरिक्त पाबंदियां हैं. ऐसा, प्लैटफ़ॉर्म को सुरक्षित और भरोसेमंद बनाए रखने के लिए किया जाता है. इसके अलावा, आपके चुने गए Gemini API प्रोवाइडर की शर्तों में, इस्तेमाल पर लगी पाबंदियां भी लागू होती हैं: Gemini Developer API या Vertex AI Gemini API ज़्यादा जानकारी के लिए, सेवा की खास शर्तों में सेवा की शर्तें सेक्शन देखें.

  • Google Maps से जानकारी लेने की सुविधा का इस्तेमाल, ज़्यादा जोखिम वाली गतिविधियों के लिए नहीं किया जा सकेगा. इनमें, आपातकालीन सेवाओं के लिए भी इसका इस्तेमाल नहीं किया जा सकेगा.Google Maps

  • आप अपने उस ऐप्लिकेशन को, पाबंदी वाले इलाके में डिस्ट्रिब्यूट या उसकी मार्केटिंग नहीं कर पाएंगे जिसमें Grounding की सुविधा उपलब्ध है.Google Maps ज़्यादा जानकारी के लिए, Google Maps Platform के पाबंदी वाले इलाके देखें. पाबंदी वाले इलाकों की सूची को समय-समय पर अपडेट किया जा सकता है.

Firebase console में, Google Maps से मिली जानकारी के आधार पर दिए गए नतीजे और एआई की निगरानी

अगर आपने एआई की निगरानी की सुविधा Firebase console में चालू की है, तो जवाब, Cloud Logging में सेव किए जाते हैं. डिफ़ॉल्ट रूप से, इस डेटा को 30 दिनों तक सेव रखा जाता है.

यह आपकी ज़िम्मेदारी है कि डेटा को सेव रखने की यह अवधि या आपके सेट की गई कोई भी कस्टम अवधि, आपके इस्तेमाल के उदाहरण और आपके चुने गए Gemini API प्रोवाइडर: Gemini Developer API या Vertex AI Gemini API के लिए, ज़रूरी शर्तों के मुताबिक हो. ज़्यादा जानकारी के लिए, सेवा की खास शर्तों में सेवा की शर्तें सेक्शन देखें. इन ज़रूरी शर्तों को पूरा करने के लिए, आपको Cloud Logging में डेटा को सेव रखने की अवधि में बदलाव करना पड़ सकता है.

कीमत और दर की सीमाएं

Google Maps से जानकारी लेने की सुविधा की कीमत, क्वेरी के आधार पर तय की जाती है. किसी अनुरोध को, Google Maps के कोटे में सिर्फ़ तब गिना जाता है, जब कोई प्रॉम्प्ट, Google Maps से मिली जानकारी के आधार पर दिया गया कम से कम एक नतीजा दिखाता है. इसका मतलब है कि जवाब में, Google Maps का कम से कम एक सोर्स शामिल हो. अगर एक अनुरोध से Google Maps को कई क्वेरी भेजी जाती हैं, तो उसे दर की सीमा के हिसाब से एक अनुरोध के तौर पर गिना जाता है.

Gemini API के आपके चुने गए Gemini API प्रोवाइडर के दस्तावेज़ में, Google Maps से जानकारी लेने की सुविधा की कीमत, मॉडल की उपलब्धता, और सीमाओं के बारे में जानकारी ज़रूर देखें: Gemini Developer API | Vertex AI Gemini API.