- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 GWT(2.61 版)和 gwt-maps(3.8.0 版)努力通过 GWT 显示 Google map 。
基础似乎可行,但现在我正在尝试运行 gwt-maps zip 附带的 CitySimple 示例。 Here它是直接使用 JavaScript,但我正在尝试通过 GWT 来完成。
但是,当我运行示例时,启动时出现以下错误:
com.google.gwt.core.client.JavaScriptException: (InvalidValueError) @com.google.maps.gwt.client.Circle::create(Lcom/google/maps/gwt/client/CircleOptions;)([JavaScript object(17)]): setCenter: not a LatLng or LatLngLiteral: in property lat: not a number
at com.google.gwt.dev.shell.BrowserChannelServer.invokeJavascript(BrowserChannelServer.java:249)
at com.google.gwt.dev.shell.ModuleSpaceOOPHM.doInvoke(ModuleSpaceOOPHM.java:136)
at com.google.gwt.dev.shell.ModuleSpace.invokeNative(ModuleSpace.java:576)
at com.google.gwt.dev.shell.ModuleSpace.invokeNativeObject(ModuleSpace.java:284)
at com.google.gwt.dev.shell.JavaScriptHost.invokeNativeObject(JavaScriptHost.java:91)
at com.google.maps.gwt.client.Circle$.create(Circle.java)
at com.test.client.GwtTest.renderMap(GwtTest.java:80)
map 出现了,但是没有一个城市圈出现。它似乎相信我的 LatLng 类型中的经纬度值不是数字,这在 GWT 中是不可能的,因为 Java 只会采用 double 值。
这是我正在运行的 GWT 代码:
package com.test.client;
import java.util.HashMap;
import com.google.gwt.ajaxloader.client.AjaxLoader;
import com.google.gwt.ajaxloader.client.AjaxLoader.AjaxLoaderOptions;
import com.google.gwt.core.client.EntryPoint;
import com.google.gwt.dom.client.Document;
import com.google.maps.gwt.client.Circle;
import com.google.maps.gwt.client.CircleOptions;
import com.google.maps.gwt.client.GoogleMap;
import com.google.maps.gwt.client.LatLng;
import com.google.maps.gwt.client.MapOptions;
import com.google.maps.gwt.client.MapTypeId;
public class GwtTest implements EntryPoint {
static class City {
LatLng center;
Long population;
City(LatLng center, Long population) {
this.center = center;
this.population = population;
}
}
private static java.util.Map<String, City> citymap = new HashMap<String, City>();
static {
citymap.put("Chicago", new City(LatLng.create(41.878113, -87.629798), 2842518L));
citymap.put("New York", new City(LatLng.create(40.714352, -74.005973), 8143197L));
citymap.put("Los Angeles", new City(LatLng.create(34.052234, -118.243684), 3844829L));
}
@Override
public void onModuleLoad() {
AjaxLoaderOptions options = AjaxLoaderOptions.newInstance();
options.setOtherParms("sensor=false");
Runnable callback = new Runnable() {
public void run() {
renderMap();
}
};
AjaxLoader.loadApi("maps", "3", callback, options);
}
public static void renderMap() {
MapOptions mapOpts = MapOptions.create();
mapOpts.setZoom(4);
mapOpts.setCenter(LatLng.create(37.09024, -95.712891));
mapOpts.setMapTypeId(MapTypeId.TERRAIN);
GoogleMap map = GoogleMap.create(Document.get().getElementById("map_canvas"), mapOpts);
for (String cityName : citymap.keySet()) {
System.out.println("City: " + cityName);
City city = citymap.get(cityName);
// Construct the circle for each value in citymap. Scale population by 20.
CircleOptions populationOptions = CircleOptions.create();
populationOptions.setStrokeColor("#ff0000");
populationOptions.setStrokeOpacity(0.8);
populationOptions.setStrokeWeight(2);
populationOptions.setFillColor("#ff0000");
populationOptions.setFillOpacity(0.35);
populationOptions.setMap(map);
System.out.println("Lat: " + city.center.lat());
System.out.println("Lng: " + city.center.lng());
populationOptions.setCenter(city.center);
populationOptions.setRadius(city.population / 20);
Circle.create(populationOptions);
}
}
}
如您所见,所有 LatLng 值都有其纬度和经度的数字,因此这个错误对我来说没有任何意义。
为了完整起见,这是我的 html 文件:
<!doctype html>
<html>
<head>
<meta http-equiv="content-type" content="text/html; charset=UTF-8">
<link type="text/css" rel="stylesheet" href="GwtTest.css">
<title>GWT Test</title>
<script type="text/javascript" src="http://maps.googleapis.com/maps/api/js?sensor=false"></script>
<script type="text/javascript" language="javascript"
src="gwttest/gwttest.nocache.js"></script>
</head>
<body>
<p>Testing</p>
<div style="width:500px; height:500px">
<div id="map_canvas" style="width: 100%; height: 100%;">Map is loading...</div>
</div>
</body>
</html>
这是我的 GWT 模块 xml 文件:
<?xml version="1.0" encoding="UTF-8"?>
<!--
When updating your version of GWT, you should also update this DTD reference,
so that your app can take advantage of the latest GWT module capabilities.
-->
<!DOCTYPE module PUBLIC "-//Google Inc.//DTD Google Web Toolkit 2.6.1//EN"
"file:///C:/Users/kworkman/Desktop/gwt-2.6.1/gwt-module.dtd">
<module rename-to='gwttest'>
<!-- Inherit the core Web Toolkit stuff. -->
<inherits name='com.google.gwt.user.User'/>
<inherits name="com.google.maps.gwt.GoogleMaps" />
<inherits name="com.google.gwt.ajaxloader.AjaxLoader" />
<!-- Inherit the default GWT style sheet. You can change -->
<!-- the theme of your GWT application by uncommenting -->
<!-- any one of the following lines. -->
<inherits name='com.google.gwt.user.theme.clean.Clean'/>
<!-- <inherits name='com.google.gwt.user.theme.standard.Standard'/> -->
<!-- <inherits name='com.google.gwt.user.theme.chrome.Chrome'/> -->
<!-- <inherits name='com.google.gwt.user.theme.dark.Dark'/> -->
<!-- Other module inherits -->
<!-- Specify the app entry point class. -->
<entry-point class='com.test.client.GwtTest'/>
<!-- Specify the paths for translatable code -->
<source path='client'/>
<source path='shared'/>
<!-- allow Super Dev Mode -->
<add-linker name="xsiframe"/>
</module>
有人能看出我做错了什么吗?我对 GWT 还是全新的,所以如果我做了一些愚蠢的事情我不会感到震惊,但这个错误似乎直接与代码相矛盾,所以我有点不知所措。
我用谷歌搜索了这个错误,但我看到的每个问题都是由于人们将字符串而不是数字传递给 LatLng 类型引起的,而我没有这样做。
最佳答案
我认为您使用 LatLng 类型的代码是在加载 api 之前执行的。在 api 完全加载后尝试初始化您的 citymap 对象:
Runnable callback = new Runnable() {
public void run() {
citymap.put("Chicago", new City(LatLng.create(41.878113, -87.629798), 2842518L));
citymap.put("New York", new City(LatLng.create(40.714352, -74.005973), 8143197L));
citymap.put("Los Angeles", new City(LatLng.create(34.052234, -118.243684), 3844829L));
renderMap();
}
};
这是因为 LatLng 对象属于 JavaScriptObject 类型,并且将使用 api 中的 javascript 函数。
另请参阅我关于您两次加载 api 的评论。
关于java - GWT 谷歌地图 : setCenter: not a LatLng or LatLngLiteral: in property lat: not a number,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26283525/
我必须用小工具制作 map ,这些小工具从上一点获得电压。我的数据库中有纬度和经度的记录。我使用自定义图标和 windowInfo 在 map 上存储带有标记的小工具,但我想获取上一个点的纬度和经度,
我的任务是查找两个纬度和经度坐标之间的行驶距离。我在[此处][1]找到了此链接,但是,我不确定我是否正确实现了它,因为我收到了错误...... Invalid float: "" GeocodingL
我一直致力于 Android 中的 Google map 服务。我想知道是否有一个实用方法可以给出 LatLng 的方向关于另一个。 我想知道一个点是否在 南还是北 东方还是西方 或两者的组合,各取其
LATLNG 无法将参数类型“LatLng”分配给参数类型“LatLng” The argument type 'LatLng (where LatLng is defined in E:\flutt
目标 知道一个坐标点是否在另外两个坐标之间。 背景 我正在制作一个谷歌地图应用程序,我需要知道某个点是否在两个 LatLng 点(起点和终点)之间。 我正在寻找如下函数: var currentCoo
在行“Location.distanceBetween(LatLng.latitude, LatLng.longitude, circle.getCenter().latitude,circle.ge
我可以使用什么算法/公式来计算距离另一个 LatLng 点 5 米的 LatLng 点?我正在尝试编写一个带有 2 个 LatLng 参数的函数,并让它返回一个 LatLng,该 LatLng 距离第
使用文档示例,我尝试放大特定点。所以我这样做: var latlng = L.latLng(50.5, 30.5); $scope.map.setZoomAround(latlng); $scope.
我有 2 个列表。 double pointY[]={105.45526,105.57364,105.53505,105.45523,105.51962,105.77320} double point
假设我有一个关联的纬度/经度 + 名称的 HashMap,以及一个相同纬度/经度的单独 ArrayList,这些纬度/经度已按距离我当前位置最近的位置排序。如何将 HashMap 排序为与 Array
我需要查明某些 LatLng 是否在 Google map 圈内(其中之一:http://code.google.com/apis/maps/documentation/javascript/over
我正在尝试在当前位置设置标记,因此我尝试将 Location 转换为 LatLng 类: LatLng mCurrentPlace= new LatLng(location.getLatitude()
我正在 Flutter 中使用 Leaflet 完成我的第一个婴儿步骤,因此欢迎耐心和教程 URL 等。 我能找到的每一段示例代码都给了我这个错误: The method 'LatLng' isn't
因此,我开始在我的小应用程序中建立并运行我的 map ,当我尝试放入相机移动时,我遇到了一些小障碍。编译器似乎根本不喜欢 LatLng 类。它给了我这个。 The method LatLng(doub
我正在从 MainActivity 向名为 MapClass 的类发送 IntentService 调用。 MapClass 有一个名为 MapClassInner 的内部类,它计算用户的当前坐标。但
我创建了一个函数来返回纬度和经度。 问题是 alert('outside:') 在 geocoder.geocode 之前触发。 查看this similar example ,这个功能应该工作。
在我更改包名称之前,一切都在我的设备上正常工作...一旦更改 pkg,相机就不会移动到初始 latlng。此外,标记不会显示。 package com.vaishnavismeclass.divyad
我有List有位置(超过 2000 个位置)。每个位置有 100 米的距离。但是列表太大所以我想根据位置优先级过滤一些位置(比如访问最多的位置、著名位置、实体名称、城市名称或其他) 实际上,当用户移动
我在使用 latlng 变量在 Leaflet map 上创建新圆时遇到问题。 我有一个包含和输入半径的表单和一个包含几个位置的选择框,选项如下所示: Place Name 单击保存按钮时,将运行以下
我想在 touchmove 事件(传单 map )中获取触摸点的 LatLng。我没有找到解决这个问题的方法。有什么方法可以获取坐标吗? $(document).on('touchmove', '#m
我是一名优秀的程序员,十分优秀!