window_drawer.py 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. import core
  2. from drawer.BaseDrawer import BaseDrawer, VentGraphDrawer
  3. from entity.primitives import Window
  4. class WindowDrawer(VentGraphDrawer):
  5. def __init__(self, obj, msp, style):
  6. super().__init__(obj, msp, style)
  7. self.window_drawers = {
  8. 0: self.draw_window_0,
  9. 1: self.draw_window_1,
  10. }
  11. def initialize_data(self):
  12. self.obj.color = (255, 255, 255)
  13. def draw_obj(self, center, route):
  14. self.window_drawers[self.style](center,route)
  15. def trans_window_rate(self, n):
  16. assert isinstance(self.obj, Window)
  17. return n * self.obj.width / 16.2
  18. def create_window_points(self, center, route):
  19. assert isinstance(self.obj, Window)
  20. cx, cy = center
  21. points = []
  22. # 定义一系列点的偏移量
  23. offsets = [
  24. (-8.11, 12.63), (-8.11, 21.60), (-8.11, -12.63), (-8.11, -21.60),
  25. (8.11, 12.63), (8.11, 21.60), (8.11, -12.63), (8.11, -21.60),
  26. (-8.11, 10.02), (3.935, 10.02), (-3.935, 7.09), (8.11, 7.09),
  27. (-8.11, 4.32), (3.935, 4.32), (-3.935, 1.385), (8.11, 1.385),
  28. (-8.11, -1.39), (3.935, -1.39), (-3.935, -4.32), (8.11, -4.32),
  29. (-8.11, -7.10), (3.935, -7.10), (-3.935, -10.03), (8.11, -10.03)
  30. ]
  31. for dx, dy in offsets:
  32. x = cx + self.trans_window_rate(dx)
  33. y = cy + self.trans_window_rate(dy)
  34. rotated_point = core.rotate_point_around_another((x, y), center, route)
  35. points.append(rotated_point)
  36. return points
  37. def draw_window_0(self, center, route):
  38. points = self.create_window_points(center, route)
  39. # 绘制线条
  40. lines = [
  41. (points[1], points[3]), (points[5], points[7]),
  42. (points[0], points[4]), (points[2], points[6]),
  43. (points[8], points[9]), (points[9], points[11]),
  44. (points[10], points[11]), (points[8], points[10]),
  45. (points[12], points[13]), (points[13], points[15]),
  46. (points[14], points[15]), (points[12], points[14]),
  47. (points[16], points[17]), (points[17], points[19]),
  48. (points[18], points[19]), (points[16], points[18]),
  49. (points[20], points[21]), (points[21], points[23]),
  50. (points[22], points[23]), (points[20], points[22])
  51. ]
  52. for line in lines:
  53. l = self.msp.add_line(line[0], line[1], dxfattribs={"layer": f"图层{self.obj.layer_id}"})
  54. l.rgb = self.obj.color
  55. # a1
  56. # b1-|-b1
  57. # |||
  58. # c1-|-c2
  59. # a2
  60. def draw_window_1(self, center, route):
  61. a1 = center[0], center[1] + self.obj.width * 0.7
  62. a2 = center[0], center[1] - self.obj.width * 0.7
  63. a1 = core.rotate_point_around_another(a1, center, route)
  64. a2 = core.rotate_point_around_another(a2, center, route)
  65. self.msp.add_line(a1, a2, dxfattribs={"layer": f"图层{self.obj.layer_id}", "lineweight": 50})
  66. b1 = center[0]-self.obj.width * 0.3, center[1] + self.obj.width * 0.3
  67. b2 = center[0]+self.obj.width * 0.3, center[1] + self.obj.width * 0.3
  68. b1 = core.rotate_point_around_another(b1, center, route)
  69. b2 = core.rotate_point_around_another(b2, center, route)
  70. self.msp.add_line(b1, b2, dxfattribs={"layer": f"图层{self.obj.layer_id}", "lineweight": 50})
  71. c1 = center[0] - self.obj.width * 0.3, center[1] - self.obj.width * 0.3
  72. c2 = center[0] + self.obj.width * 0.3, center[1] - self.obj.width * 0.3
  73. c1 = core.rotate_point_around_another(c1, center, route)
  74. c2 = core.rotate_point_around_another(c2, center, route)
  75. self.msp.add_line(c1, c2, dxfattribs={"layer": f"图层{self.obj.layer_id}", "lineweight": 50})
  76. self.msp.add_line(b1, c1, dxfattribs={"layer": f"图层{self.obj.layer_id}", "lineweight": 50})
  77. self.msp.add_line(b2, c2, dxfattribs={"layer": f"图层{self.obj.layer_id}", "lineweight": 50})