Giriş
Bu eğiticide, Flutter uygulamanıza Google Haritası ekleme işlemi gösterilmektedir. Haritada, belirli bir konumu belirtmek için işaretçi (pin olarak da bilinir) bulunur.
Kodu alma
Flutter örnekleri deposunu klonlayın veya indirin. Örnek kod, google_maps
dizininde bulunabilir.
Geliştirme projenizi oluşturma
Bu konuya devam etmeden önce Flutter projesi oluşturma kılavuzunda belirtilen adımları tamamladığınızdan emin olun.
1. Flutter için Google Haritalar paketini içe aktarma
-
main.dart
dosyanızı tercih ettiğiniz IDE'de açın. - Aşağıdaki içe aktarma ifadesinin dosyaya eklendiğini doğrulayın:
import 'package:google_maps_flutter/google_maps_flutter.dart';
2. Flutter uygulamanıza Google Haritalar'ı ekleme
Scaffold
widget'ına gövde olarak GoogleMap
widget'ı ekleyin.
GoogleMap( initialCameraPosition: CameraPosition( target: _center, zoom: 11.0, ), markers: { const Marker( markerId: MarkerId('Sydney'), position: LatLng(-33.86, 151.20), ) }, )
markerId
seçeneği, işaretçinizi etiketler.position
seçeneği, işaretçinin haritanızda görüneceği yeri belirler.
3. Uygulamanızı oluşturma ve çalıştırma
Aşağıdaki seçeneklerden birini kullanarak Flutter uygulamasını başlatın:
- IDE'nizden
Run
düğmesini tıklayın. - Komut satırından
flutter run
komutunu çalıştırın.
Bu sayfadaki resme benzer şekilde, Avustralya'nın doğu kıyısında Sidney'i merkezine alan bir harita görmeniz gerekir.
Sorun giderme
- Harita görmüyorsanız API anahtarı aldığınızdan ve bunu uygulamaya eklediğinizden emin olun.
- API anahtarını kısıtlamak için iOS paket tanımlayıcısını kullandıysanız anahtarı düzenleyerek uygulamaya paket tanımlayıcıyı ekleyin:
com.google.examples.map-with-marker
. - İyi bir kablosuz veya GPS bağlantınız olduğundan emin olun.
- Günlükleri görüntülemek ve uygulamada hata ayıklamak için Flutter DevTools'u kullanın.
- Flutter uygulaması çalıştırma hakkında daha fazla bilgi edinebilirsiniz.
4. Kodu anlama
Bu kodu GitHub'da bulabilirsiniz.
- Gerekli paketleri içe aktarın ve uygulamayı başlatın.
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(); }
- Avustralya'nın Sidney şehrini merkezine alan bir harita oluştur.
class _MyAppState extends State<MyApp> { late GoogleMapController mapController; final LatLng _center = const LatLng(-33.86, 151.20); void _onMapCreated(GoogleMapController controller) { mapController = controller; }
- Uygulamada harita göstermek için gereken widget'ları ekleyin.
@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 } }
- Widget'ı uygulamanıza eklemek için işaretçi widget'larını ekleyin.
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 ...
- İşarete bir bilgi penceresi ekleyin.
Varsayılan olarak, kullanıcı bir işaretçiye dokunduğunda Flutter için Google Haritalar paketi bilgi penceresinin içeriğini gösterir. Varsayılan davranışı kullanmaktan memnunsanız işaretçi için tıklama işleyici eklemeniz gerekmez.const Marker( markerId: const MarkerId("Sydney"), position: LatLng(-33.86, 151.20), infoWindow: InfoWindow( title: "Sydney", snippet: "Capital of New South Wales", ), // InfoWindow ), //Marker ...
Tebrikler! Belirli bir konumu belirtmek için işaretçi içeren ve bilgi penceresinde ek bilgiler sağlayan bir Google Haritası gösteren bir Flutter uygulaması oluşturdunuz. Ayrıca, Flutter için Google Haritalar paketini nasıl kullanacağınızı da öğrendiniz.