forked from benrugg/AI-Render
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathhandlers.py
123 lines (93 loc) · 4.39 KB
/
handlers.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
import bpy
from bpy.app.handlers import persistent
import functools
from . import (
operators,
preferences,
properties,
task_queue,
utils,
)
@persistent
def load_post_handler(context):
"""Handle new blender file load (and new scene load)"""
if not context:
context = bpy.context
# if AI Render has been enabled in this file, do the enable steps
# right now, to ensure everything is running and in place
if context.scene.air_props.is_enabled:
operators.enable_air(context.scene)
# ensure that the sampler is set to a valid value (it could be wrong
# from an existing file with an older version of AI Render)
properties.ensure_sampler(None, context)
# update the sd backend to migrate a possible old value from a previous installation
preferences.update_sd_backend_from_previous_installation(context)
@persistent
def render_init_handler(scene):
"""Handle an entire render process about to start"""
# if AI Render wasn't installed correctly or isn't enabled, quit here
if not utils.is_installation_valid() or not scene.air_props.is_enabled:
return
# track that a render is in progress
scene.air_props.is_rendering = True
scene.air_props.animation_init_frame = scene.frame_current
# do the pre-render setup
# NOTE: We want to do this even if auto_run is disabled, because we need to mute
# the node group in that case, so that the actual render can be viewed
operators.do_pre_render_setup(scene)
@persistent
def frame_change_pre_handler(scene):
"""Handle frame change"""
# if AI Render wasn't installed correctly, quit here
if not utils.is_installation_valid():
return
# if we are rendering, track that we are rendering an animation
if scene.air_props.is_rendering and int(scene.air_props.animation_init_frame) != int(scene.frame_current):
scene.air_props.is_rendering_animation = True
@persistent
def render_complete_handler(scene):
"""Handle render completed (this is where the API and Stable Diffusion start)"""
# if AI Render wasn't installed correctly, or it isn't enabled, or we don't want
# to run automatically, or we don't have an API Key (and we're using DreamStudio),
# quit here
if (
not utils.is_installation_valid()
or not scene.air_props.is_enabled
or not scene.air_props.auto_run
or (not utils.get_dream_studio_api_key() and utils.sd_backend() == "dreamstudio")
):
return
# if we are rendering an animation...
if scene.air_props.is_rendering_animation or scene.air_props.is_rendering_animation_manually:
# if we are rendering an animation, but not manually, set a silent error message,
# just to warn users that this won't work with AI Render
if scene.air_props.is_rendering_animation and not scene.air_props.is_rendering_animation_manually:
operators.set_silent_error(scene, "To render an animation with AI Render, use the \"Render Animation\" button in the Animation panel below")
# track that we're not rendering
scene.air_props.is_rendering = False
scene.air_props.is_rendering_animation = False
# then quit here
return
# check to see if we have a render result
is_img_ready = bpy.data.images['Render Result'].has_data
# if it's ready, post to the api
if is_img_ready:
# do pre-api setup
operators.do_pre_api_setup(scene)
# post to the api (on a different thread, outside the handler)
task_queue.add(functools.partial(operators.send_to_api, scene))
else:
operators.handle_error("Rendered image is not ready. Try generating a new image manually under AI Render > Operation", "image_not_ready")
# track that we're no longer rendering
scene.air_props.is_rendering = False
scene.air_props.is_rendering_animation = False
def register():
bpy.app.handlers.load_post.append(load_post_handler)
bpy.app.handlers.render_init.append(render_init_handler)
bpy.app.handlers.frame_change_pre.append(frame_change_pre_handler)
bpy.app.handlers.render_complete.append(render_complete_handler)
def unregister():
bpy.app.handlers.load_post.remove(load_post_handler)
bpy.app.handlers.render_init.remove(render_init_handler)
bpy.app.handlers.frame_change_pre.remove(frame_change_pre_handler)
bpy.app.handlers.render_complete.remove(render_complete_handler)