index.html 13 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta http-equiv="X-UA-Compatible" content="IE=edge">
  6. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  7. <title>Document</title>
  8. <style>
  9. html,body,canvas {
  10. margin: 0;
  11. padding: 0;
  12. width: 100%;
  13. height: 100%;
  14. overflow: hidden;
  15. }
  16. </style>
  17. </head>
  18. <body>
  19. <canvas id="canvas"> </canvas>
  20. </body>
  21. </html>
  22. <script>
  23. const loadImage = (imgUrl) => {
  24. return new Promise((resolve, reject) => {
  25. const img = new Image()
  26. img.onload = () => {
  27. resolve(img)
  28. }
  29. img.onerror = reject
  30. img.src = imgUrl
  31. })
  32. }
  33. const drawCadImg = async (imgUrl, angle, scale, canvas) => {
  34. const img = await loadImage(imgUrl)
  35. const ctx = canvas.getContext('2d')
  36. ctx.save()
  37. ctx.translate(canvas.width / 2, canvas.height / 2)
  38. ctx.rotate(angle)
  39. ctx.scale(scale, scale)
  40. ctx.translate(-img.width / 2, - img.height / 2)
  41. ctx.drawImage(img, 0, 0)
  42. ctx.restore()
  43. }
  44. const canvas = document.querySelector('canvas')
  45. const ctx = canvas.getContext('2d')
  46. canvas.width = canvas.offsetWidth
  47. canvas.height = canvas.offsetHeight
  48. drawCadImg(
  49. ``,
  50. 45,
  51. 1.2,
  52. document.querySelector('canvas')
  53. )
  54. ctx.save()
  55. ctx.translate(canvas.width / 2, canvas.height / 2)
  56. ctx.rect(0, 0, 200, 200)
  57. ctx.fill()
  58. ctx.restore()
  59. </script>