我正在寻找一个代码,该代码允许使用鼠标绘制多边形并计算表面。 以及选择一个角度并移动它以变换形状。 PS:我设法在不同点之间绘制线并关闭它们以创建多边形。 但是我无法选择要转换多边形的点。
我的问题是:是否有人已经发明了这种轮子?
Cordially。
答案 0 :(得分:2)
是的,您可以使用d3。看到这个相关的小提琴: http://jsfiddle.net/eZQdE/43/
var dragging = false, drawing = false, startPoint;
var svg = d3.select('body').append('svg')
.attr('height', 1000)
.attr('width', 1000);
var points = [], g;
// behaviors
var dragger = d3.behavior.drag()
.on('drag', handleDrag)
.on('dragend', function(d){
dragging = false;
});
svg.on('mouseup', function(){
if(dragging) return;
drawing = true;
startPoint = [d3.mouse(this)[0], d3.mouse(this)[1]];
if(svg.select('g.drawPoly').empty()) g = svg.append('g').attr('class', 'drawPoly');
if(d3.event.target.hasAttribute('is-handle')) {
closePolygon();
return;
};
points.push(d3.mouse(this));
g.select('polyline').remove();
var polyline = g.append('polyline').attr('points', points)
.style('fill', 'none')
.attr('stroke', '#000');
for(var i = 0; i < points.length; i++) {
g.append('circle')
.attr('cx', points[i][0])
.attr('cy', points[i][1])
.attr('r', 4)
.attr('fill', 'yellow')
.attr('stroke', '#000')
.attr('is-handle', 'true')
.style({cursor: 'pointer'});
}
});
function closePolygon() {
svg.select('g.drawPoly').remove();
var g = svg.append('g');
g.append('polygon')
.attr('points', points)
.style('fill', getRandomColor());
for(var i = 0; i < points.length; i++) {
var circle = g.selectAll('circles')
.data([points[i]])
.enter()
.append('circle')
.attr('cx', points[i][0])
.attr('cy', points[i][1])
.attr('r', 4)
.attr('fill', '#FDBC07')
.attr('stroke', '#000')
.attr('is-handle', 'true')
.style({cursor: 'move'})
.call(dragger);
}
points.splice(0);
drawing = false;
}
svg.on('mousemove', function() {
if(!drawing) return;
var g = d3.select('g.drawPoly');
g.select('line').remove();
var line = g.append('line')
.attr('x1', startPoint[0])
.attr('y1', startPoint[1])
.attr('x2', d3.mouse(this)[0] + 2)
.attr('y2', d3.mouse(this)[1])
.attr('stroke', '#53DBF3')
.attr('stroke-width', 1);
})
function handleDrag() {
if(drawing) return;
var dragCircle = d3.select(this), newPoints = [], circle;
dragging = true;
var poly = d3.select(this.parentNode).select('polygon');
var circles = d3.select(this.parentNode).selectAll('circle');
dragCircle
.attr('cx', d3.event.x)
.attr('cy', d3.event.y);
for (var i = 0; i < circles[0].length; i++) {
circle = d3.select(circles[0][i]);
newPoints.push([circle.attr('cx'), circle.attr('cy')]);
}
poly.attr('points', newPoints);
}
function getRandomColor() {
var letters = '0123456789ABCDEF'.split('');
var color = '#';
for (var i = 0; i < 6; i++) {
color += letters[Math.floor(Math.random() * 16)];
}
return color;
}
svg {
border: 1px solid;
}
path{
fill: lightsalmon;
stroke: salmon;
stroke-width: 5px;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/d3/3.4.11/d3.min.js"></script>
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>D3 Drawing</title>
<script src="https://cdn.jsdelivr.net/d3js/3.5.9/d3.min.js"></script>
</head>
<body>
<h3>Draw a polygon :D</h3>
计算面积应该非常简单,因为您掌握了所有要点!