断言失败:第 19 行第 16 行:'latitude != null':不正确。颤动错误
Failed assertion: line 19 pos 16: 'latitude != null': is not true. Flutter Error
我使用 flutter 和 google 地图
地理定位用于显示用户的当前位置
地图加载正确,但在加载之前显示此错误
'package:google_maps_flutter_platform_interface/src/types/location.dart': Failed assertion: line 19 pos 16: 'latitude != null': is not true.
这是我初始化和获取当前位置的代码部分
var lat;
var long;
@override
void initState() {
_child = SpinKitRipple(
itemBuilder: (BuildContext context, int index) {
return DecoratedBox(
decoration: BoxDecoration(
color: index.isEven ? Colors.grey : Color(0xffffb838),
),
);
},
);
getCurrentLocation();
populateClients();
setCustomMapPin();
super.initState();
}
void getCurrentLocation() async {
LocationPermission permission;
permission = await Geolocator.checkPermission();
if (permission == LocationPermission.deniedForever) {
lat=6.9271;long=79.8612;
}
else if (permission == LocationPermission.denied) {
permission = await Geolocator.requestPermission();
if (permission != LocationPermission.whileInUse &&
permission != LocationPermission.always) {
lat=6.9271;long=79.8612;
}
}
else{
Position res = await Geolocator.getCurrentPosition(desiredAccuracy: LocationAccuracy.high); //getCurrentPosition();
lat=res.latitude;long=res.longitude;
}
setState(() {
//position = res;
//lat=6.9271;long=79.8612;
_child = mapWidget();
});
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
iconTheme: IconThemeData(color: Colors.white),
title: Text('Map'),
centerTitle: true,
backgroundColor: Colors.blue,
),
body: mapWidget(),
);
}
Widget mapWidget() {
return Stack(
children: <Widget>[
GoogleMap(
initialCameraPosition: CameraPosition(
target: LatLng(lat,long),//(position.latitude, position.longitude),
zoom: 18,
),
///mapType: MapType.normal,
onMapCreated: (GoogleMapController controller) async{
_controller = controller;
await setMapStyle(controller, context);
},
markers: Set<Marker>.of(markers.values),
compassEnabled: true,
myLocationEnabled: true,
),
SizedBox(
height: 26,
),
],
);
}
}
** 我想在地图正确加载之前显示动画**
无论何时渲染 UI,这取决于等待另一个操作完成,您必须使用 FutureBuilder 小部件。
https://api.flutter.dev/flutter/widgets/FutureBuilder-class.html
为了完成您想要做的事情,您必须用 FutureBuilder 包装您当前的小部件。像这样:
Future<Widget> reloadCurrentLocation;
@override
void initState() {
super.initState();
reloadCurrentLocation = getCurrentLocation();
}
Future<Widget> getCurrentLocation() async {
LocationPermission permission;
permission = await Geolocator.checkPermission();
if (permission == LocationPermission.deniedForever) {
lat=40.7128;long=74.0060;
}
else if (permission == LocationPermission.denied) {
permission = await Geolocator.requestPermission();
if (permission != LocationPermission.whileInUse &&
permission != LocationPermission.always) {
lat=40.7128;long=74.0060;
}
}
else {
Position res = await Geolocator.getCurrentPosition(desiredAccuracy:
LocationAccuracy.high); //getCurrentPosition();
lat=res.latitude;
long=res.longitude;
}
populateClients();
setCustomMapPin();
return _child = mapWidget();
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
iconTheme: IconThemeData(color: Colors.white),
title: Text('Map'),
centerTitle: true,
backgroundColor: Colors.blue,
),
body: mapWidget(),
);
}
Widget mapWidget() {
return FutureBuilder(
future: reloadCurrentLocation,
builder: (context, state) {
if (state.connectionState == ConnectionState.active ||
state.connectionState == ConnectionState.waiting) {
return SpinKitRipple(
itemBuilder: (BuildContext context, int index) {
return DecoratedBox(
decoration: BoxDecoration(
color: index.isEven ? Colors.grey :
Color(0xffffb838),
),
);
},
);
} else {
return Stack(
children: <Widget>[
GoogleMap(
initialCameraPosition: CameraPosition(
target:
LatLng(lat,long),//(position.latitude,
position.longitude),
zoom: 18,
),
///mapType: MapType.normal,
onMapCreated: (GoogleMapController
controller) async{
_controller = controller;
await setMapStyle(controller, context);
},
markers: Set<Marker>.of(markers.values),
compassEnabled: true,
myLocationEnabled: true,
),
SizedBox(
height: 26,
),
],
);
});
}
}
我的情况已经解决了。是的,如果我们使用 FutureBuilder,那是真的。但是,对于像这样的示例,您需要在 getCurrentLocation() 中使用 setState((){})
GoogleMapController map;
Future<GoogleMapController> getCurrentLocation(GoogleMapController controller) async {
map = controller;
setState((){
//your logical function
}
return map;
}
之后我尝试了它,最后它在我的设备上运行了。
我只是添加了这些行....
if (lat != null && lng != null) DisplayMap(lat: lat,lng: lng,) else CupertinoActivityIndicator()
我使用 flutter 和 google 地图
地理定位用于显示用户的当前位置
地图加载正确,但在加载之前显示此错误
'package:google_maps_flutter_platform_interface/src/types/location.dart': Failed assertion: line 19 pos 16: 'latitude != null': is not true.
这是我初始化和获取当前位置的代码部分
var lat;
var long;
@override
void initState() {
_child = SpinKitRipple(
itemBuilder: (BuildContext context, int index) {
return DecoratedBox(
decoration: BoxDecoration(
color: index.isEven ? Colors.grey : Color(0xffffb838),
),
);
},
);
getCurrentLocation();
populateClients();
setCustomMapPin();
super.initState();
}
void getCurrentLocation() async {
LocationPermission permission;
permission = await Geolocator.checkPermission();
if (permission == LocationPermission.deniedForever) {
lat=6.9271;long=79.8612;
}
else if (permission == LocationPermission.denied) {
permission = await Geolocator.requestPermission();
if (permission != LocationPermission.whileInUse &&
permission != LocationPermission.always) {
lat=6.9271;long=79.8612;
}
}
else{
Position res = await Geolocator.getCurrentPosition(desiredAccuracy: LocationAccuracy.high); //getCurrentPosition();
lat=res.latitude;long=res.longitude;
}
setState(() {
//position = res;
//lat=6.9271;long=79.8612;
_child = mapWidget();
});
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
iconTheme: IconThemeData(color: Colors.white),
title: Text('Map'),
centerTitle: true,
backgroundColor: Colors.blue,
),
body: mapWidget(),
);
}
Widget mapWidget() {
return Stack(
children: <Widget>[
GoogleMap(
initialCameraPosition: CameraPosition(
target: LatLng(lat,long),//(position.latitude, position.longitude),
zoom: 18,
),
///mapType: MapType.normal,
onMapCreated: (GoogleMapController controller) async{
_controller = controller;
await setMapStyle(controller, context);
},
markers: Set<Marker>.of(markers.values),
compassEnabled: true,
myLocationEnabled: true,
),
SizedBox(
height: 26,
),
],
);
}
}
** 我想在地图正确加载之前显示动画**
无论何时渲染 UI,这取决于等待另一个操作完成,您必须使用 FutureBuilder 小部件。
https://api.flutter.dev/flutter/widgets/FutureBuilder-class.html
为了完成您想要做的事情,您必须用 FutureBuilder 包装您当前的小部件。像这样:
Future<Widget> reloadCurrentLocation;
@override
void initState() {
super.initState();
reloadCurrentLocation = getCurrentLocation();
}
Future<Widget> getCurrentLocation() async {
LocationPermission permission;
permission = await Geolocator.checkPermission();
if (permission == LocationPermission.deniedForever) {
lat=40.7128;long=74.0060;
}
else if (permission == LocationPermission.denied) {
permission = await Geolocator.requestPermission();
if (permission != LocationPermission.whileInUse &&
permission != LocationPermission.always) {
lat=40.7128;long=74.0060;
}
}
else {
Position res = await Geolocator.getCurrentPosition(desiredAccuracy:
LocationAccuracy.high); //getCurrentPosition();
lat=res.latitude;
long=res.longitude;
}
populateClients();
setCustomMapPin();
return _child = mapWidget();
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
iconTheme: IconThemeData(color: Colors.white),
title: Text('Map'),
centerTitle: true,
backgroundColor: Colors.blue,
),
body: mapWidget(),
);
}
Widget mapWidget() {
return FutureBuilder(
future: reloadCurrentLocation,
builder: (context, state) {
if (state.connectionState == ConnectionState.active ||
state.connectionState == ConnectionState.waiting) {
return SpinKitRipple(
itemBuilder: (BuildContext context, int index) {
return DecoratedBox(
decoration: BoxDecoration(
color: index.isEven ? Colors.grey :
Color(0xffffb838),
),
);
},
);
} else {
return Stack(
children: <Widget>[
GoogleMap(
initialCameraPosition: CameraPosition(
target:
LatLng(lat,long),//(position.latitude,
position.longitude),
zoom: 18,
),
///mapType: MapType.normal,
onMapCreated: (GoogleMapController
controller) async{
_controller = controller;
await setMapStyle(controller, context);
},
markers: Set<Marker>.of(markers.values),
compassEnabled: true,
myLocationEnabled: true,
),
SizedBox(
height: 26,
),
],
);
});
}
}
我的情况已经解决了。是的,如果我们使用 FutureBuilder,那是真的。但是,对于像这样的示例,您需要在 getCurrentLocation() 中使用 setState((){})
GoogleMapController map;
Future<GoogleMapController> getCurrentLocation(GoogleMapController controller) async {
map = controller;
setState((){
//your logical function
}
return map;
}
之后我尝试了它,最后它在我的设备上运行了。
我只是添加了这些行....
if (lat != null && lng != null) DisplayMap(lat: lat,lng: lng,) else CupertinoActivityIndicator()