diff options
author | JashoBell <JoshuaDB@gmail.com> | 2022-09-16 21:06:21 +0000 |
---|---|---|
committer | JashoBell <JoshuaDB@gmail.com> | 2022-09-16 21:06:21 +0000 |
commit | 5a797a5612924e50d5b60d2aa1eddfae4c3e157e (patch) | |
tree | c1c5b12013f826b477a8affd36adf5a9d9212877 /scripts | |
parent | b153ebe3b679854e7314a6d33a038f9f0cc0c233 (diff) | |
download | stable-diffusion-webui-gfx803-5a797a5612924e50d5b60d2aa1eddfae4c3e157e.tar.gz stable-diffusion-webui-gfx803-5a797a5612924e50d5b60d2aa1eddfae4c3e157e.tar.bz2 stable-diffusion-webui-gfx803-5a797a5612924e50d5b60d2aa1eddfae4c3e157e.zip |
Basic explanation for custom_code.py template
Diffstat (limited to 'scripts')
-rw-r--r-- | scripts/custom_code.py | 23 |
1 files changed, 21 insertions, 2 deletions
diff --git a/scripts/custom_code.py b/scripts/custom_code.py index 5694f2dd..6583d3b8 100644 --- a/scripts/custom_code.py +++ b/scripts/custom_code.py @@ -4,20 +4,38 @@ import gradio as gr from modules.processing import Processed
from modules.shared import opts, cmd_opts, state
-
+# An example custom script that allows you to make modifications to how the model object is handled.
+# These scripts appear in the lower-left dropdown menu on the txt2img and img2img tabs.
class Script(scripts.Script):
+
+ # The title of the script. This is what will be displayed in the dropdown menu.
def title(self):
return "Custom code"
+ # Determines when the script should be shown in the dropdown menu via the returned value.
+ # is_img2img is True if the current tab is img2img, and False if it is txt2img. Thus, return
+ # is_img2img to only show the script on the img2img tab.
def show(self, is_img2img):
return cmd_opts.allow_code
+
+ # How the script's is displayed in the UI. See https://gradio.app/docs/#components
+ # for the different elements you can use and how to specify them.
+ # Each UI element can return a value, such as a boolean for a checkbox.
+ # The returned values are passed to the run method as parameters.
def ui(self, is_img2img):
code = gr.Textbox(label="Python code", visible=False, lines=1)
return [code]
+
+ # This is where the additional processing is implemented. The parameters include self, the
+ # model object (a StableDiffusionProcessing class, see processing.py), and the parameters
+ # returned by the ui method.
+ # Custom functions can be defined here, and additional libraries can be imported to be used
+ # in processing. The return value should be a Processed object, which is what is returned
+ # by the process_images method.
def run(self, p, code):
assert cmd_opts.allow_code, '--allow-code option must be enabled'
@@ -37,4 +55,5 @@ class Script(scripts.Script): exec(compiled, module.__dict__)
return Processed(p, *display_result_data)
-
+
+
\ No newline at end of file |