如何修复 flutter_google_places_autocomplete.dart 的错误?

Posted

技术标签:

【中文标题】如何修复 flutter_google_places_autocomplete.dart 的错误?【英文标题】:How to fix error with flutter_google_places_autocomplete.dart? 【发布时间】:2019-11-13 11:45:27 【问题描述】:

我用谷歌地图制作了一个应用程序,您可以在其中找到一个地方并在地图上建立一条通往它的路径。我想根据用户键入的内容在其下方显示地点和地址。显示结果后,我需要获取其经纬度以在地图上标记。

我尝试使用flutter_google_places: 0.2.3,但未定义函数(GoogleMapsPlaces、Prediction)。接下来我使用了flutter_google_places_autocomplete: 0.1.3,一切都很好。不幸的是,当我尝试运行该项目时出现错误:

编译器消息: file:///C:/Users/admin/AppData/Roaming/Pub/Cache/hosted/pub.dartlang.org/flutter_google_places_autocomplete-0.1.3/lib/src/flutter_google_places_autocomplete.dart:337:35: 错误:位置参数太多:允许 0 个,但找到了 1 个。尝试 删除额外的位置参数。 _places = new GoogleMapsPlaces(widget.apiKey); ^ file:///C:/Users/admin/AppData/Roaming/Pub/Cache/hosted/pub.dartlang.org/google_maps_webservice-0.0.14/lib/src/places.dart:22:3: 上下文:找到了这个候选人,但参数不匹配。 GoogleMapsPlaces( ^ 编译器失败 C:\Users\admin\androidStudioProjects\advertise_me\lib\main.dart

FAILURE:构建失败并出现异常。

其中:脚本 'C:\Users\admin\flutter\packages\flutter_tools\gradle\flutter.gradle' 行:647

出了什么问题:任务 ':app:compileflutterBuildDebugandroid-arm64' 执行失败。

Process 'command 'C:\Users\admin\flutter\bin\flutter.bat'' 以非零退出值 1 结束

尝试:使用 --stacktrace 选项运行以获取堆栈跟踪。使用 --info 或 --debug 选项运行以获得更多日志输出。运行 --scan 以获得完整的见解。

通过https://help.gradle.org获得更多帮助

BUILD FAILED in 9s Finished with error: Gradle task assembleDebug 退出代码 1 失败

我的 pubspes.yaml:

依赖关系:颤动: sdk:颤动

cupertino_icons: ^0.1.2 url_launcher: ^4.2.0+1 google_maps_flutter:bottom_sheet_stateful:^0.1.1 flutter_google_places_autocomplete:0.1.3 地理编码器:0.1.2 google_maps_webservice:0.0.14

我的代码:

import 'package:flutter/material.dart';
import 'package:advertise_me/login_screen.dart';
import 'dart:async';
import 'package:google_maps_webservice/geocoding.dart';
//import 'package:flutter_google_places/flutter_google_places.dart';
import 'package:flutter_google_places_autocomplete/flutter_google_places_autocomplete.dart';
import 'package:geocoder/geocoder.dart';


void main() => runApp(MyApp());

const kGoogleApiKey = "My key";


GoogleMapsPlaces _places = GoogleMapsPlaces(apiKey: kGoogleApiKey);

class MyApp extends StatelessWidget 
  @override
  Widget build(BuildContext context) 
    return MaterialApp(
      home: Scaffold(
        body: demo(),
      ),
    );
  


class demo extends StatefulWidget 
  @override
  demoState createState() => new demoState();


class demoState extends State<demo> 
  @override
  Widget build(BuildContext context) 

    return Scaffold(
        body: Container(
            alignment: Alignment.center,
            child: RaisedButton(
              onPressed: () async 
                Prediction p = await showGooglePlacesAutocomplete(
                    context: context, apiKey: kGoogleApiKey);
                displayPrediction(p);
              ,
              child: Text('Find address'),

            )
        )
    );
  

  Future<Null> displayPrediction(Prediction p) async 
    if (p != null) 
      PlacesDetailsResponse detail =
      await _places.getDetailsByPlaceId(p.placeId);

      var placeId = p.placeId;
      double lat = detail.result.geometry.location.lat;
      double lng = detail.result.geometry.location.lng;

      var address = await Geocoder.local.findAddressesFromQuery(p.description);

      print(lat);
      print(lng);
    
  

我该如何解决这个错误? 非常感谢任何帮助。

【问题讨论】:

【参考方案1】:

flutter_google_places_autocomplete 已弃用,您应该改用flutter_google_places。请参阅文档:https://pub.dev/packages/flutter_google_places_autocomplete

一旦你使用flutter_google_places,就使用

Prediction p = await PlacesAutoComplete.show() 而不是showGooglePlacesAutoComplete()

======= 更新答案 =====

import 'package:flutter/material.dart';
//import 'package:advertise_me/login_screen.dart';
import 'dart:async';
import 'package:flutter_google_places/flutter_google_places.dart';
import 'package:geocoder/geocoder.dart';
import 'package:google_maps_webservice/places.dart';


void main() => runApp(MyApp());

const kGoogleApiKey = "My key";


GoogleMapsPlaces _places = GoogleMapsPlaces(apiKey: kGoogleApiKey);

class MyApp extends StatelessWidget 
  @override
  Widget build(BuildContext context) 
    return MaterialApp(
      home: Scaffold(
        body: demo(),
      ),
    );
  


class demo extends StatefulWidget 
  @override
  demoState createState() => new demoState();


class demoState extends State<demo> 
  @override
  Widget build(BuildContext context) 

    return Scaffold(
        body: Container(
            alignment: Alignment.center,
            child: RaisedButton(
              onPressed: () async 
                Prediction p = await PlacesAutocomplete.show(
                    context: context, apiKey: kGoogleApiKey);
                displayPrediction(p);
              ,
              child: Text('Find address'),

            )
        )
    );
  

  Future<Null> displayPrediction(Prediction p) async 
    if (p != null) 
      PlacesDetailsResponse detail =
      await _places.getDetailsByPlaceId(p.placeId);

      var placeId = p.placeId;
      double lat = detail.result.geometry.location.lat;
      double lng = detail.result.geometry.location.lng;

      var address = await Geocoder.local.findAddressesFromQuery(p.description);

      print(lat);
      print(lng);
    
  

【讨论】:

感谢您的回答。我很不专心。但是,在我导入 flutter_google_places: 0.2.3 后出现错误(未定义类“GoogleMapsPlaces”。未定义函数“GoogleMapsPlaces”。未定义类“预测”。未定义类“预测”。未定义类“PlacesDetailsResponse”。)。你能帮我解决这些问题吗?或者我应该在另一个问题中问这个吗? 那是因为您的代码缺少正确的导入。为了使用GoogleMapsPlacesPredictionPlacesDetailsResponse,您需要导入package:google_maps_webservice/places.dart。我用工作代码更新了我的答案。这应该可以解决您面临的问题。 谢谢,我意识到我必须导入:google_maps_webservice/places。你能告诉我为什么 Unhandled Exception: NoSuchMethodError: The getter 'geometry' was called on null。我认为这是预测 p = null,但为什么会发生这种情况?我选择了这个地方还是我做错了什么?如果是真的,我怎样才能得到用户点击的位置? 可能是由于为您的项目配置了 google api。检查该功能是否已启用并按照 api 密钥的预期工作。请参阅针对插件发布的此问题:github.com/fluttercommunity/flutter_google_places/issues/51 另外,我认为您最初发布问题的原始问题已经解决。如果是这样,您可以接受我的回答让其他人也知道:-)【参考方案2】:

使用 import 'package:google_maps_webservice/places.dart'; 和 import 'package:flutter_google_places/flutter_google_places.dart';

【讨论】:

【参考方案3】:

使用完整的函数参数列表,例如:

Prediction p = await PlacesAutocomplete.show( offset: 0, radius: 1000, types: [], strictbounds: false,
region: "ar", context: context, apiKey: googleAPIKey, mode: Mode.overlay, language: "es", components: [Component(Component.country, "ar")] );

【讨论】:

以上是关于如何修复 flutter_google_places_autocomplete.dart 的错误?的主要内容,如果未能解决你的问题,请参考以下文章

如何修复drv?

如何修复漏洞

如何修复WMI

PHP网站漏洞怎么修复 如何修补网站程序代码漏洞

如何修复这些漏洞? (npm audit fix 无法修复这些漏洞)

如何修复AppScan漏洞