From 33c8137a197aad050cd23aaddd1818f6601cf8c0 Mon Sep 17 00:00:00 2001 From: Gui-FernandesBR Date: Tue, 19 Dec 2023 04:22:48 -0300 Subject: [PATCH] FIX: EmptyMotor no longer breaks the rocket draw --- rocketpy/plots/rocket_plots.py | 26 +++++++++++++------------- 1 file changed, 13 insertions(+), 13 deletions(-) diff --git a/rocketpy/plots/rocket_plots.py b/rocketpy/plots/rocket_plots.py index 500b12a1d..c3fb998f6 100644 --- a/rocketpy/plots/rocket_plots.py +++ b/rocketpy/plots/rocket_plots.py @@ -1,7 +1,7 @@ import matplotlib.pyplot as plt import numpy as np -from rocketpy.motors import HybridMotor, LiquidMotor, SolidMotor +from rocketpy.motors import EmptyMotor, HybridMotor, LiquidMotor, SolidMotor from rocketpy.rocket.aero_surface import Fins, NoseCone, Tail @@ -332,10 +332,6 @@ def draw(self, vis_args=None): self.rocket.motor_position + self.rocket.motor.nozzle_position * total_csys ) - nozzle = self.rocket.motor.plots._generate_nozzle( - translate=(nozzle_position, 0), csys=self.rocket._csys - ) - # List of motor patches motor_patches = [] @@ -414,14 +410,18 @@ def draw(self, vis_args=None): motor_patches += [tank] # add nozzle last so it is in front of the other patches - motor_patches += [nozzle] - outline = self.rocket.motor.plots._generate_motor_region( - list_of_patches=motor_patches - ) - # add outline first so it is behind the other patches - ax.add_patch(outline) - for patch in motor_patches: - ax.add_patch(patch) + if not isinstance(self.rocket.motor, EmptyMotor): + nozzle = self.rocket.motor.plots._generate_nozzle( + translate=(nozzle_position, 0), csys=self.rocket._csys + ) + motor_patches += [nozzle] + outline = self.rocket.motor.plots._generate_motor_region( + list_of_patches=motor_patches + ) + # add outline first so it is behind the other patches + ax.add_patch(outline) + for patch in motor_patches: + ax.add_patch(patch) # Check if nozzle is beyond the last surface, if so draw a tube # to it, with the radius of the last surface