DrawLine2.vue 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. <template>
  2. <canvas id="drawLine2" width="800" height="100"/>
  3. </template>
  4. <script lang="ts">
  5. import { SCanvasView, SColor, SPainter } from "@persagy-web/draw/lib";
  6. import { Component, Vue } from "vue-property-decorator";
  7. class TestView extends SCanvasView {
  8. constructor() {
  9. super("drawLine2")
  10. }
  11. onDraw(canvas: SPainter): void {
  12. // 在此编写绘制操作相关命令
  13. canvas.drawLine(0, 0, 100, 100);
  14. canvas.pen.lineWidth = 1;
  15. canvas.pen.color = SColor.Blue;
  16. for (let i = 0; i < 360; i += 10) {
  17. let q = i * Math.PI / 180;
  18. // 绘制一条线段
  19. canvas.drawLine(
  20. 200,
  21. 50,
  22. 200 + 50 * Math.cos(q),
  23. 50 + 50 * Math.sin(q));
  24. }
  25. canvas.pen.color = SColor.Red;
  26. for (let i = 0; i < 360; i += 10) {
  27. let q1 = i * Math.PI / 180;
  28. let q2 = (i + 120) * Math.PI / 180;
  29. canvas.drawLine(
  30. 350 + 50 * Math.cos(q1),
  31. 50 + 50 * Math.sin(q1),
  32. 350 + 50 * Math.cos(q2),
  33. 50 + 50 * Math.sin(q2));
  34. }
  35. }
  36. }
  37. @Component
  38. export default class DrawLine2 extends Vue {
  39. mounted(): void {
  40. new TestView();
  41. }
  42. }
  43. </script>