Skip to content

Commit ea9bd9f

Browse files
Merge pull request #7556 from EllangoK/master
Adds options for grid margins to XYZ Plot and Prompt Matrix
2 parents 3993aa4 + 0ca1a64 commit ea9bd9f

File tree

3 files changed

+28
-27
lines changed

3 files changed

+28
-27
lines changed

modules/images.py

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -199,7 +199,7 @@ def draw_texts(drawing, draw_x, draw_y, lines, initial_fnt, initial_fontsize):
199199

200200
pad_top = 0 if sum(hor_text_heights) == 0 else max(hor_text_heights) + line_spacing * 2
201201

202-
result = Image.new("RGB", (im.width + pad_left + margin * (rows-1), im.height + pad_top + margin * (cols-1)), "white")
202+
result = Image.new("RGB", (im.width + pad_left + margin * (cols-1), im.height + pad_top + margin * (rows-1)), "white")
203203

204204
for row in range(rows):
205205
for col in range(cols):
@@ -223,7 +223,7 @@ def draw_texts(drawing, draw_x, draw_y, lines, initial_fnt, initial_fontsize):
223223
return result
224224

225225

226-
def draw_prompt_matrix(im, width, height, all_prompts):
226+
def draw_prompt_matrix(im, width, height, all_prompts, margin=0):
227227
prompts = all_prompts[1:]
228228
boundary = math.ceil(len(prompts) / 2)
229229

@@ -233,7 +233,7 @@ def draw_prompt_matrix(im, width, height, all_prompts):
233233
hor_texts = [[GridAnnotation(x, is_active=pos & (1 << i) != 0) for i, x in enumerate(prompts_horiz)] for pos in range(1 << len(prompts_horiz))]
234234
ver_texts = [[GridAnnotation(x, is_active=pos & (1 << i) != 0) for i, x in enumerate(prompts_vert)] for pos in range(1 << len(prompts_vert))]
235235

236-
return draw_grid_annotations(im, width, height, hor_texts, ver_texts)
236+
return draw_grid_annotations(im, width, height, hor_texts, ver_texts, margin)
237237

238238

239239
def resize_image(resize_mode, im, width, height, upscaler_name=None):

scripts/prompt_matrix.py

Lines changed: 9 additions & 15 deletions
Original file line numberDiff line numberDiff line change
@@ -48,23 +48,17 @@ def ui(self, is_img2img):
4848
gr.HTML('<br />')
4949
with gr.Row():
5050
with gr.Column():
51-
put_at_start = gr.Checkbox(label='Put variable parts at start of prompt',
52-
value=False, elem_id=self.elem_id("put_at_start"))
51+
put_at_start = gr.Checkbox(label='Put variable parts at start of prompt', value=False, elem_id=self.elem_id("put_at_start"))
52+
different_seeds = gr.Checkbox(label='Use different seed for each picture', value=False, elem_id=self.elem_id("different_seeds"))
5353
with gr.Column():
54-
# Radio buttons for selecting the prompt between positive and negative
55-
prompt_type = gr.Radio(["positive", "negative"], label="Select prompt",
56-
elem_id=self.elem_id("prompt_type"), value="positive")
57-
with gr.Row():
58-
with gr.Column():
59-
different_seeds = gr.Checkbox(
60-
label='Use different seed for each picture', value=False, elem_id=self.elem_id("different_seeds"))
54+
prompt_type = gr.Radio(["positive", "negative"], label="Select prompt", elem_id=self.elem_id("prompt_type"), value="positive")
55+
variations_delimiter = gr.Radio(["comma", "space"], label="Select joining char", elem_id=self.elem_id("variations_delimiter"), value="comma")
6156
with gr.Column():
62-
# Radio buttons for selecting the delimiter to use in the resulting prompt
63-
variations_delimiter = gr.Radio(["comma", "space"], label="Select delimiter", elem_id=self.elem_id(
64-
"variations_delimiter"), value="comma")
65-
return [put_at_start, different_seeds, prompt_type, variations_delimiter]
57+
margin_size = gr.Slider(label="Grid margins (px)", min=0, max=500, value=0, step=2, elem_id=self.elem_id("margin_size"))
58+
59+
return [put_at_start, different_seeds, prompt_type, variations_delimiter, margin_size]
6660

67-
def run(self, p, put_at_start, different_seeds, prompt_type, variations_delimiter):
61+
def run(self, p, put_at_start, different_seeds, prompt_type, variations_delimiter, margin_size):
6862
modules.processing.fix_seed(p)
6963
# Raise error if promp type is not positive or negative
7064
if prompt_type not in ["positive", "negative"]:
@@ -106,7 +100,7 @@ def run(self, p, put_at_start, different_seeds, prompt_type, variations_delimite
106100
processed = process_images(p)
107101

108102
grid = images.image_grid(processed.images, p.batch_size, rows=1 << ((len(prompt_matrix_parts) - 1) // 2))
109-
grid = images.draw_prompt_matrix(grid, p.width, p.height, prompt_matrix_parts)
103+
grid = images.draw_prompt_matrix(grid, p.width, p.height, prompt_matrix_parts, margin_size)
110104
processed.images.insert(0, grid)
111105
processed.index_of_first_image = 1
112106
processed.infotexts.insert(0, processed.infotexts[0])

scripts/xyz_grid.py

Lines changed: 16 additions & 9 deletions
Original file line numberDiff line numberDiff line change
@@ -205,7 +205,7 @@ def __init__(self, *args, **kwargs):
205205
]
206206

207207

208-
def draw_xyz_grid(p, xs, ys, zs, x_labels, y_labels, z_labels, cell, draw_legend, include_lone_images, include_sub_grids, first_axes_processed, second_axes_processed):
208+
def draw_xyz_grid(p, xs, ys, zs, x_labels, y_labels, z_labels, cell, draw_legend, include_lone_images, include_sub_grids, first_axes_processed, second_axes_processed, margin_size):
209209
hor_texts = [[images.GridAnnotation(x)] for x in x_labels]
210210
ver_texts = [[images.GridAnnotation(y)] for y in y_labels]
211211
title_texts = [[images.GridAnnotation(z)] for z in z_labels]
@@ -292,7 +292,7 @@ def index(ix, iy, iz):
292292
end_index = start_index + len(xs) * len(ys)
293293
grid = images.image_grid(image_cache[start_index:end_index], rows=len(ys))
294294
if draw_legend:
295-
grid = images.draw_grid_annotations(grid, cell_size[0], cell_size[1], hor_texts, ver_texts)
295+
grid = images.draw_grid_annotations(grid, cell_size[0], cell_size[1], hor_texts, ver_texts, margin_size)
296296
sub_grids[i] = grid
297297
if include_sub_grids and len(zs) > 1:
298298
processed_result.images.insert(i+1, grid)
@@ -351,10 +351,16 @@ def ui(self, is_img2img):
351351
fill_z_button = ToolButton(value=fill_values_symbol, elem_id="xyz_grid_fill_z_tool_button", visible=False)
352352

353353
with gr.Row(variant="compact", elem_id="axis_options"):
354-
draw_legend = gr.Checkbox(label='Draw legend', value=True, elem_id=self.elem_id("draw_legend"))
355-
include_lone_images = gr.Checkbox(label='Include Sub Images', value=False, elem_id=self.elem_id("include_lone_images"))
356-
include_sub_grids = gr.Checkbox(label='Include Sub Grids', value=False, elem_id=self.elem_id("include_sub_grids"))
357-
no_fixed_seeds = gr.Checkbox(label='Keep -1 for seeds', value=False, elem_id=self.elem_id("no_fixed_seeds"))
354+
with gr.Column():
355+
draw_legend = gr.Checkbox(label='Draw legend', value=True, elem_id=self.elem_id("draw_legend"))
356+
no_fixed_seeds = gr.Checkbox(label='Keep -1 for seeds', value=False, elem_id=self.elem_id("no_fixed_seeds"))
357+
with gr.Column():
358+
include_lone_images = gr.Checkbox(label='Include Sub Images', value=False, elem_id=self.elem_id("include_lone_images"))
359+
include_sub_grids = gr.Checkbox(label='Include Sub Grids', value=False, elem_id=self.elem_id("include_sub_grids"))
360+
with gr.Column():
361+
margin_size = gr.Slider(label="Grid margins (px)", min=0, max=500, value=0, step=2, elem_id=self.elem_id("margin_size"))
362+
363+
with gr.Row(variant="compact", elem_id="swap_axes"):
358364
swap_xy_axes_button = gr.Button(value="Swap X/Y axes", elem_id="xy_grid_swap_axes_button")
359365
swap_yz_axes_button = gr.Button(value="Swap Y/Z axes", elem_id="yz_grid_swap_axes_button")
360366
swap_xz_axes_button = gr.Button(value="Swap X/Z axes", elem_id="xz_grid_swap_axes_button")
@@ -393,9 +399,9 @@ def select_axis(x_type):
393399
(z_values, "Z Values"),
394400
)
395401

396-
return [x_type, x_values, y_type, y_values, z_type, z_values, draw_legend, include_lone_images, include_sub_grids, no_fixed_seeds]
402+
return [x_type, x_values, y_type, y_values, z_type, z_values, draw_legend, include_lone_images, include_sub_grids, no_fixed_seeds, margin_size]
397403

398-
def run(self, p, x_type, x_values, y_type, y_values, z_type, z_values, draw_legend, include_lone_images, include_sub_grids, no_fixed_seeds):
404+
def run(self, p, x_type, x_values, y_type, y_values, z_type, z_values, draw_legend, include_lone_images, include_sub_grids, no_fixed_seeds, margin_size):
399405
if not no_fixed_seeds:
400406
modules.processing.fix_seed(p)
401407

@@ -590,7 +596,8 @@ def cell(x, y, z):
590596
include_lone_images=include_lone_images,
591597
include_sub_grids=include_sub_grids,
592598
first_axes_processed=first_axes_processed,
593-
second_axes_processed=second_axes_processed
599+
second_axes_processed=second_axes_processed,
600+
margin_size=margin_size
594601
)
595602

596603
if opts.grid_save and len(sub_grids) > 1:

0 commit comments

Comments
 (0)