質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
Flutter

Flutterは、iOSとAndroidのアプリを同じコードで開発するためのフレームワークです。オープンソースで開発言語はDart。双方のプラットフォームにおける高度な実行パフォーマンスと開発効率を提供することを目的としています。

Google マップ

Google Mapは、Google社がオンラインで提供している地図・ローカル検索サービスです。GIS(Geographic Information System:地理情報システム)の中の「WebGIS」に該当します。地図・航空写真・地形の表示方式があり、それぞれユーザーが縮尺を調整して表示させることができます。地域の情報サービスを検索する機能やルート検索の機能も搭載されています。

Q&A

解決済

2回答

3944閲覧

Flutter GoogleMapで最初に描画されるページを現在地にする

t-sakurai816

総合スコア5

Flutter

Flutterは、iOSとAndroidのアプリを同じコードで開発するためのフレームワークです。オープンソースで開発言語はDart。双方のプラットフォームにおける高度な実行パフォーマンスと開発効率を提供することを目的としています。

Google マップ

Google Mapは、Google社がオンラインで提供している地図・ローカル検索サービスです。GIS(Geographic Information System:地理情報システム)の中の「WebGIS」に該当します。地図・航空写真・地形の表示方式があり、それぞれユーザーが縮尺を調整して表示させることができます。地域の情報サービスを検索する機能やルート検索の機能も搭載されています。

0グッド

0クリップ

投稿2021/07/12 07:40

前提・実現したいこと

FlutterにてGoogleMapを表示するアプリを作成しています。
画面起動時に表示される地点をユーザーの現在地にしたいと考えています。

下記のパッケージを利用しています

google_maps_flutter: ^2.0.6 geolocator: ^7.2.0+1

発生している問題・エラーメッセージ

ユーザーの現在地を取得するために、static LatLng _initialPositionを最初に定義していますが、そこで下記のエラーが出ています。

The non-nullable variable '_initialPosition' must be initialized. Try adding an initializer expression.

lateをつけると解決するというような情報を得たのでstatic late LatLng _initialPosition;のようにすると、VScode上ではエラーは出なくなりますが、ビルドしたときに下記のエラーが出ます

例外が発生しました LateError (LateInitializationError: Field '_initialPosition@<ここになにかの数字が入っている>' has not been initialized.)

またこのエラーに関してはブレークポイントをつけないと、iPhone上に一瞬だけ表示され、その後消えて現在地でマップが起動するようになっています。

該当のソースコード

一部_createMarker()など本質問を関係ない箇所は削除しています。

dart

1import 'package:flutter/material.dart'; 2import 'package:google_maps_flutter/google_maps_flutter.dart'; 3import 'dart:async'; 4import 'package:material_floating_search_bar/material_floating_search_bar.dart'; 5import 'package:geolocator/geolocator.dart'; 6 7class MapBody extends StatefulWidget { 8 9 _MapBody createState() => _MapBody(); 10} 11 12class _MapBody extends State<MapBody> { 13 Completer<GoogleMapController> _controller = Completer(); 14 static LatLng _initialPosition; 15 16 17 void initState() { 18 super.initState(); 19 _getUserLocation(); 20 } 21 22 void _getUserLocation() async { 23 Position position = await Geolocator.getCurrentPosition( 24 desiredAccuracy: LocationAccuracy.high); 25 setState(() { 26 _initialPosition = LatLng(position.latitude, position.longitude); 27 print(position); 28 }); 29 } 30 31// static final CameraPosition _kGooglePlex = CameraPosition( 32// target: LatLng(35.6809591, 139.7673068), 33// zoom: 14.4746, 34// ); 35 36 37 Widget build(BuildContext context) { 38 return Scaffold( 39 body: SafeArea( 40 child: Stack( 41 fit: StackFit.expand, 42 children: [ 43 GoogleMap( 44 initialCameraPosition: CameraPosition( 45 target: _initialPosition, 46 zoom: 14.4746, 47 ), 48 onMapCreated: (GoogleMapController controller) { 49 _controller.complete(controller); 50 }, 51 markers: _createMarker(), 52 myLocationEnabled: true, 53 myLocationButtonEnabled: true, 54 mapToolbarEnabled: false, 55 buildingsEnabled: true, 56 onTap: (LatLng latLang) { 57 print('Clicked: $latLang'); 58 }, 59 ), 60 buildFloatingSearchBar(), 61 ], 62 ), 63 ), 64 ); 65 }

試したこと

  • static LatLng _initialPosition;が定義されていないということが原因だと考え、適当に東京駅の座標を入れて見ましたが、そうすると端末の現在地ではなく、東京駅が表示されてしまいました。
  • static late LatLng _initialPosition;にしてみましたが、下記エラーが出てしまいました。
例外が発生しました LateError (LateInitializationError: Field '_initialPosition@<ここになにかの数字が入っている>' has not been initialized.)

補足情報(FW/ツールのバージョンなど)

flutter --version Flutter 2.2.1 • channel stable • https://github.com/flutter/flutter.git Framework • revision 02c026b03c (7 weeks ago) • 2021-05-27 12:24:44 -0700 Engine • revision 0fdb562ac8 Tools • Dart 2.13.1
geolocator: ^7.2.0+1 google_maps_flutter: ^2.0.6

参考にしたページは下記です。
Flutter Google Maps not determining current location of device

このころとは変わり、null safetyへの対応で変わってしまったと考えています。

以上、よろしくお願いいたします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

ベストアンサー

画面のデータを準備し終わる前に表示に入っている為だと思われます。
一旦これを試してみてはどうでしょう。

dart

1bool _loading; 2 3 void initState() { 4 super.initState(); 5 _loading = true; 6 _getUserLocation(); 7} 8 9void _getUserLocation() async { 10 Position position = await Geolocator.getCurrentPosition( 11 desiredAccuracy: LocationAccuracy.high); 12 _initialPosition = LatLng(position.latitude, position.longitude); 13 setState(() { 14 _loading = false; 15 }); 16} 17 18 19 Widget build(BuildContext context) { 20 return Scaffold( 21 body: _loading 22 ?CircularProgressIndicator() 23 :SafeArea( 24 child: Stack( 25 fit: StackFit.expand, 26 children: [ 27 GoogleMap( 28 initialCameraPosition: CameraPosition( 29 target: _initialPosition, 30 zoom: 14.4746, 31 ), 32 onMapCreated: (GoogleMapController controller) { 33 _controller.complete(controller); 34 }, 35 markers: _createMarker(), 36 myLocationEnabled: true, 37 myLocationButtonEnabled: true, 38 mapToolbarEnabled: false, 39 buildingsEnabled: true, 40 onTap: (LatLng latLang) { 41 print('Clicked: $latLang'); 42 }, 43 ), 44 buildFloatingSearchBar(), 45 ], 46 ), 47 ), 48 ); 49 }

追記 コードを書くところにコードを入れました。

投稿2021/07/12 10:01

編集2021/07/13 03:16
endiv

総合スコア161

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

t-sakurai816

2021/07/12 10:13

ご回答ありがとうございます! 試したところ、`bool _loading;`の箇所でエラーが出ていたので、`late bool _loading;`としたところ、解決できました!!ありがとうございます! > 画面のデータを準備し終わる前に表示に入っている為だと思われます。 こちらが原因だと思われます。ありがとうございます!
guest

0

_initialPosition変数がクラスメンバー(static)になっているため出たエラーだと思います。
インスタンスメンバーにしてみてください。

dart

1class _MapBody extends State<MapBody> { 2 Completer<GoogleMapController> _controller = Completer(); 3 // ↓ static 削除、late 追加 4 late LatLng _initialPosition; 5 6 7 void initState() { 8 super.initState(); 9 _getUserLocation(); 10 } 11 12 void _getUserLocation() async { 13 Position position = await Geolocator.getCurrentPosition( 14 desiredAccuracy: LocationAccuracy.high); 15 setState(() { 16 _initialPosition = LatLng(position.latitude, position.longitude); 17 print(position); 18 }); 19 }

投稿2021/07/12 09:44

退会済みユーザー

退会済みユーザー

総合スコア0

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

t-sakurai816

2021/07/12 10:06

ご回答ありがとうございます。 試してみましたが、同じような下記エラーが出てしまいます ``` LateError (LateInitializationError: Field '_initialPosition@数字' has not been initialized.) ```
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問