examples フォルダにある「OpenLayers Modify Feature Example(modify-feature.html)」を参考に マウスで移動してみます。
「ol014-nippon_bmi_akiruno_pgis.html」 ファイルを続けて使います。
a メニューの「ファイル」->「開く」をクリックします。
b 「ファイルを開く」ウィンドウで、「OpenLayers-2.13.1」->「examples」->「modify-feature.html」をクリックして選択し、「OK」ボタンをクリックします。
c 次のように「modify-feature.html」の内容の一部をコピーして「ol014-nippon_bmi_akiruno_pgis.html」に貼り付け、修正します。
---
<link rel="stylesheet" href="OpenLayers-2.13.1/theme/default/style.css" type="text/css"> <link rel="stylesheet" href="OpenLayers-2.13.1/examples/style.css" type="text/css">
<style type="text/css"> /* ここから追加 */ #controls { width: 512px; } #controlToggle { padding-left: 1em; } /* ここまで */ #controlToggle li { list-style: none; } p { width: 512px; } /* avoid pink tiles */ .olImageLoadError { background-color: transparent !important; } </style>
<title>WMS Example BMI Akiruno PGIS2</title>---
map.addLayers([layer0, layer3, layer1, layer2, layer4, vectors]);
// ここから追加 if (console && console.log) { function report(event) { console.log(event.type, event.feature ? event.feature.id : event.components); } vectors.events.on({ "beforefeaturemodified": report, "featuremodified": report, "afterfeaturemodified": report, "vertexmodified": report, "sketchmodified": report, "sketchstarted": report, "sketchcomplete": report }); } // ここまで
drawControls = { polygon: new OpenLayers.Control.DrawFeature( vectors, OpenLayers.Handler.Polygon), drag1: new OpenLayers.Control.DragFeature( // "drag" を "drag1" に修正 vectors, { onStart: startDrag, onDrag: doDrag, onComplete: endDrag } ), modify: new OpenLayers.Control.ModifyFeature(vectors), // 追加 select: new OpenLayers.Control.SelectFeature( vectors,---
function update() { var clickout = document.getElementById("clickout").checked; if(clickout != drawControls.select.clickout) { drawControls.select.clickout = clickout; }
// ここから追加 "controls" を "drawControls" に修正 // reset modification mode drawControls.modify.mode = OpenLayers.Control.ModifyFeature.RESHAPE; var rotate = document.getElementById("rotate").checked; if(rotate) { drawControls.modify.mode |= OpenLayers.Control.ModifyFeature.ROTATE; }
var resize = document.getElementById("resize").checked; if(resize) { drawControls.modify.mode |= OpenLayers.Control.ModifyFeature.RESIZE; var keepAspectRatio = document.getElementById("keepAspectRatio").checked; if (keepAspectRatio) { drawControls.modify.mode &= ~OpenLayers.Control.ModifyFeature.RESHAPE; } }
var drag = document.getElementById("drag").checked; if(drag) { drawControls.modify.mode |= OpenLayers.Control.ModifyFeature.DRAG; }
if (rotate || drag) { drawControls.modify.mode &= ~OpenLayers.Control.ModifyFeature.RESHAPE; }
drawControls.modify.createVertices = document.getElementById("createVertices").checked; var sides = parseInt(document.getElementById("sides").value); sides = Math.max(3, isNaN(sides) ? 0 : sides); drawControls.regular.handler.sides = sides; var irregular = document.getElementById("irregular").checked; drawControls.regular.handler.irregular = irregular; // ここまで
var box = document.getElementById("box").checked; if(box != drawControls.select.box) { drawControls.select.box = box; if(drawControls.select.active) { drawControls.select.deactivate(); drawControls.select.activate(); } } }
</script> </head> <body onload="init()">---
<div id="controls"> <!-- 追加 --> <ul id="controlToggle">---
<!-- "drag" を "drag1" に修正 --> <li> <input type="radio" name="type" value="drag1" id="dragToggle" onclick="toggleControl(this);" /> <label for="dragToggle">drag feature</label> </li>---
<!-- ここから追加 --> <li> <input type="radio" name="type" value="modify" id="modifyToggle" onclick="toggleControl(this);" /> <label for="modifyToggle">modify feature</label> <ul> <li> <input id="createVertices" type="checkbox" checked name="createVertices" onchange="update()" /> <label for="createVertices">allow vertices creation</label> </li> <li> <input id="rotate" type="checkbox" name="rotate" onchange="update()" /> <label for="rotate">allow rotation</label> </li> <li> <input id="resize" type="checkbox" name="resize" onchange="update()" /> <label for="resize">allow resizing</label> (<input id="keepAspectRatio" type="checkbox" name="keepAspectRatio" onchange="update()" checked="checked" /> <label for="keepAspectRatio">keep aspect ratio</label>) </li> <li> <input id="drag" type="checkbox" name="drag" onchange="update()" /> <label for="drag">allow dragging</label> </li> </ul> </li> <!-- ここまで -->
</ul> </div> <!-- 追加 --> </body> </html>modify feature
allow vertices creation: 角数を増やす(他のオプションと同時に動作しません)
allow rotation: 点をドラッグして回転させる
allow resizing: 点をドラッグして大きさを変える
(keep aspect ratio: 比率を変えない)
allow dragging: 点をドラッグして移動させる
(このドラッグでは複数のフィーチャを同時に移動する方法が見つかりませんでした。)
0 件のコメント:
コメントを投稿