935c31ccb3c771849675833a142a1a75ac666ef58083ccb32560abae4d2d44911dfeba513f6864d3f19f4a0bb0c2ada3ab15ab25d49cb464570f9f986be27b 1.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="utf8" />
  5. <title>Ring</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 ring = render.add({
  24. name: 'ring',
  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. },
  34. style: {
  35. stroke: '#ffee97',
  36. lineWidth: 20
  37. }
  38. })
  39. function wait (time) {
  40. return new Promise(resolve => setTimeout(resolve, time))
  41. }
  42. async function start () {
  43. await wait(1000)
  44. await ring.animation('shape', {
  45. r: 150
  46. })
  47. await wait(1000)
  48. ring.animation('style', {
  49. stroke: 'lemonchiffon'
  50. })
  51. }
  52. start()
  53. </script>
  54. </html>