2019-08-13 18:00:54 +02:00
|
|
|
import bpy
|
2019-08-23 12:28:57 +02:00
|
|
|
|
2019-08-14 14:25:20 +02:00
|
|
|
from . import operators, utils
|
2019-08-13 21:32:15 +02:00
|
|
|
from .bl_types.bl_user import BlUser
|
2019-08-23 12:28:57 +02:00
|
|
|
from .libs import debug
|
2019-08-27 00:09:52 +02:00
|
|
|
from .libs.replication.replication.constants import FETCHED
|
2019-08-23 12:28:57 +02:00
|
|
|
|
2019-08-13 18:00:54 +02:00
|
|
|
|
|
|
|
class Delayable():
|
2019-08-14 15:01:30 +02:00
|
|
|
"""Delayable task interface
|
|
|
|
"""
|
2019-08-23 12:28:57 +02:00
|
|
|
|
2019-08-13 18:00:54 +02:00
|
|
|
def register(self):
|
|
|
|
raise NotImplementedError
|
|
|
|
|
|
|
|
def execute(self):
|
|
|
|
raise NotImplementedError
|
|
|
|
|
|
|
|
def unregister(self):
|
|
|
|
raise NotImplementedError
|
|
|
|
|
2019-08-23 12:28:57 +02:00
|
|
|
|
2019-08-13 18:00:54 +02:00
|
|
|
class Timer(Delayable):
|
|
|
|
"""Timer binder interface for blender
|
|
|
|
|
|
|
|
Run a bpy.app.Timer in the background looping at the given rate
|
|
|
|
"""
|
2019-08-23 12:28:57 +02:00
|
|
|
|
2019-08-13 18:00:54 +02:00
|
|
|
def __init__(self, duration=1):
|
|
|
|
self._timeout = duration
|
|
|
|
|
|
|
|
def register(self):
|
|
|
|
"""Register the timer into the blender timer system
|
|
|
|
"""
|
|
|
|
bpy.app.timers.register(self.execute)
|
|
|
|
|
|
|
|
def execute(self):
|
|
|
|
"""Main timer loop
|
|
|
|
"""
|
|
|
|
return self._timeout
|
|
|
|
|
|
|
|
def unregister(self):
|
|
|
|
"""Unnegister the timer of the blender timer system
|
|
|
|
"""
|
2019-08-13 21:32:15 +02:00
|
|
|
try:
|
|
|
|
bpy.app.timers.unregister(self.execute)
|
|
|
|
except:
|
|
|
|
print("timer already unregistered")
|
2019-08-13 18:00:54 +02:00
|
|
|
|
2019-08-23 12:28:57 +02:00
|
|
|
|
2019-08-13 18:00:54 +02:00
|
|
|
class ApplyTimer(Timer):
|
2019-08-23 12:28:57 +02:00
|
|
|
def __init__(self, timout=1, target_type=None):
|
2019-08-13 18:00:54 +02:00
|
|
|
self._type = target_type
|
|
|
|
super().__init__(timout)
|
|
|
|
|
|
|
|
def execute(self):
|
|
|
|
if operators.client:
|
|
|
|
nodes = operators.client.list(filter=self._type)
|
|
|
|
|
|
|
|
for node in nodes:
|
2019-08-26 17:27:12 +02:00
|
|
|
node_ref = operators.client.get(uuid=node)
|
2019-08-13 18:00:54 +02:00
|
|
|
|
|
|
|
if node_ref.state == FETCHED:
|
|
|
|
operators.client.apply(uuid=node)
|
|
|
|
|
|
|
|
return self._timeout
|
|
|
|
|
2019-08-26 17:27:12 +02:00
|
|
|
# class CheckNewTimer(Timer):
|
|
|
|
|
2019-08-23 12:28:57 +02:00
|
|
|
|
2019-08-13 18:00:54 +02:00
|
|
|
class Draw(Delayable):
|
|
|
|
def __init__(self):
|
|
|
|
self._handler = None
|
|
|
|
|
|
|
|
def register(self):
|
|
|
|
self._handler = bpy.types.SpaceView3D.draw_handler_add(
|
2019-08-23 12:28:57 +02:00
|
|
|
self.execute, (), 'WINDOW', 'POST_VIEW')
|
|
|
|
|
2019-08-13 18:00:54 +02:00
|
|
|
def execute(self):
|
|
|
|
raise NotImplementedError()
|
2019-08-23 12:28:57 +02:00
|
|
|
|
2019-08-13 18:00:54 +02:00
|
|
|
def unregister(self):
|
2019-08-13 21:32:15 +02:00
|
|
|
try:
|
|
|
|
bpy.types.SpaceView3D.draw_handler_remove(
|
2019-08-23 12:28:57 +02:00
|
|
|
self._handler, "WINDOW")
|
2019-08-13 21:32:15 +02:00
|
|
|
except:
|
|
|
|
print("draw already unregistered")
|
2019-08-23 12:28:57 +02:00
|
|
|
|
|
|
|
|
2019-08-13 18:00:54 +02:00
|
|
|
class ClientUpdate(Draw):
|
|
|
|
def __init__(self, client_uuid=None):
|
|
|
|
assert(client_uuid)
|
|
|
|
self._client_uuid = client_uuid
|
|
|
|
super().__init__()
|
|
|
|
|
|
|
|
def execute(self):
|
2019-08-26 17:59:36 +02:00
|
|
|
if self._client_uuid and operators.client:
|
2019-08-26 17:27:12 +02:00
|
|
|
client = operators.client.get(uuid=self._client_uuid)
|
2019-08-13 21:32:15 +02:00
|
|
|
|
|
|
|
if client:
|
|
|
|
client.pointer.update_location()
|