DrawRect1.vue 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. <template>
  2. <canvas id="drawRect1" width="800" height="180"/>
  3. </template>
  4. <script lang="ts">
  5. import { SCanvasView, SColor, SPainter, SPoint, SRect, SSize } from "@persagy-web/draw/lib";
  6. import { Component, Vue } from "vue-property-decorator";
  7. class TestView extends SCanvasView {
  8. constructor() {
  9. super("drawRect1")
  10. }
  11. onDraw(canvas: SPainter): void {
  12. // 清除画布
  13. canvas.clearRect(0, 0, 800, 200);
  14. // 绘制操作相关命令
  15. canvas.pen.color = SColor.Blue;
  16. canvas.brush.color = SColor.Red;
  17. // 绘制矩形
  18. canvas.drawRect(10, 10, 80, 80);
  19. canvas.pen.color = SColor.Transparent;
  20. canvas.brush.color = SColor.Red;
  21. //绘制矩形
  22. canvas.drawRect(new SPoint(110, 10), new SSize(80, 80));
  23. canvas.pen.color = SColor.Blue;
  24. canvas.brush.color = SColor.Transparent;
  25. // 绘制矩形
  26. canvas.drawRect(new SRect(210, 10, 80, 80));
  27. canvas.pen.lineWidth = 1;
  28. canvas.pen.color = SColor.Blue;
  29. canvas.brush.color = SColor.Transparent;
  30. for (let i = 1; i < 100; i += 10) {
  31. //绘制矩形
  32. canvas.drawRect(310 + i, i, 80, 80);
  33. }
  34. canvas.pen.lineWidth = 2;
  35. canvas.pen.color = SColor.Blue;
  36. canvas.brush.color = SColor.Red;
  37. let k = new Date().getTime() / 100 % 10;
  38. for (let i = 1; i < k * 10; i += 10) {
  39. canvas.drawRect(510 + i, i, 80, 80);
  40. }
  41. this.update();
  42. }
  43. }
  44. @Component
  45. export default class DrawRect1 extends Vue {
  46. mounted(): void {
  47. new TestView();
  48. }
  49. }
  50. </script>