- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在多边形形状中,需要在末尾重复起点,才能得到GeoJSON以下数组:
{
"type": "Polygon",
"coordinates": [
[
[15.99609375, 62.0215281910076],
[-9.140625, 51.1793429792893],
[12.12890625, 37.0200982013681],
[44.12109375, 37.7185903255882],
[49.5703125, 59.5343180010956],
[15.99609375, 62.0215281910076]
]
]
}
在我的代码中,我不重复它并从我的 map 中获取:
{
"type": "Polygon",
"coordinates": [
[
[15.99609375, 62.0215281910076],
[-9.140625, 51.1793429792893],
[12.12890625, 37.0200982013681],
[44.12109375, 37.7185903255882],
[49.5703125, 59.5343180010956]
]
]
}
请您告诉我,如何在数组末尾再次添加第一个值 arr[0] ?
for(var i = 0; i < arr.length; i++)
{
shape=arr[i];
tmp=new goo.Polygon({paths:this.mm_(shape.geometry)});
break;
tmp.setValues({map:map,id:shape.id})
shapes.push(tmp);
}
return shapes;
整个代码如下所示:
<script type='text/javascript'>//<![CDATA[
function initialize()
{
var goo = google.maps,
map_in = new goo.Map(document.getElementById('map_in'),
{ zoom: 6,
center: new goo.LatLng(52.344, 18.048)
}),
shapes = [],
selected_shape = null,
// drawman = new goo.drawing.DrawingManager({map:map_in}),
drawman = new google.maps.drawing.DrawingManager({
map: map_in,
drawingMode: goo.drawing.OverlayType.POLYGON,
drawingControl: true,
drawingControlOptions: {
position: goo.ControlPosition.TOP_CENTER,
drawingModes: [goo.drawing.OverlayType.POLYGON]
}
})
byId = function(s){return document.getElementById(s)},
clearSelection = function(){
if(selected_shape){
selected_shape.set((selected_shape.type
===
google.maps.drawing.OverlayType.MARKER
)?'draggable':'editable',false);
selected_shape = null;
}
},
setSelection = function(shape){
clearSelection();
selected_shape=shape;
selected_shape.set((selected_shape.type
===
google.maps.drawing.OverlayType.MARKER
)?'draggable':'editable',true);
},
clearShapes = function(){
for(var i=0;i<shapes.length;++i){
shapes[i].setMap(null);
}
shapes=[];
};
// map_in.bindTo('center',map_out,'center');
// map_in.bindTo('zoom',map_out,'zoom');
goo.event.addListener(drawman, 'overlaycomplete', function(e) {
var shape = e.overlay;
shape.type = e.type;
goo.event.addListener(shape, 'click', function() {
setSelection(this);
});
setSelection(shape);
shapes.push(shape);
});
goo.event.addListener(map_in, 'click',clearSelection);
goo.event.addDomListener(byId('clear_shapes'), 'click', clearShapes);
goo.event.addListener(drawman, 'overlaycomplete', function(){
var data=IO.IN(shapes,false);byId('data').innerHTML=JSON.stringify(data[0]);});
}
var IO={
//returns array with storable google.maps.Overlay-definitions
IN:function(arr,//array with google.maps.Overlays
encoded//boolean indicating whether pathes should be stored encoded
){
var shapes = [],
goo=google.maps,
shape,tmp;
for(var i = 0; i < arr.length; i++)
{
shape=arr[i];
tmp={type:this.t_(shape.type),id:shape.id||null};
switch(tmp.type){
case 'POLYGON':
tmp.coordinates=this.m_(shape.getPaths(),encoded);
break;
}
shapes.push(tmp);
}
return shapes;
},
//returns array with google.maps.Overlays
OUT:function(arr,//array containg the stored shape-definitions
map//map where to draw the shapes
){
var shapes = [],
goo=google.maps,
map=map||null,
shape,tmp;
for(var i = 0; i < arr.length; i++)
{
shape=arr[i];
tmp=new goo.Polygon({paths:this.mm_(shape.geometry)});
break;
tmp.setValues({map:map,id:shape.id})
shapes.push(tmp);
}
return shapes;
},
l_:function(path,e){
path=(path.getArray)?path.getArray():path;
if(e){
return google.maps.geometry.encoding.encodePath(path);
}else{
var r=[];
for(var i=0;i<path.length;++i){
r.push(this.p_(path[i]));
}
return r;
}
},
ll_:function(path){
if(typeof path==='string'){
return google.maps.geometry.encoding.decodePath(path);
}
else{
var r=[];
for(var i=0;i<path.length;++i){
r.push(this.pp_.apply(this,path[i]));
}
return r;
}
},
m_:function(paths,e){
var r=[];
paths=(paths.getArray)?paths.getArray():paths;
for(var i=0;i<paths.length;++i){
r.push(this.l_(paths[i],e));
}
return r;
},
mm_:function(paths){
var r=[];
for(var i=0;i<paths.length;++i){
r.push(this.ll_.call(this,paths[i]));
}
return r;
},
p_:function(latLng){
return([latLng.lng(),latLng.lat()]);
},
pp_:function(lat,lng){
return new google.maps.LatLng(lng,lat);
},
b_:function(bounds){
return([this.p_(bounds.getSouthWest()),
this.p_(bounds.getNorthEast())]);
},
bb_:function(sw,ne){
return new google.maps.LatLngBounds(this.pp_.apply(this,sw),
this.pp_.apply(this,ne));
},
t_:function(s){
var t=['CIRCLE','MARKER','RECTANGLE','POLYLINE','POLYGON'];
for(var i=0;i<t.length;++i){
if(s===google.maps.drawing.OverlayType[t[i]]){
return t[i];
}
}
}
}
google.maps.event.addDomListener(window, 'load', initialize);
//]]>
</script>
最佳答案
类似这样的吗?
arr.push(arr[0]);
关于javascript - Google Drawing API 多边形数组 javascript,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39436939/
Draw joust是什么游戏 Draw joust是一款voodoo推出的玩家对战类游戏,Draw joust游戏中文版叫做手绘战车游戏。 这次voodoo将该游戏的玩法再度升级,难度也有所提
我在本地托管了 draw.io,我们正在使用它来直观地表示仓库中托盘的位置。问题在于,当你在周围拖动托盘时,你经常会不小心调整它们的大小,这很痛苦。无论如何我可以禁用它或锁定托盘的大小吗? 最佳答案
我想在 draw.io 中格式化一个矩形,这样只有一个边框(左边框)是黑色的,其他边框:顶部、右侧和底部必须保持“清晰”。 我试图找出正确的编码来仅影响这些元素,但似乎您只能使用样式键影响整个边框:i
我的线正在连接,即使我没有将它们设置为多边形。 我的脚本基于 pyshp 包。 我的脚本如下所示: w=Shapefile.Writer() #shapetype 11 is a polylineZ
我在表单值中有一个标题(“cadeau check 50 €”),我想使用 arial.ttf 将其写入背景图像。我的文字是正确的,但对于欧元符号。我有 2 [] 到位。我不知道问题出在哪里。这是 P
我收到上述错误。我需要帮助修复它。我看过this question它似乎对我没有任何帮助,我在与需要它的指令相同的元素上拥有所需的指令。我也不明白为什么我的错误说无法找到指令“绘图”所需的 Contr
我正在使用 VBUC 将 VB6 应用程序迁移到 C#但我得到了这个错误: 无法将类型“System.Drawing.Image”转换为“System.Drawing.Icon”我的代码是:
我有一行代码是从某个地方借来的,Visual Studio 无法解决 Bitmap或 ImageConverter类引用。 我有: using System.Drawing; 代码行是 Image x
我正在尝试将花费很长时间的大型 Lucidchart 图转换为 Draw.io。 Draw.io 推荐 ctr-a、ctr-c、ctr-v,但这似乎不起作用。然而,Draw.io 也隐晦地提到: dr
我想显示一个相对较长的图表。我曾经使用过 javafx Canvas ,但有时会出现缓冲区溢出异常,因为绘制了很多值。我正在寻找一种不同的方法,并找到了一种使用 java.awt.graphics2d
我很困惑 System.Drawing.Image 和 System.Drawing.Bitmap 之间有什么不同 有人可以解释这两种类型之间的主要区别吗? 为什么要使用 System.Drawing
声明了一个位图 private Bitmap img1 = null; private Bitmap img2 = null; 从openFileDialog中选择图像后,图像将被放置。 选定的图
我想遍历 System.Drawing.Color 结构并使用它来初始化笔列表。 我是这样试的,但是字段类型不合适: colorList = new List(); foreach (
System.Drawing.Point 和 System.Drawing.PointF 有什么区别。你能举个这两者之间的例子吗? 提前致谢。 最佳答案 Point 使用整数坐标(int 代表 X 和
我正在为我们公司开发 WinForm 打印应用程序。 打印文档时,我需要获取文档上每个控件的System.Drawing.Color属性,并创建一个System.Drawing.Brush对象来画出来
我正在使用这个从另一个应用程序获取图标: Icon IEIcon = Icon.ExtractAssociatedIcon(@"C:\Program Files\Internet Explorer\
这个问题不太可能帮助任何 future 的访问者;它只与一个小的地理区域、一个特定的时间点或一个非常狭窄的情况有关,这些情况并不普遍适用于互联网的全局受众。为了帮助使这个问题更广泛地适用,visit
在 UIView 子类中,我覆盖了 Draw 子类以绘制一些自定义文本,但文本始终绘制为翻转文本。 这是我正在使用的代码: class TextViewProblem : UIView { publi
我想从 Zotero 导出的嵌套 XML/JSON(嵌套在子集合和集合中的单个项目)以编程方式生成 draw.io map 图。 我已经有了基本的 JSON/XML,可以适应 draw.io 的格式,
1) 重新绘制与绘制 这是一个哲学问题,但是...在不同分辨率下渲染游戏的“正确”或“可接受”的方式是什么(2d,我理解 OGL 视角如何工作...)?我应该为我的图像(如 Android APK)添
我是一名优秀的程序员,十分优秀!