在SVG和HTML中使用用户输入绘制和动画三角形
Drawing and animating a triangle in SVG and HTML with user input
我有一个大学项目,我选择在HTML中呈现,用户将输入三角形的三个边,形状将呈现在屏幕上。我已经制作了一个JavaScript来获取这些值并创建x和y坐标,在<canvas>
标签内绘制三角形:
<script type="application/javascript">
function init() {
var canvas = document.getElementById("canvas");
if (canvas.getContext) {
var ctx = canvas.getContext("2d");
var a = *user input*;
var b = *user input*;
var c = *user input*;
var ox = 450-(a/2); // 450px since the canvas size is 900px,
var oy = 450+(y3/2); // this aligns the figure to the center
var x3 = ((b*b)+(a*a)-(c*c))/(2*a);
var y3 = Math.ceil(Math.sqrt((b*b)-(x3*2)));
var img = new Image();
img.src = 'grad.png';
ctx.strokeStyle = '#fff';
ctx.lineWidth = 3;
ctx.shadowOffsetX = 0;
ctx.shadowOffsetY = 0;
ctx.shadowBlur = 10;
ctx.shadowColor = 'rgba(0, 0, 0, 0.5)';
var ptrn = ctx.createPattern(img,'repeat');
ctx.fillStyle = ptrn;
ctx.beginPath();
ctx.moveTo(ox,oy);
ctx.lineTo(a+ox,oy);
ctx.lineTo(ox+x3,oy-y3);
ctx.lineTo(ox,oy);
ctx.fill();
ctx.stroke();
ctx.closePath();
}
}
</script>
<body onLoad="init();">
<canvas id="canvas" width="900" height="900"></canvas><br>
</body>
我试图撰写一个简单的缩放动画,一旦页面加载使三角形和其他形状"生长"在屏幕上。如果我使用CSS,整个画布都会缩放。此外,我不知道如何使这个动画成为可能,因为值不是固定的,使用画布,我必须逐帧动画。现在,如果我使用CSS和SVG,我可以对每个元素使用简单的导入和缩放效果,问题是我必须使用用户输入的值在SVG中生成三角形。我该怎么做呢?
三角形是有3个点的多边形。查看SVG Polygon文档。在JavaScript中,你可以像这样创建一个多边形:
var svgns = "http://www.w3.org/2000/svg";
function makeTriangle() {
shape = svgDocument.createElementNS(svgns, "polygon");
shape.setAttributeNS(null, "points", "5,5 45,45 5,45");
shape.setAttributeNS(null, "fill", "none");
shape.setAttributeNS(null, "stroke", "green");
svgDocument.documentElement.appendChild(shape);
}
如果你总是要在屏幕上有一个三角形(或多边形),我会用SVG/CSS创建基本框架,并设置属性为CSS:
<svg xmlns="http://www.w3.org/2000/svg" width="900" height="900">
<defs>
<filter id="dropshadow" height="130%">
<feGaussianBlur in="SourceAlpha" stdDeviation="10"/>
<feMerge>
<feMergeNode/>
<feMergeNode in="SourceGraphic"/>
</feMerge>
</filter>
</defs>
<polygon id="triangle" filter="url(#dropshadow)" />
</svg>
<style>
#triangle {
fill: url(grad.png);
stroke-width: 3px;
stroke: white;
}
</style>
你可以使用大部分相同的代码来设置多边形点:
var points = [
[ox, oy].join(','),
[a + ox, oy].join(','),
[ox + x3, oy - y3].join(',')
].join(' ');
document.getElementById('triangle').setAttribute('points', points);
您可以在这里看到一个示例:http://fiddle.jshell.net/fTPdy/
相关文章:
- 为什么不't Javascript对我的输入值进行了一些重新检查
- 如何显示/绘制以数字作为输入的屏幕锁定模式
- 如何正确使用条件执行根据输入绘制圆
- 从 html 输入值绘制圆圈
- 单击按钮时从输入框中绘制百分比条
- 允许用户使用他们输入的半径在地图上绘制圆圈
- 获取与数组匹配的用户输入以绘制到画布上
- 让用户输入图像 URL 并将其绘制在 html5 画布上
- 使用人力车绘制时间序列图.输入数据的格式
- 在地图上绘制图标,基于用户's在Openlayers 3中的输入
- 检测“;输入“;键并绘制textarea组件
- 如何绘制HTML5画布线给定用户输入的X,Y点
- 输入纬度和经度以从文本区域绘制多边形
- 在SVG和HTML中使用用户输入绘制和动画三角形
- 在用户输入后重新绘制谷歌
- 用用户输入在Canvas中绘制一条线
- 如何使用js库使用两个输入x和y值绘制图形
- 在svg编辑器中转换路径,方法使用用户输入值绘制
- 使用2个数组输入x-y绘制
- 如何在谷歌地图上获取用户对他/她绘制的边界的输入