首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用HTML5画布和Javascript绘制MS绘制三角形工具

使用HTML5画布和Javascript绘制MS绘制三角形工具
EN

Stack Overflow用户
提问于 2017-01-19 21:26:46
回答 2查看 3.6K关注 0票数 1

我是javascript和Canvas的新手,我想知道如何通过点击和拖动鼠标在画布上绘制三角形,就像我们在MS Paint中所做的那样,三角形的大小取决于用户拖拽的程度。

EN

回答 2

Stack Overflow用户

发布于 2017-01-19 22:05:56

这里是一个起点:

代码语言:javascript
复制
//HTML elements
var canvas = document.getElementById("canvas");
var ctx = canvas.getContext("2d");
//Current unconnected points
var mouse = [];
//Existing triangles
var triangles = [];
//The function that draws
function draw() {
    //Clear canvas
    ctx.clearRect(0, 0, canvas.width, canvas.height);
    //Draw existing triangles
    for (var tIndex = 0; tIndex < triangles.length; tIndex++) {
      var triangle = triangles[tIndex];
      ctx.beginPath();
      ctx.moveTo(triangle.a.x, triangle.a.y);
      ctx.lineTo(triangle.b.x, triangle.b.y);
      ctx.lineTo(triangle.c.x, triangle.c.y);
      ctx.closePath();
      ctx.stroke();
    }
    //Draw current mouse points
    if (mouse.length > 0) {
      ctx.beginPath();
      ctx.moveTo(mouse[0].x, mouse[0].y);
    }
    if (mouse.length > 1) {
      ctx.lineTo(mouse[1].x, mouse[1].y);
    }
    if (mouse.length > 0) {
      ctx.stroke();
    }
  }
  //Catch point
canvas.onclick = function eventHandler(event) {
  //Add points to list
  mouse.push({
    x: event.layerX,
    y: event.layerY
  });
  //If we have enough points, add a triangle
  if (mouse.length >= 3) {
    //Adding the triangle
    triangles.push({
      a: mouse[0],
      b: mouse[1],
      c: mouse[2]
    });
    //Clear points
    mouse = [];
  }
  //Update canvas
  draw();
};
代码语言:javascript
复制
body,
html,
* {
  margin: 0px;
  padding: 0px;
}
#canvas {
  background-color: #ddd;
}
代码语言:javascript
复制
<canvas id="canvas" width="400" height="400"></canvas>

你必须自己发明拖拽效果。

票数 1
EN

Stack Overflow用户

发布于 2021-01-13 15:38:44

代码语言:javascript
复制
//HTML elements
var canvas = document.getElementById("canvas");
var ctx = canvas.getContext("2d");
//Current unconnected points
var mouse = [];
//Existing triangles
var triangles = [];
//The function that draws
function draw() {
    //Clear canvas
    ctx.clearRect(0, 0, canvas.width, canvas.height);
    //Draw existing triangles
    for (var tIndex = 0; tIndex < triangles.length; tIndex++) {
      var triangle = triangles[tIndex];
      ctx.beginPath();
      ctx.moveTo(triangle.a.x, triangle.a.y);
      ctx.lineTo(triangle.b.x, triangle.b.y);
      ctx.lineTo(triangle.c.x, triangle.c.y);
      ctx.closePath();
      ctx.stroke();
    }
    //Draw current mouse points
    if (mouse.length > 0) {
      ctx.beginPath();
      ctx.moveTo(mouse[0].x, mouse[0].y);
    }
    if (mouse.length > 1) {
      ctx.lineTo(mouse[1].x, mouse[1].y);
    }
    if (mouse.length > 0) {
      ctx.stroke();
    }
  }
  //Catch point
canvas.onclick = function eventHandler(event) {
  //Add points to list
  mouse.push({
    x: event.layerX,
    y: event.layerY
  });
  //If we have enough points, add a triangle
  if (mouse.length >= 3) {
    //Adding the triangle
    triangles.push({
      a: mouse[0],
      b: mouse[1],
      c: mouse[2]
    });
    //Clear points
    mouse = [];
  }
  //Update canvas
  draw();
};
代码语言:javascript
复制
body,
html,
* {
  margin: 0px;
  padding: 0px;
}
#canvas {
  background-color: #ddd;
}
代码语言:javascript
复制
<canvas id="canvas" width="400" height="400"></canvas>

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/41742949

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档