Add swap axes button for XY Grid
This commit is contained in:
parent
dd292a925e
commit
2144c2eb7f
@ -23,6 +23,9 @@ import os
|
||||
import re
|
||||
|
||||
|
||||
up_down_arrow_symbol = "\u2195\ufe0f"
|
||||
|
||||
|
||||
def apply_field(field):
|
||||
def fun(p, x, xs):
|
||||
setattr(p, field, x)
|
||||
@ -292,6 +295,10 @@ class Script(scripts.Script):
|
||||
def ui(self, is_img2img):
|
||||
current_axis_options = [x for x in axis_options if type(x) == AxisOption or type(x) == AxisOptionImg2Img and is_img2img]
|
||||
|
||||
with gr.Row():
|
||||
with gr.Column(scale=1, elem_id="xy_grid_button_column"):
|
||||
swap_axes_button = gr.Button(value=up_down_arrow_symbol, elem_id="xy_grid_swap_axes")
|
||||
with gr.Column(scale=19):
|
||||
with gr.Row():
|
||||
x_type = gr.Dropdown(label="X type", choices=[x.label for x in current_axis_options], value=current_axis_options[1].label, type="index", elem_id=self.elem_id("x_type"))
|
||||
x_values = gr.Textbox(label="X values", lines=1, elem_id=self.elem_id("x_values"))
|
||||
@ -304,6 +311,13 @@ class Script(scripts.Script):
|
||||
include_lone_images = gr.Checkbox(label='Include Separate Images', value=False, elem_id=self.elem_id("include_lone_images"))
|
||||
no_fixed_seeds = gr.Checkbox(label='Keep -1 for seeds', value=False, elem_id=self.elem_id("no_fixed_seeds"))
|
||||
|
||||
def swap_axes(x_type, x_values, y_type, y_values):
|
||||
nonlocal current_axis_options
|
||||
return current_axis_options[y_type].label, y_values, current_axis_options[x_type].label, x_values
|
||||
|
||||
swap_args = [x_type, x_values, y_type, y_values]
|
||||
swap_axes_button.click(swap_axes, inputs=swap_args, outputs=swap_args)
|
||||
|
||||
return [x_type, x_values, y_type, y_values, draw_legend, include_lone_images, no_fixed_seeds]
|
||||
|
||||
def run(self, p, x_type, x_values, y_type, y_values, draw_legend, include_lone_images, no_fixed_seeds):
|
||||
|
10
style.css
10
style.css
@ -717,6 +717,16 @@ footer {
|
||||
line-height: 2.4em;
|
||||
}
|
||||
|
||||
#xy_grid_button_column {
|
||||
min-width: 38px !important;
|
||||
}
|
||||
|
||||
#xy_grid_button_column button {
|
||||
height: 100%;
|
||||
margin-bottom: 0.7em;
|
||||
margin-left: 1em;
|
||||
}
|
||||
|
||||
/* The following handles localization for right-to-left (RTL) languages like Arabic.
|
||||
The rtl media type will only be activated by the logic in javascript/localization.js.
|
||||
If you change anything above, you need to make sure it is RTL compliant by just running
|
||||
|
Loading…
Reference in New Issue
Block a user