मार्कर की मदद से मैप जोड़ना

परिचय

मार्कर वाले मैप का उदाहरण

इस ट्यूटोरियल में, Flutter ऐप्लिकेशन में Google मैप जोड़ने का तरीका बताया गया है. मैप में किसी खास जगह को दिखाने के लिए मार्कर होता है, जिसे पिन भी कहा जाता है.

कोड पाना

Flutter के सैंपल के लिए रिपॉज़िटरी को क्लोन या डाउनलोड करें. सैंपल कोड, google_maps डायरेक्ट्री में मिल सकता है.

डेवलपमेंट प्रोजेक्ट सेट अप करना

इस विषय पर आगे बढ़ने से पहले, पक्का करें कि आपने Flutter प्रोजेक्ट सेट अप करने के लिए बनी गाइड में बताए गए चरणों को पूरा कर लिया हो.

1. Flutter के लिए Google Maps का पैकेज इंपोर्ट करना

  1. अपनी पसंद के आईडीई में main.dart फ़ाइल खोलें.
  2. पुष्टि करें कि फ़ाइल में, इंपोर्ट स्टेटमेंट जोड़ा गया है:
import 'package:google_maps_flutter/google_maps_flutter.dart';

2. अपने Flutter ऐप्लिकेशन में Google Maps जोड़ना

Scaffold विजेट में, मुख्य हिस्से के तौर पर GoogleMap विजेट जोड़ें.

GoogleMap(
   initialCameraPosition: CameraPosition(
      target: _center,
      zoom: 11.0,
   ),
   markers: {
      const Marker(
         markerId: MarkerId('Sydney'),
         position: LatLng(-33.86, 151.20),
      )
   },
)

  • markerId विकल्प, आपके मार्कर को लेबल करता है.
  • position विकल्प से यह सेट किया जाता है कि आपके मैप पर मार्कर कहां दिखेगा.

3. अपना ऐप्लिकेशन बनाना और चलाना

इनमें से किसी एक विकल्प का इस्तेमाल करके, Flutter ऐप्लिकेशन शुरू करें:

  1. अपने आईडीई में, Run बटन पर क्लिक करें
  2. कमांड लाइन से, flutter run चलाएं.

आपको एक मैप दिखेगा, जिसमें ऑस्ट्रेलिया के पूर्वी तट पर सिडनी के बीच में मार्कर होगा. यह मैप, इस पेज पर दी गई इमेज से मिलता-जुलता होगा.

समस्या का हल

  • अगर आपको कोई मैप नहीं दिखता है, तो देखें कि आपने एपीआई कुंजी ली है या नहीं. साथ ही, यह भी देखें कि आपने उसे ऐप्लिकेशन में जोड़ा है या नहीं.
  • अगर आपने एपीआई पासकोड पर पाबंदी लगाने के लिए, iOS बंडल आइडेंटिफ़ायर का इस्तेमाल किया है, तो ऐप्लिकेशन के लिए बंडल आइडेंटिफ़ायर जोड़ने के लिए पासकोड में बदलाव करें: com.google.examples.map-with-marker.
  • पक्का करें कि आपका वाई-फ़ाई या जीपीएस कनेक्शन अच्छा हो.
  • लॉग देखने और ऐप्लिकेशन को डीबग करने के लिए, Flutter DevTools का इस्तेमाल करें.
  • Flutter ऐप्लिकेशन चलाने के बारे में ज़्यादा जानें.

4. कोड को समझना

यह कोड GitHub पर देखा जा सकता है.

  1. ज़रूरी पैकेज इंपोर्ट करें और ऐप्लिकेशन को शुरू करें.
       import 'package:flutter/material.dart';
       import 'package:google_maps_flutter/google_maps_flutter.dart';
    
       void main() => runApp(const MyApp());
    
       class MyApp extends StatefulWidget {
       const MyApp({super.key});
    
       @override
          State<MyApp> createState() => _MyAppState();
       }
  2. ऑस्ट्रेलिया के सिडनी को सेंटर में रखकर मैप बनाएं.
    class _MyAppState extends State<MyApp> {
       
       late GoogleMapController mapController;
       
       final LatLng _center = const LatLng(-33.86, 151.20);
       
       void _onMapCreated(GoogleMapController controller) {
          mapController = controller;
       }
  3. ऐप्लिकेशन में मैप दिखाने के लिए ज़रूरी विजेट जोड़ें.
    @override
    Widget build(BuildContext context) {
        return MaterialApp(
          home: Scaffold(
            appBar: AppBar(
              title: const Text('Maps Sample App'),
              backgroundColor: Colors.green[700],
            ),
            body: GoogleMap(
                onMapCreated: _onMapCreated,
                initialCameraPosition: CameraPosition(
                  target: _center,
                  zoom: 11.0,
                ), // CameraPosition
            ), // GoogleMap
          ), // Scaffold
        ); // MaterialApp
      }
    }
  4. अपने ऐप्लिकेशन में विजेट जोड़ने के लिए, मार्कर विजेट जोड़ें.
       body: GoogleMap(
          onMapCreated: _onMapCreated,
          initialCameraPosition: CameraPosition(
             target: _center,
             zoom: 11.0,
          ),
          markers: {
             const Marker(
                   markerId: const MarkerId("Sydney"),
                   position: LatLng(-33.86, 151.20),
                ), // Marker
          }, // markers
       ), // GoogleMap
       ...
  5. मार्कर में जानकारी वाली विंडो जोड़ें.
          const Marker(
                markerId: const MarkerId("Sydney"),
                position: LatLng(-33.86, 151.20),
                infoWindow: InfoWindow(
                   title: "Sydney",
                   snippet: "Capital of New South Wales",
                ), // InfoWindow
          ), //Marker
          ...
    डिफ़ॉल्ट रूप से, जब कोई उपयोगकर्ता किसी मार्कर पर टैप करता है, तो Google Maps for Flutter पैकेज, जानकारी वाली विंडो का कॉन्टेंट दिखाता है. अगर आपको डिफ़ॉल्ट व्यवहार का इस्तेमाल करना है, तो मार्कर के लिए क्लिक लिसनर जोड़ने की ज़रूरत नहीं है.

बधाई हो! आपने एक ऐसा Flutter ऐप्लिकेशन बनाया है जो किसी खास जगह की जानकारी देने के लिए, मार्कर के साथ Google मैप दिखाता है. साथ ही, जानकारी वाली विंडो में ज़्यादा जानकारी भी देता है. आपने Flutter के लिए Google Maps पैकेज का इस्तेमाल करने का तरीका भी जाना है.