fix: selection right

This commit is contained in:
Swann Martinez 2019-10-02 14:01:45 +02:00
parent 14ccb68cf7
commit 93be6ae6cc
No known key found for this signature in database
GPG Key ID: 414CCAFD8DA720E1

View File

@ -75,7 +75,7 @@ class ApplyTimer(Timer):
class DynamicRightSelectTimer(Timer): class DynamicRightSelectTimer(Timer):
def __init__(self, timout=1): def __init__(self, timout=.1):
super().__init__(timout) super().__init__(timout)
self.last_selection = [] self.last_selection = []
@ -87,17 +87,11 @@ class DynamicRightSelectTimer(Timer):
user_ref = operators.client.get(uuid=user) user_ref = operators.client.get(uuid=user)
settings = bpy.context.window_manager.session settings = bpy.context.window_manager.session
# Other user
if user_ref.buffer['name'] != settings.username:
user_selection = user_ref.buffer['selected_objects']
for obj in bpy.data.objects:
obj.hide_select = obj.name in user_selection
# Local user # Local user
elif user_ref.pointer: if user_ref.pointer:
current_selection = utils.get_selected_objects( current_selection = utils.get_selected_objects(
bpy.context.scene) bpy.context.scene)
if current_selection != self.last_selection: if current_selection != self.last_selection:
user_ref.pointer.update_selected_objects(bpy.context)
right_strategy = operators.client.get_config()[ right_strategy = operators.client.get_config()[
'right_strategy'] 'right_strategy']
if right_strategy == RP_COMMON: if right_strategy == RP_COMMON:
@ -106,15 +100,6 @@ class DynamicRightSelectTimer(Timer):
obj_ours = [ obj_ours = [
o for o in current_selection if o not in self.last_selection] o for o in current_selection if o not in self.last_selection]
# change old selection right to common
for obj in obj_common:
_object = bpy.data.objects.get(obj)
node = operators.client.get(reference=_object)
if node and node.owner == settings.username:
operators.client.change_owner(
node.uuid, RP_COMMON)
# change new selection to our # change new selection to our
for obj in obj_ours: for obj in obj_ours:
node = operators.client.get( node = operators.client.get(
@ -122,18 +107,22 @@ class DynamicRightSelectTimer(Timer):
if node and node.owner == RP_COMMON: if node and node.owner == RP_COMMON:
operators.client.change_owner( operators.client.change_owner(
node.uuid, settings.username) node.uuid, settings.username)
else:
return
self.last_selection = current_selection self.last_selection = current_selection
user_ref.pointer.update_selected_objects(
bpy.context)
user_ref.update()
# change old selection right to common
for obj in obj_common:
_object = bpy.data.objects.get(obj)
class RedrawTimer(Timer): node = operators.client.get(reference=_object)
def __init__(self, timout=1, target_type=None): if node and (node.owner == settings.username or node.owner == RP_COMMON):
self._type = target_type operators.client.change_owner(
super().__init__(timout) node.uuid, RP_COMMON)
def execute(self):
if presence.renderer:
presence.refresh_3d_view()
class Draw(Delayable): class Draw(Delayable):
@ -155,6 +144,25 @@ class Draw(Delayable):
logger.error("draw already unregistered") logger.error("draw already unregistered")
class DrawClient(Draw):
def execute(self):
repo = operators.client
if repo and presence.renderer:
settings = bpy.context.window_manager.session
client_list = [key for key in repo.list(filter=BlUser) if
key != settings.user_uuid]
for cli in client_list:
cli_ref = repo.get(uuid=cli)
if settings.presence_show_selected:
presence.renderer.draw_client_selection(
cli_ref.buffer['name'], cli_ref.buffer['color'], cli_ref.buffer['selected_objects'])
if settings.presence_show_user:
presence.renderer.draw_client_camera(
cli_ref.buffer['name'], cli_ref.buffer['location'], cli_ref.buffer['color'])
class ClientUpdate(Draw): class ClientUpdate(Draw):
def __init__(self, client_uuid=None): def __init__(self, client_uuid=None):
assert(client_uuid) assert(client_uuid)