diff options
author | Greg Zaal <gregzzmail@gmail.com> | 2015-02-15 19:29:45 +0300 |
---|---|---|
committer | Greg Zaal <gregzzmail@gmail.com> | 2015-02-15 19:29:45 +0300 |
commit | 211bc1e831800be71d8731224c8513af1bfcbd68 (patch) | |
tree | 08655ad1a159e42ed9c47a8f02c39d3cb432ed13 /node_wrangler.py | |
parent | 48ecad6989ae61753bc980fa0cef156fc20721a1 (diff) |
Node Wrangler: Viewer Focus fixes...
- Only act when clicking on the background
- remove unused variables
Diffstat (limited to 'node_wrangler.py')
-rw-r--r-- | node_wrangler.py | 54 |
1 files changed, 26 insertions, 28 deletions
diff --git a/node_wrangler.py b/node_wrangler.py index 4a58bb97..7926d674 100644 --- a/node_wrangler.py +++ b/node_wrangler.py @@ -19,7 +19,7 @@ bl_info = { "name": "Node Wrangler", "author": "Bartek Skorupa, Greg Zaal, Sebastian Koenig", - "version": (3, 23), + "version": (3, 24), "blender": (2, 72, 0), "location": "Node Editor Toolbar or Ctrl-Space", "description": "Various tools to enhance and speed up node-based workflow", @@ -3085,41 +3085,39 @@ class NWViewerFocus(bpy.types.Operator): render = context.scene.render space = context.space_data percent = render.resolution_percentage*0.01 - - for n in bpy.context.scene.node_tree.nodes: - if n.type == "VIEWER": - self.x = event.mouse_region_x - self.y = event.mouse_region_y - - region_x=context.region.width - region_y=context.region.height - region_center_x=region_x/2 - region_center_y=region_y/2 + nodes, links = get_nodes_links(context) + viewers = [n for n in nodes if n.type == 'VIEWER'] - rel_region_mouse_x=region_x-self.x - rel_region_mouse_y=region_y-self.y - - bd_x = render.resolution_x*percent*space.backdrop_zoom - bd_y = render.resolution_y* percent*space.backdrop_zoom + if viewers: + mlocx = event.mouse_region_x + mlocy = event.mouse_region_y + select_node = bpy.ops.node.select(mouse_x=mlocx, mouse_y=mlocy, extend=False) - backdrop_center_x=(bd_x/2)-space.backdrop_x - backdrop_center_y=(bd_y/2)-space.backdrop_y + if not 'FINISHED' in select_node: # only run if we're not clicking on a node + region_x = context.region.width + region_y = context.region.height - margin_x = region_center_x-backdrop_center_x - margin_y = region_center_y-backdrop_center_y + region_center_x = context.region.width / 2 + region_center_y = context.region.height / 2 - absolute_x_max = margin_x+bd_x - absolute_y_max = margin_y+bd_y + bd_x = render.resolution_x * percent * space.backdrop_zoom + bd_y = render.resolution_y * percent * space.backdrop_zoom - abs_mouse_x = (self.x-margin_x)/bd_x - abs_mouse_y = (self.y-margin_y)/bd_y + backdrop_center_x = (bd_x / 2) - space.backdrop_x + backdrop_center_y = (bd_y / 2) - space.backdrop_y - rel_bd_x = (bd_x-rel_region_mouse_x) - rel_bd_y = (bd_y-rel_region_mouse_y) + margin_x = region_center_x - backdrop_center_x + margin_y = region_center_y - backdrop_center_y - n.center_x = abs_mouse_x - n.center_y = abs_mouse_y + abs_mouse_x = (mlocx - margin_x) / bd_x + abs_mouse_y = (mlocy - margin_y) / bd_y + + for node in viewers: + node.center_x = abs_mouse_x + node.center_y = abs_mouse_y + else: + return {'PASS_THROUGH'} return self.execute(context) |