73f8fd7bcfbbe5a66350d6224f97dcbffee73c74563cd23211745a4c677ecb159aaedee679c95fc7deff6cc10c675b646365748e2fcf3623317fb97a1f1bb3 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="utf8" />
  5. <title>Arc</title>
  6. <style>
  7. html, body, #canvas {
  8. width: 100%;
  9. height: 100%;
  10. margin: 0px;
  11. padding: 0px;
  12. }
  13. </style>
  14. <script src="../../dist/crender.map.js"></script>
  15. </head>
  16. <body>
  17. <canvas id="canvas"></canvas>
  18. </body>
  19. <script>
  20. const { CRender, extendNewGraph } = window.CRender
  21. const render = new CRender(document.querySelector('#canvas'))
  22. const [w, h] = render.area
  23. const arc = render.add({
  24. name: 'arc',
  25. animationCurve: 'easeOutCubic',
  26. animationFrame: 50,
  27. drag: true,
  28. hover: true,
  29. shape: {
  30. rx: w / 2,
  31. ry: h / 2,
  32. r: 100,
  33. startAngle: -Math.PI / 2,
  34. endAngle: Math.PI
  35. },
  36. style: {
  37. stroke: '#ffee97',
  38. lineWidth: 20,
  39. rotate: 0
  40. }
  41. })
  42. function wait (time) {
  43. return new Promise(resolve => setTimeout(resolve, time))
  44. }
  45. async function start () {
  46. await wait(1000)
  47. arc.animation('shape', {
  48. r: 150
  49. }, true)
  50. await arc.animation('style', {
  51. rotate: 45
  52. })
  53. await wait(1000)
  54. arc.animation('style', {
  55. stroke: 'lemonchiffon'
  56. })
  57. }
  58. start()
  59. </script>
  60. </html>