Skip to content

Commit

Permalink
refactor init (#1132)
Browse files Browse the repository at this point in the history
  • Loading branch information
hainm authored Nov 23, 2024
1 parent 5de7373 commit 98415dd
Showing 1 changed file with 16 additions and 11 deletions.
27 changes: 16 additions & 11 deletions nglview/widget.py
Original file line number Diff line number Diff line change
Expand Up @@ -198,7 +198,14 @@ def __init__(self,
parameters=None,
**kwargs):
super().__init__(**kwargs)
self._initialize_attributes(kwargs)
self._initialize_threads()
self._initialize_components(structure, representations, parameters, kwargs)
self._initialize_layout(kwargs)
self._create_player()
self._create_ibtn_fullscreen()

def _initialize_attributes(self, kwargs):
self._gui = None
self._init_gui = kwargs.pop('gui', False)
self._theme = kwargs.pop('theme', 'default')
Expand All @@ -212,18 +219,21 @@ def __init__(self,
self.shape = Shape(view=self)
self.stage = Stage(view=self)
self.control = ViewerControl(view=self)
self._trajlist = []
self._ngl_component_ids = []

def _initialize_threads(self):
self._handle_msg_thread = threading.Thread(
target=self.on_msg, args=(self._handle_nglview_custom_msg,))
# # register to get data from JS side
# register to get data from JS side
self._handle_msg_thread.daemon = True
self._handle_msg_thread.start()
self._remote_call_thread = RemoteCallThread(
self,
registered_funcs=['loadFile', 'replaceStructure', '_exportImage'])
self._remote_call_thread.start()
self._trajlist = []
self._ngl_component_ids = []

def _initialize_components(self, structure, representations, parameters, kwargs):
if representations:
# Must be set here before calling
# add_trajectory or add_struture
Expand All @@ -234,18 +244,16 @@ def __init__(self,
if 'default' in kwargs:
kwargs['default_representation'] = kwargs['default']

autoview = 'center' not in kwargs or ('center' in kwargs and
kwargs.pop('center'))
# NOTE: Using `pop` to avoid passing `center` to NGL.
autoview = 'center' not in kwargs or ('center' in kwargs and kwargs.pop('center'))

if parameters:
self.parameters = parameters
if isinstance(structure, Trajectory):
name = py_utils.get_name(structure, **kwargs)
self.add_trajectory(structure, name=name, **kwargs)
elif isinstance(structure, (list, tuple)):
trajectories = structure
for trajectory in trajectories:
for trajectory in structure:
name = py_utils.get_name(trajectory, **kwargs)
self.add_trajectory(trajectory, name=name, **kwargs)
else:
Expand All @@ -259,15 +267,12 @@ def __init__(self,
if autoview:
self.center()

def _initialize_layout(self, kwargs):
self._view_width = kwargs.get('width', '')
self._view_height = kwargs.get('height', '')

# Updating only self.layout.{width, height} don't handle
# resizing NGL widget properly.
self._sync_with_layout()
# self.layout.width = 'auto'
self._create_player()
self._create_ibtn_fullscreen()

def _create_ibtn_fullscreen(self):
button = widgets.Button(icon='compress')
Expand Down

0 comments on commit 98415dd

Please sign in to comment.