WindFlow3DDrawer.py 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. import math
  2. import time
  3. import ezdxf
  4. import numpy as np
  5. from ezdxf.enums import TextEntityAlignment
  6. import core
  7. from core import rotate_point_around_another, calculate_route, calculate_angle_with_x_axis
  8. class WindFlow3DDrawer:
  9. def __init__(self, msp, layer, length, center, route, type_):
  10. self.layer = layer
  11. self.msp = msp
  12. self.len = length
  13. self.center = center
  14. self.route = route
  15. self.type = type_
  16. def draw_wind_flow(self):
  17. point_end = self.center[0] - self.len / 2, self.center[1]
  18. point_arrow = self.center[0] + self.len / 2, self.center[1]
  19. point_s_end = self.center[0] - self.len / 2.5, self.center[1]
  20. point_s_arrow = self.center[0] + self.len / 5, self.center[1]
  21. point_text = self.center[0]-self.len/ 2 ,self.center[1]
  22. arrow = ezdxf.ARROWS.closed_filled
  23. point_end = rotate_point_around_another(point_end, self.center, self.route)
  24. point_arrow = rotate_point_around_another(point_arrow, self.center, self.route)
  25. point_s_end = rotate_point_around_another(point_s_end, self.center, self.route)
  26. point_s_arrow = rotate_point_around_another(point_s_arrow, self.center, self.route)
  27. point_text = rotate_point_around_another(point_text, self.center, self.route)
  28. angle = math.degrees(self.route)
  29. # 用风类型 0:未指定 1:进风 2: 用风 3:回风
  30. # 0、1 是绿色箭头, 2、3是红色箭头
  31. if self.type == '2' or self.type == '3':
  32. p1, p2 = core.line_point_normal_distance(point_s_arrow, point_s_end, 1 / 4, self.len/25)
  33. p3, p4 = core.line_point_normal_distance(point_s_arrow, point_s_end, 3 / 4, self.len/25)
  34. self.msp.add_spline([point_s_arrow, p1, p4, point_s_end],dxfattribs={
  35. "color": self.get_color(),
  36. "layer": f"图层{self.layer}"
  37. })
  38. # dxfattribs = {
  39. # 'insert': point_text, 'style': 'msyh', 'color': '1', "layer":f"图层{self.layer}"}
  40. # self.msp.add_text(text="S", rotation=angle - 90, dxfattribs=dxfattribs,height=0.2*self.len).set_placement(point_text, align=TextEntityAlignment.CENTER)
  41. self.msp.add_line(point_end, point_arrow, {
  42. "color": self.get_color(),
  43. "layer":f"图层{self.layer}"
  44. })
  45. # 2d 6
  46. self.msp.add_arrow(arrow, point_arrow, 1, angle, {
  47. "color": self.get_color(),
  48. "layer": f"图层{self.layer}"
  49. })
  50. def get_color(self):
  51. if self.type == '2' or self.type == '3':
  52. return '1'
  53. else:
  54. return '3'