diff --git a/bioviz/biorbd_vtk.py b/bioviz/biorbd_vtk.py index fe5d933..22e7ffd 100644 --- a/bioviz/biorbd_vtk.py +++ b/bioviz/biorbd_vtk.py @@ -8,6 +8,7 @@ import numpy as np from PyQt5 import QtWidgets from PyQt5.QtGui import QPalette, QColor +import threading from vtk import ( vtkActor, @@ -41,10 +42,11 @@ from pyomeca import Markers, Rototrans from .mesh import Mesh -first = True -if first: +first = threading.local() +first.value = True +if first.value: app = QtWidgets.QApplication(sys.argv) - first = False + first.value = False class VtkWindow(QtWidgets.QMainWindow): @@ -861,7 +863,7 @@ def new_mesh_set(self, all_meshes): self.mesh_actors = list() # Create the geometry of a point (the coordinate) points = vtkPoints() - for (i, mesh) in enumerate(self.all_meshes): + for i, mesh in enumerate(self.all_meshes): if mesh.time.size != 1: raise IndexError("Mesh should be from one frame only") @@ -940,7 +942,7 @@ def update_mesh(self, all_meshes): self.all_meshes = all_meshes - for (i, mesh) in enumerate(self.all_meshes): + for i, mesh in enumerate(self.all_meshes): points = vtkPoints() n_vertex = mesh.channel.size mesh = np.array(mesh) @@ -1000,7 +1002,7 @@ def new_muscle_set(self, all_muscles): self.muscle_actors = list() # Create the geometry of a point (the coordinate) points = vtkPoints() - for (i, mesh) in enumerate(self.all_muscles): + for i, mesh in enumerate(self.all_muscles): if mesh.time.size != 1: raise IndexError("Muscles should be from one frame only") @@ -1064,7 +1066,7 @@ def update_muscle(self, all_muscles): self.all_muscles = all_muscles - for (i, mesh) in enumerate(self.all_muscles): + for i, mesh in enumerate(self.all_muscles): points = vtkPoints() n_vertex = mesh.channel.size mesh = np.array(mesh) @@ -1123,7 +1125,7 @@ def new_ligament_set(self, all_ligaments): self.ligament_actors = list() # Create the geometry of a point (the coordinate) points = vtkPoints() - for (i, mesh) in enumerate(self.all_ligaments): + for i, mesh in enumerate(self.all_ligaments): if mesh.time.size != 1: raise IndexError("ligaments should be from one frame only") @@ -1187,7 +1189,7 @@ def update_ligament(self, all_ligaments): self.all_ligaments = all_ligaments - for (i, mesh) in enumerate(self.all_ligaments): + for i, mesh in enumerate(self.all_ligaments): points = vtkPoints() n_vertex = mesh.channel.size mesh = np.array(mesh) @@ -1246,7 +1248,7 @@ def new_wrapping_set(self, all_wrappings, seg): self.wrapping_actors[seg] = list() # Create the geometry of a point (the coordinate) points = vtkPoints() - for (i, wrapping) in enumerate(self.all_wrappings[seg]): + for i, wrapping in enumerate(self.all_wrappings[seg]): if wrapping.time.size != 1: raise IndexError("Mesh should be from one frame only") @@ -1312,7 +1314,7 @@ def update_wrapping(self, all_wrappings): self.all_wrappings[seg] = wrappings - for (i, wrapping) in enumerate(self.all_wrappings[seg]): + for i, wrapping in enumerate(self.all_wrappings[seg]): points = vtkPoints() n_vertex = wrapping.channel.size wrapping = np.array(wrapping) diff --git a/tests/test_Gui.py b/tests/test_Gui.py index 6dc271d..49e6428 100644 --- a/tests/test_Gui.py +++ b/tests/test_Gui.py @@ -9,7 +9,6 @@ def get_test_folder(): def test_model_load(): - model_path = f"{get_test_folder()}/../examples/pyomecaman.bioMod" # From path