feat(rcf): append client data init

This commit is contained in:
Swann Martinez 2019-04-17 15:48:20 +02:00
parent 7c354778ce
commit aaffde6e5b
No known key found for this signature in database
GPG Key ID: 414CCAFD8DA720E1
3 changed files with 26 additions and 18 deletions

View File

@ -257,11 +257,11 @@ def rcf_client_agent(ctx, pipe,queue):
# Store snapshot # Store snapshot
if rcfmsg.key == "SNAPSHOT_END": if rcfmsg.key == "SNAPSHOT_END":
client_key = "Client/{}".format(agent.id.decode()) client_key = "Client/{}".format(agent.id.decode())
client_dict = {} client_dict = {}
client_dict['location'] = [[0,0,0],[0,0,0],[0,0,0],[0,0,0]]
client_dict['color'] = [0,1,1,1] with lock:
client_dict['active_object'] = '' client_dict = helpers.init_client(key=client_key)
client_store = message.RCFMessage(key=client_key, id=agent.id.decode(),body=client_dict) client_store = message.RCFMessage(key=client_key, id=agent.id.decode(),body=client_dict)
logger.info(client_store) logger.info(client_store)
client_store.store(agent.property_map) client_store.store(agent.property_map)

11
draw.py
View File

@ -179,17 +179,6 @@ class HUD(object):
except Exception as e: except Exception as e:
print("2D EXCEPTION") print("2D EXCEPTION")
def is_object_selected(self, obj):
# TODO: function to find occurence
for k, v in self.client.property_map.items():
if v.mtype == 'clientObject':
if self.client.id != v.id:
if obj.name in v.body:
return True
return False
def draw(self): def draw(self):
if self.client: if self.client:
# Draw clients # Draw clients

View File

@ -6,12 +6,19 @@ CORRESPONDANCE = {'Collection': 'collections', 'Mesh': 'meshes', 'Object': 'obje
'Texture': 'textures', 'Scene': 'scenes', 'Light': 'lights', 'Camera': 'cameras', 'Action': 'actions', 'Armature': 'armatures', 'Grease Pencil': 'grease_pencils'} 'Texture': 'textures', 'Scene': 'scenes', 'Light': 'lights', 'Camera': 'cameras', 'Action': 'actions', 'Armature': 'armatures', 'Grease Pencil': 'grease_pencils'}
# UTILITY FUNCTIONS
def refresh_window(): def refresh_window():
import bpy import bpy
bpy.ops.wm.redraw_timer(type='DRAW_WIN_SWAP', iterations=1) bpy.ops.wm.redraw_timer(type='DRAW_WIN_SWAP', iterations=1)
# LOAD HELPERS def get_selected_objects(view_layer):
selected_objects = []
for obj in view_layer.objects:
if obj.select_get():
selected_objects.append(obj.name)
return selected_objects
# LOAD HELPERS
def load(key, value): def load(key, value):
target = resolve_bpy_path(key) target = resolve_bpy_path(key)
target_type = key.split('/')[0] target_type = key.split('/')[0]
@ -60,15 +67,17 @@ def resolve_bpy_path(path):
return item return item
def load_client(client=None,data=None): def load_client(client=None,data=None):
if client and data: if client and data:
# Draw client # Draw client
#Load selected object #Load selected object
if data['active_object']: if data['active_objects']:
print("toto") print("toto")
pass pass
def load_mesh(target=None, data=None, create=False): def load_mesh(target=None, data=None, create=False):
import bmesh import bmesh
@ -292,7 +301,6 @@ def load_default(target=None, data=None, create=False, type=None):
print("default loading error") print("default loading error")
# DUMP HELPERS # DUMP HELPERS
def dump(key): def dump(key):
target = resolve_bpy_path(key) target = resolve_bpy_path(key)
target_type = key.split('/')[0] target_type = key.split('/')[0]
@ -350,3 +358,14 @@ def dump_datablock_attibute(datablock, attributes, depth=1):
return data return data
def init_client(key=None):
client_dict = {}
client_dict['location'] = [[0,0,0],[0,0,0],[0,0,0],[0,0,0]]
client_dict['color'] = [0,1,1,1]
C = bpy.context
# for o in bpy.context.selected_objects:
# print("TOTO {}".format(o.name))
client_dict['active_objects'] = get_selected_objects(C.view_layer)
print(client_dict['active_objects'])
return client_dict