mirror of
https://github.com/invoke-ai/InvokeAI
synced 2024-08-30 20:32:17 +00:00
Merge branch 'main' into bugfix/ignore-dot-directories-on-model-scan
This commit is contained in:
commit
c9d95e5758
@ -8,28 +8,42 @@ To download a node, simply download the `.py` node file from the link and add it
|
|||||||
|
|
||||||
To use a community workflow, download the the `.json` node graph file and load it into Invoke AI via the **Load Workflow** button in the Workflow Editor.
|
To use a community workflow, download the the `.json` node graph file and load it into Invoke AI via the **Load Workflow** button in the Workflow Editor.
|
||||||
|
|
||||||
--------------------------------
|
- Community Nodes
|
||||||
|
+ [Depth Map from Wavefront OBJ](#depth-map-from-wavefront-obj)
|
||||||
|
+ [Film Grain](#film-grain)
|
||||||
|
+ [Generative Grammar-Based Prompt Nodes](#generative-grammar-based-prompt-nodes)
|
||||||
|
+ [GPT2RandomPromptMaker](#gpt2randompromptmaker)
|
||||||
|
+ [Grid to Gif](#grid-to-gif)
|
||||||
|
+ [Halftone](#halftone)
|
||||||
|
+ [Ideal Size](#ideal-size)
|
||||||
|
+ [Image and Mask Composition Pack](#image-and-mask-composition-pack)
|
||||||
|
+ [Image to Character Art Image Nodes](#image-to-character-art-image-nodes)
|
||||||
|
+ [Image Picker](#image-picker)
|
||||||
|
+ [Load Video Frame](#load-video-frame)
|
||||||
|
+ [Make 3D](#make-3d)
|
||||||
|
+ [Oobabooga](#oobabooga)
|
||||||
|
+ [Prompt Tools](#prompt-tools)
|
||||||
|
+ [Retroize](#retroize)
|
||||||
|
+ [Size Stepper Nodes](#size-stepper-nodes)
|
||||||
|
+ [Text font to Image](#text-font-to-image)
|
||||||
|
+ [Thresholding](#thresholding)
|
||||||
|
+ [XY Image to Grid and Images to Grids nodes](#xy-image-to-grid-and-images-to-grids-nodes)
|
||||||
|
- [Example Node Template](#example-node-template)
|
||||||
|
- [Disclaimer](#disclaimer)
|
||||||
|
- [Help](#help)
|
||||||
|
|
||||||
|
|
||||||
--------------------------------
|
--------------------------------
|
||||||
### Make 3D
|
### Depth Map from Wavefront OBJ
|
||||||
|
|
||||||
**Description:** Create compelling 3D stereo images from 2D originals.
|
**Description:** Render depth maps from Wavefront .obj files (triangulated) using this simple 3D renderer utilizing numpy and matplotlib to compute and color the scene. There are simple parameters to change the FOV, camera position, and model orientation.
|
||||||
|
|
||||||
**Node Link:** [https://gitlab.com/srcrr/shift3d/-/raw/main/make3d.py](https://gitlab.com/srcrr/shift3d)
|
To be imported, an .obj must use triangulated meshes, so make sure to enable that option if exporting from a 3D modeling program. This renderer makes each triangle a solid color based on its average depth, so it will cause anomalies if your .obj has large triangles. In Blender, the Remesh modifier can be helpful to subdivide a mesh into small pieces that work well given these limitations.
|
||||||
|
|
||||||
**Example Node Graph:** https://gitlab.com/srcrr/shift3d/-/raw/main/example-workflow.json?ref_type=heads&inline=false
|
**Node Link:** https://github.com/dwringer/depth-from-obj-node
|
||||||
|
|
||||||
**Output Examples**
|
**Example Usage:**
|
||||||
|
</br><img src="https://raw.githubusercontent.com/dwringer/depth-from-obj-node/main/depth_from_obj_usage.jpg" width="500" />
|
||||||
![Painting of a cozy delapidated house](https://gitlab.com/srcrr/shift3d/-/raw/main/example-1.png){: style="height:512px;width:512px"}
|
|
||||||
![Photo of cute puppies](https://gitlab.com/srcrr/shift3d/-/raw/main/example-2.png){: style="height:512px;width:512px"}
|
|
||||||
|
|
||||||
--------------------------------
|
|
||||||
### Ideal Size
|
|
||||||
|
|
||||||
**Description:** This node calculates an ideal image size for a first pass of a multi-pass upscaling. The aim is to avoid duplication that results from choosing a size larger than the model is capable of.
|
|
||||||
|
|
||||||
**Node Link:** https://github.com/JPPhoto/ideal-size-node
|
|
||||||
|
|
||||||
--------------------------------
|
--------------------------------
|
||||||
### Film Grain
|
### Film Grain
|
||||||
@ -39,68 +53,19 @@ To use a community workflow, download the the `.json` node graph file and load i
|
|||||||
**Node Link:** https://github.com/JPPhoto/film-grain-node
|
**Node Link:** https://github.com/JPPhoto/film-grain-node
|
||||||
|
|
||||||
--------------------------------
|
--------------------------------
|
||||||
### Image Picker
|
### Generative Grammar-Based Prompt Nodes
|
||||||
|
|
||||||
**Description:** This InvokeAI node takes in a collection of images and randomly chooses one. This can be useful when you have a number of poses to choose from for a ControlNet node, or a number of input images for another purpose.
|
**Description:** This set of 3 nodes generates prompts from simple user-defined grammar rules (loaded from custom files - examples provided below). The prompts are made by recursively expanding a special template string, replacing nonterminal "parts-of-speech" until no nonterminal terms remain in the string.
|
||||||
|
|
||||||
**Node Link:** https://github.com/JPPhoto/image-picker-node
|
This includes 3 Nodes:
|
||||||
|
- *Lookup Table from File* - loads a YAML file "prompt" section (or of a whole folder of YAML's) into a JSON-ified dictionary (Lookups output)
|
||||||
|
- *Lookups Entry from Prompt* - places a single entry in a new Lookups output under the specified heading
|
||||||
|
- *Prompt from Lookup Table* - uses a Collection of Lookups as grammar rules from which to randomly generate prompts.
|
||||||
|
|
||||||
--------------------------------
|
**Node Link:** https://github.com/dwringer/generative-grammar-prompt-nodes
|
||||||
### Thresholding
|
|
||||||
|
|
||||||
**Description:** This node generates masks for highlights, midtones, and shadows given an input image. You can optionally specify a blur for the lookup table used in making those masks from the source image.
|
**Example Usage:**
|
||||||
|
</br><img src="https://raw.githubusercontent.com/dwringer/generative-grammar-prompt-nodes/main/lookuptables_usage.jpg" width="500" />
|
||||||
**Node Link:** https://github.com/JPPhoto/thresholding-node
|
|
||||||
|
|
||||||
**Examples**
|
|
||||||
|
|
||||||
Input:
|
|
||||||
|
|
||||||
![image](https://github.com/invoke-ai/InvokeAI/assets/34005131/c88ada13-fb3d-484c-a4fe-947b44712632){: style="height:512px;width:512px"}
|
|
||||||
|
|
||||||
Highlights/Midtones/Shadows:
|
|
||||||
|
|
||||||
<img src="https://github.com/invoke-ai/InvokeAI/assets/34005131/727021c1-36ff-4ec8-90c8-105e00de986d" style="width: 30%" />
|
|
||||||
<img src="https://github.com/invoke-ai/InvokeAI/assets/34005131/0b721bfc-f051-404e-b905-2f16b824ddfe" style="width: 30%" />
|
|
||||||
<img src="https://github.com/invoke-ai/InvokeAI/assets/34005131/04c1297f-1c88-42b6-a7df-dd090b976286" style="width: 30%" />
|
|
||||||
|
|
||||||
Highlights/Midtones/Shadows (with LUT blur enabled):
|
|
||||||
|
|
||||||
<img src="https://github.com/invoke-ai/InvokeAI/assets/34005131/19aa718a-70c1-4668-8169-d68f4bd13771" style="width: 30%" />
|
|
||||||
<img src="https://github.com/invoke-ai/InvokeAI/assets/34005131/0a440e43-697f-4d17-82ee-f287467df0a5" style="width: 30%" />
|
|
||||||
<img src="https://github.com/invoke-ai/InvokeAI/assets/34005131/0701fd0f-2ca7-4fe2-8613-2b52547bafce" style="width: 30%" />
|
|
||||||
|
|
||||||
--------------------------------
|
|
||||||
### Halftone
|
|
||||||
|
|
||||||
**Description**: Halftone converts the source image to grayscale and then performs halftoning. CMYK Halftone converts the image to CMYK and applies a per-channel halftoning to make the source image look like a magazine or newspaper. For both nodes, you can specify angles and halftone dot spacing.
|
|
||||||
|
|
||||||
**Node Link:** https://github.com/JPPhoto/halftone-node
|
|
||||||
|
|
||||||
**Example**
|
|
||||||
|
|
||||||
Input:
|
|
||||||
|
|
||||||
![image](https://github.com/invoke-ai/InvokeAI/assets/34005131/fd5efb9f-4355-4409-a1c2-c1ca99e0cab4){: style="height:512px;width:512px"}
|
|
||||||
|
|
||||||
Halftone Output:
|
|
||||||
|
|
||||||
![image](https://github.com/invoke-ai/InvokeAI/assets/34005131/7e606f29-e68f-4d46-b3d5-97f799a4ec2f){: style="height:512px;width:512px"}
|
|
||||||
|
|
||||||
CMYK Halftone Output:
|
|
||||||
|
|
||||||
![image](https://github.com/invoke-ai/InvokeAI/assets/34005131/c59c578f-db8e-4d66-8c66-2851752d75ea){: style="height:512px;width:512px"}
|
|
||||||
|
|
||||||
--------------------------------
|
|
||||||
### Retroize
|
|
||||||
|
|
||||||
**Description:** Retroize is a collection of nodes for InvokeAI to "Retroize" images. Any image can be given a fresh coat of retro paint with these nodes, either from your gallery or from within the graph itself. It includes nodes to pixelize, quantize, palettize, and ditherize images; as well as to retrieve palettes from existing images.
|
|
||||||
|
|
||||||
**Node Link:** https://github.com/Ar7ific1al/invokeai-retroizeinode/
|
|
||||||
|
|
||||||
**Retroize Output Examples**
|
|
||||||
|
|
||||||
![image](https://github.com/Ar7ific1al/InvokeAI_nodes_retroize/assets/2306586/de8b4fa6-324c-4c2d-b36c-297600c73974)
|
|
||||||
|
|
||||||
--------------------------------
|
--------------------------------
|
||||||
### GPT2RandomPromptMaker
|
### GPT2RandomPromptMaker
|
||||||
@ -113,76 +78,49 @@ CMYK Halftone Output:
|
|||||||
|
|
||||||
Generated Prompt: An enchanted weapon will be usable by any character regardless of their alignment.
|
Generated Prompt: An enchanted weapon will be usable by any character regardless of their alignment.
|
||||||
|
|
||||||
![9acf5aef-7254-40dd-95b3-8eac431dfab0 (1)](https://github.com/mickr777/InvokeAI/assets/115216705/8496ba09-bcdd-4ff7-8076-ff213b6a1e4c)
|
<img src="https://github.com/mickr777/InvokeAI/assets/115216705/8496ba09-bcdd-4ff7-8076-ff213b6a1e4c" width="200" />
|
||||||
|
|
||||||
--------------------------------
|
--------------------------------
|
||||||
### Load Video Frame
|
### Grid to Gif
|
||||||
|
|
||||||
**Description:** This is a video frame image provider + indexer/video creation nodes for hooking up to iterators and ranges and ControlNets and such for invokeAI node experimentation. Think animation + ControlNet outputs.
|
**Description:** One node that turns a grid image into an image collection, one node that turns an image collection into a gif.
|
||||||
|
|
||||||
**Node Link:** https://github.com/helix4u/load_video_frame
|
**Node Link:** https://github.com/mildmisery/invokeai-GridToGifNode/blob/main/GridToGif.py
|
||||||
|
|
||||||
**Example Node Graph:** https://github.com/helix4u/load_video_frame/blob/main/Example_Workflow.json
|
**Example Node Graph:** https://github.com/mildmisery/invokeai-GridToGifNode/blob/main/Grid%20to%20Gif%20Example%20Workflow.json
|
||||||
|
|
||||||
**Output Example:**
|
**Output Examples**
|
||||||
|
|
||||||
![Example animation](https://github.com/helix4u/load_video_frame/blob/main/testmp4_embed_converted.gif)
|
<img src="https://raw.githubusercontent.com/mildmisery/invokeai-GridToGifNode/main/input.png" width="300" />
|
||||||
[Full mp4 of Example Output test.mp4](https://github.com/helix4u/load_video_frame/blob/main/test.mp4)
|
<img src="https://raw.githubusercontent.com/mildmisery/invokeai-GridToGifNode/main/output.gif" width="300" />
|
||||||
|
|
||||||
--------------------------------
|
--------------------------------
|
||||||
|
### Halftone
|
||||||
|
|
||||||
### Oobabooga
|
**Description**: Halftone converts the source image to grayscale and then performs halftoning. CMYK Halftone converts the image to CMYK and applies a per-channel halftoning to make the source image look like a magazine or newspaper. For both nodes, you can specify angles and halftone dot spacing.
|
||||||
|
|
||||||
**Description:** asks a local LLM running in Oobabooga's Text-Generation-Webui to write a prompt based on the user input.
|
**Node Link:** https://github.com/JPPhoto/halftone-node
|
||||||
|
|
||||||
**Link:** https://github.com/sammyf/oobabooga-node
|
**Example**
|
||||||
|
|
||||||
|
Input:
|
||||||
|
|
||||||
**Example:**
|
<img src="https://github.com/invoke-ai/InvokeAI/assets/34005131/fd5efb9f-4355-4409-a1c2-c1ca99e0cab4" width="300" />
|
||||||
|
|
||||||
"describe a new mystical creature in its natural environment"
|
Halftone Output:
|
||||||
|
|
||||||
*can return*
|
<img src="https://github.com/invoke-ai/InvokeAI/assets/34005131/7e606f29-e68f-4d46-b3d5-97f799a4ec2f" width="300" />
|
||||||
|
|
||||||
"The mystical creature I am describing to you is called the "Glimmerwing". It is a majestic, iridescent being that inhabits the depths of the most enchanted forests and glimmering lakes. Its body is covered in shimmering scales that reflect every color of the rainbow, and it has delicate, translucent wings that sparkle like diamonds in the sunlight. The Glimmerwing's home is a crystal-clear lake, surrounded by towering trees with leaves that shimmer like jewels. In this serene environment, the Glimmerwing spends its days swimming gracefully through the water, chasing schools of glittering fish and playing with the gentle ripples of the lake's surface.
|
CMYK Halftone Output:
|
||||||
As the sun sets, the Glimmerwing perches on a branch of one of the trees, spreading its wings to catch the last rays of light. The creature's scales glow softly, casting a rainbow of colors across the forest floor. The Glimmerwing sings a haunting melody, its voice echoing through the stillness of the night air. Its song is said to have the power to heal the sick and bring peace to troubled souls. Those who are lucky enough to hear the Glimmerwing's song are forever changed by its beauty and grace."
|
|
||||||
|
|
||||||
![glimmerwing_small](https://github.com/sammyf/oobabooga-node/assets/42468608/cecdd820-93dd-4c35-abbf-607e001fb2ed)
|
<img src="https://github.com/invoke-ai/InvokeAI/assets/34005131/c59c578f-db8e-4d66-8c66-2851752d75ea" width="300" />
|
||||||
|
|
||||||
**Requirement**
|
|
||||||
|
|
||||||
a Text-Generation-Webui instance (might work remotely too, but I never tried it) and obviously InvokeAI 3.x
|
|
||||||
|
|
||||||
**Note**
|
|
||||||
|
|
||||||
This node works best with SDXL models, especially as the style can be described independantly of the LLM's output.
|
|
||||||
|
|
||||||
--------------------------------
|
--------------------------------
|
||||||
### Depth Map from Wavefront OBJ
|
### Ideal Size
|
||||||
|
|
||||||
**Description:** Render depth maps from Wavefront .obj files (triangulated) using this simple 3D renderer utilizing numpy and matplotlib to compute and color the scene. There are simple parameters to change the FOV, camera position, and model orientation.
|
**Description:** This node calculates an ideal image size for a first pass of a multi-pass upscaling. The aim is to avoid duplication that results from choosing a size larger than the model is capable of.
|
||||||
|
|
||||||
To be imported, an .obj must use triangulated meshes, so make sure to enable that option if exporting from a 3D modeling program. This renderer makes each triangle a solid color based on its average depth, so it will cause anomalies if your .obj has large triangles. In Blender, the Remesh modifier can be helpful to subdivide a mesh into small pieces that work well given these limitations.
|
**Node Link:** https://github.com/JPPhoto/ideal-size-node
|
||||||
|
|
||||||
**Node Link:** https://github.com/dwringer/depth-from-obj-node
|
|
||||||
|
|
||||||
**Example Usage:**
|
|
||||||
![depth from obj usage graph](https://raw.githubusercontent.com/dwringer/depth-from-obj-node/main/depth_from_obj_usage.jpg)
|
|
||||||
|
|
||||||
--------------------------------
|
|
||||||
### Generative Grammar-Based Prompt Nodes
|
|
||||||
|
|
||||||
**Description:** This set of 3 nodes generates prompts from simple user-defined grammar rules (loaded from custom files - examples provided below). The prompts are made by recursively expanding a special template string, replacing nonterminal "parts-of-speech" until no more nonterminal terms remain in the string.
|
|
||||||
|
|
||||||
This includes 3 Nodes:
|
|
||||||
- *Lookup Table from File* - loads a YAML file "prompt" section (or of a whole folder of YAML's) into a JSON-ified dictionary (Lookups output)
|
|
||||||
- *Lookups Entry from Prompt* - places a single entry in a new Lookups output under the specified heading
|
|
||||||
- *Prompt from Lookup Table* - uses a Collection of Lookups as grammar rules from which to randomly generate prompts.
|
|
||||||
|
|
||||||
**Node Link:** https://github.com/dwringer/generative-grammar-prompt-nodes
|
|
||||||
|
|
||||||
**Example Usage:**
|
|
||||||
![lookups usage example graph](https://raw.githubusercontent.com/dwringer/generative-grammar-prompt-nodes/main/lookuptables_usage.jpg)
|
|
||||||
|
|
||||||
--------------------------------
|
--------------------------------
|
||||||
### Image and Mask Composition Pack
|
### Image and Mask Composition Pack
|
||||||
@ -208,45 +146,88 @@ This includes 15 Nodes:
|
|||||||
- *Text Mask (simple 2D)* - create and position a white on black (or black on white) line of text using any font locally available to Invoke.
|
- *Text Mask (simple 2D)* - create and position a white on black (or black on white) line of text using any font locally available to Invoke.
|
||||||
|
|
||||||
**Node Link:** https://github.com/dwringer/composition-nodes
|
**Node Link:** https://github.com/dwringer/composition-nodes
|
||||||
|
|
||||||
**Nodes and Output Examples:**
|
</br><img src="https://raw.githubusercontent.com/dwringer/composition-nodes/main/composition_pack_overview.jpg" width="500" />
|
||||||
![composition nodes usage graph](https://raw.githubusercontent.com/dwringer/composition-nodes/main/composition_pack_overview.jpg)
|
|
||||||
|
|
||||||
--------------------------------
|
--------------------------------
|
||||||
### Size Stepper Nodes
|
### Image to Character Art Image Nodes
|
||||||
|
|
||||||
**Description:** This is a set of nodes for calculating the necessary size increments for doing upscaling workflows. Use the *Final Size & Orientation* node to enter your full size dimensions and orientation (portrait/landscape/random), then plug that and your initial generation dimensions into the *Ideal Size Stepper* and get 1, 2, or 3 intermediate pairs of dimensions for upscaling. Note this does not output the initial size or full size dimensions: the 1, 2, or 3 outputs of this node are only the intermediate sizes.
|
**Description:** Group of nodes to convert an input image into ascii/unicode art Image
|
||||||
|
|
||||||
A third node is included, *Random Switch (Integers)*, which is just a generic version of Final Size with no orientation selection.
|
**Node Link:** https://github.com/mickr777/imagetoasciiimage
|
||||||
|
|
||||||
**Node Link:** https://github.com/dwringer/size-stepper-nodes
|
|
||||||
|
|
||||||
**Example Usage:**
|
|
||||||
![size stepper usage graph](https://raw.githubusercontent.com/dwringer/size-stepper-nodes/main/size_nodes_usage.jpg)
|
|
||||||
|
|
||||||
--------------------------------
|
|
||||||
|
|
||||||
### Text font to Image
|
|
||||||
|
|
||||||
**Description:** text font to text image node for InvokeAI, download a font to use (or if in font cache uses it from there), the text is always resized to the image size, but can control that with padding, optional 2nd line
|
|
||||||
|
|
||||||
**Node Link:** https://github.com/mickr777/textfontimage
|
|
||||||
|
|
||||||
**Output Examples**
|
**Output Examples**
|
||||||
|
|
||||||
![a3609d48-d9b7-41f0-b280-063d857986fb](https://github.com/mickr777/InvokeAI/assets/115216705/c21b0af3-d9c6-4c16-9152-846a23effd36)
|
<img src="https://user-images.githubusercontent.com/115216705/271817646-8e061fcc-9a2c-4fa9-bcc7-c0f7b01e9056.png" width="300" /><img src="https://github.com/mickr777/imagetoasciiimage/assets/115216705/3c4990eb-2f42-46b9-90f9-0088b939dc6a" width="300" /></br>
|
||||||
|
<img src="https://github.com/mickr777/imagetoasciiimage/assets/115216705/fee7f800-a4a8-41e2-a66b-c66e4343307e" width="300" />
|
||||||
Results after using the depth controlnet
|
<img src="https://github.com/mickr777/imagetoasciiimage/assets/115216705/1d9c1003-a45f-45c2-aac7-46470bb89330" width="300" />
|
||||||
|
|
||||||
![9133eabb-bcda-4326-831e-1b641228b178](https://github.com/mickr777/InvokeAI/assets/115216705/915f1a53-968e-43eb-aa61-07cd8f1a733a)
|
|
||||||
![4f9a3fa8-9be9-4236-8a3e-fcec66decd2a](https://github.com/mickr777/InvokeAI/assets/115216705/821ef89e-8a60-44f5-b94e-471a9d8690cc)
|
|
||||||
![babd69c4-9d60-4a55-a834-5e8397f62610](https://github.com/mickr777/InvokeAI/assets/115216705/2befcb6d-49f4-4bfd-b5fc-1fee19274f89)
|
|
||||||
|
|
||||||
--------------------------------
|
--------------------------------
|
||||||
|
|
||||||
|
### Image Picker
|
||||||
|
|
||||||
|
**Description:** This InvokeAI node takes in a collection of images and randomly chooses one. This can be useful when you have a number of poses to choose from for a ControlNet node, or a number of input images for another purpose.
|
||||||
|
|
||||||
|
**Node Link:** https://github.com/JPPhoto/image-picker-node
|
||||||
|
|
||||||
|
--------------------------------
|
||||||
|
### Load Video Frame
|
||||||
|
|
||||||
|
**Description:** This is a video frame image provider + indexer/video creation nodes for hooking up to iterators and ranges and ControlNets and such for invokeAI node experimentation. Think animation + ControlNet outputs.
|
||||||
|
|
||||||
|
**Node Link:** https://github.com/helix4u/load_video_frame
|
||||||
|
|
||||||
|
**Example Node Graph:** https://github.com/helix4u/load_video_frame/blob/main/Example_Workflow.json
|
||||||
|
|
||||||
|
**Output Example:**
|
||||||
|
|
||||||
|
<img src="https://github.com/helix4u/load_video_frame/blob/main/testmp4_embed_converted.gif" width="500" />
|
||||||
|
[Full mp4 of Example Output test.mp4](https://github.com/helix4u/load_video_frame/blob/main/test.mp4)
|
||||||
|
|
||||||
|
--------------------------------
|
||||||
|
### Make 3D
|
||||||
|
|
||||||
|
**Description:** Create compelling 3D stereo images from 2D originals.
|
||||||
|
|
||||||
|
**Node Link:** [https://gitlab.com/srcrr/shift3d/-/raw/main/make3d.py](https://gitlab.com/srcrr/shift3d)
|
||||||
|
|
||||||
|
**Example Node Graph:** https://gitlab.com/srcrr/shift3d/-/raw/main/example-workflow.json?ref_type=heads&inline=false
|
||||||
|
|
||||||
|
**Output Examples**
|
||||||
|
|
||||||
|
<img src="https://gitlab.com/srcrr/shift3d/-/raw/main/example-1.png" width="300" />
|
||||||
|
<img src="https://gitlab.com/srcrr/shift3d/-/raw/main/example-2.png" width="300" />
|
||||||
|
|
||||||
|
--------------------------------
|
||||||
|
### Oobabooga
|
||||||
|
|
||||||
|
**Description:** asks a local LLM running in Oobabooga's Text-Generation-Webui to write a prompt based on the user input.
|
||||||
|
|
||||||
|
**Link:** https://github.com/sammyf/oobabooga-node
|
||||||
|
|
||||||
|
**Example:**
|
||||||
|
|
||||||
|
"describe a new mystical creature in its natural environment"
|
||||||
|
|
||||||
|
*can return*
|
||||||
|
|
||||||
|
"The mystical creature I am describing to you is called the "Glimmerwing". It is a majestic, iridescent being that inhabits the depths of the most enchanted forests and glimmering lakes. Its body is covered in shimmering scales that reflect every color of the rainbow, and it has delicate, translucent wings that sparkle like diamonds in the sunlight. The Glimmerwing's home is a crystal-clear lake, surrounded by towering trees with leaves that shimmer like jewels. In this serene environment, the Glimmerwing spends its days swimming gracefully through the water, chasing schools of glittering fish and playing with the gentle ripples of the lake's surface.
|
||||||
|
As the sun sets, the Glimmerwing perches on a branch of one of the trees, spreading its wings to catch the last rays of light. The creature's scales glow softly, casting a rainbow of colors across the forest floor. The Glimmerwing sings a haunting melody, its voice echoing through the stillness of the night air. Its song is said to have the power to heal the sick and bring peace to troubled souls. Those who are lucky enough to hear the Glimmerwing's song are forever changed by its beauty and grace."
|
||||||
|
|
||||||
|
<img src="https://github.com/sammyf/oobabooga-node/assets/42468608/cecdd820-93dd-4c35-abbf-607e001fb2ed" width="300" />
|
||||||
|
|
||||||
|
**Requirement**
|
||||||
|
|
||||||
|
a Text-Generation-Webui instance (might work remotely too, but I never tried it) and obviously InvokeAI 3.x
|
||||||
|
|
||||||
|
**Note**
|
||||||
|
|
||||||
|
This node works best with SDXL models, especially as the style can be described independently of the LLM's output.
|
||||||
|
|
||||||
|
--------------------------------
|
||||||
### Prompt Tools
|
### Prompt Tools
|
||||||
|
|
||||||
**Description:** A set of InvokeAI nodes that add general prompt manipulation tools. These where written to accompany the PromptsFromFile node and other prompt generation nodes.
|
**Description:** A set of InvokeAI nodes that add general prompt manipulation tools. These were written to accompany the PromptsFromFile node and other prompt generation nodes.
|
||||||
|
|
||||||
1. PromptJoin - Joins to prompts into one.
|
1. PromptJoin - Joins to prompts into one.
|
||||||
2. PromptReplace - performs a search and replace on a prompt. With the option of using regex.
|
2. PromptReplace - performs a search and replace on a prompt. With the option of using regex.
|
||||||
@ -263,51 +244,83 @@ See full docs here: https://github.com/skunkworxdark/Prompt-tools-nodes/edit/mai
|
|||||||
**Node Link:** https://github.com/skunkworxdark/Prompt-tools-nodes
|
**Node Link:** https://github.com/skunkworxdark/Prompt-tools-nodes
|
||||||
|
|
||||||
--------------------------------
|
--------------------------------
|
||||||
|
### Retroize
|
||||||
|
|
||||||
|
**Description:** Retroize is a collection of nodes for InvokeAI to "Retroize" images. Any image can be given a fresh coat of retro paint with these nodes, either from your gallery or from within the graph itself. It includes nodes to pixelize, quantize, palettize, and ditherize images; as well as to retrieve palettes from existing images.
|
||||||
|
|
||||||
|
**Node Link:** https://github.com/Ar7ific1al/invokeai-retroizeinode/
|
||||||
|
|
||||||
|
**Retroize Output Examples**
|
||||||
|
|
||||||
|
<img src="https://github.com/Ar7ific1al/InvokeAI_nodes_retroize/assets/2306586/de8b4fa6-324c-4c2d-b36c-297600c73974" width="500" />
|
||||||
|
|
||||||
|
--------------------------------
|
||||||
|
### Size Stepper Nodes
|
||||||
|
|
||||||
|
**Description:** This is a set of nodes for calculating the necessary size increments for doing upscaling workflows. Use the *Final Size & Orientation* node to enter your full size dimensions and orientation (portrait/landscape/random), then plug that and your initial generation dimensions into the *Ideal Size Stepper* and get 1, 2, or 3 intermediate pairs of dimensions for upscaling. Note this does not output the initial size or full size dimensions: the 1, 2, or 3 outputs of this node are only the intermediate sizes.
|
||||||
|
|
||||||
|
A third node is included, *Random Switch (Integers)*, which is just a generic version of Final Size with no orientation selection.
|
||||||
|
|
||||||
|
**Node Link:** https://github.com/dwringer/size-stepper-nodes
|
||||||
|
|
||||||
|
**Example Usage:**
|
||||||
|
</br><img src="https://raw.githubusercontent.com/dwringer/size-stepper-nodes/main/size_nodes_usage.jpg" width="500" />
|
||||||
|
|
||||||
|
--------------------------------
|
||||||
|
### Text font to Image
|
||||||
|
|
||||||
|
**Description:** text font to text image node for InvokeAI, download a font to use (or if in font cache uses it from there), the text is always resized to the image size, but can control that with padding, optional 2nd line
|
||||||
|
|
||||||
|
**Node Link:** https://github.com/mickr777/textfontimage
|
||||||
|
|
||||||
|
**Output Examples**
|
||||||
|
|
||||||
|
<img src="https://github.com/mickr777/InvokeAI/assets/115216705/c21b0af3-d9c6-4c16-9152-846a23effd36" width="300" />
|
||||||
|
|
||||||
|
Results after using the depth controlnet
|
||||||
|
|
||||||
|
<img src="https://github.com/mickr777/InvokeAI/assets/115216705/915f1a53-968e-43eb-aa61-07cd8f1a733a" width="300" />
|
||||||
|
<img src="https://github.com/mickr777/InvokeAI/assets/115216705/821ef89e-8a60-44f5-b94e-471a9d8690cc" width="300" />
|
||||||
|
<img src="https://github.com/mickr777/InvokeAI/assets/115216705/2befcb6d-49f4-4bfd-b5fc-1fee19274f89" width="300" />
|
||||||
|
|
||||||
|
--------------------------------
|
||||||
|
### Thresholding
|
||||||
|
|
||||||
|
**Description:** This node generates masks for highlights, midtones, and shadows given an input image. You can optionally specify a blur for the lookup table used in making those masks from the source image.
|
||||||
|
|
||||||
|
**Node Link:** https://github.com/JPPhoto/thresholding-node
|
||||||
|
|
||||||
|
**Examples**
|
||||||
|
|
||||||
|
Input:
|
||||||
|
|
||||||
|
<img src="https://github.com/invoke-ai/InvokeAI/assets/34005131/c88ada13-fb3d-484c-a4fe-947b44712632" width="300" />
|
||||||
|
|
||||||
|
Highlights/Midtones/Shadows:
|
||||||
|
|
||||||
|
<img src="https://github.com/invoke-ai/InvokeAI/assets/34005131/727021c1-36ff-4ec8-90c8-105e00de986d" width="300" />
|
||||||
|
<img src="https://github.com/invoke-ai/InvokeAI/assets/34005131/0b721bfc-f051-404e-b905-2f16b824ddfe" width="300" />
|
||||||
|
<img src="https://github.com/invoke-ai/InvokeAI/assets/34005131/04c1297f-1c88-42b6-a7df-dd090b976286" width="300" />
|
||||||
|
|
||||||
|
Highlights/Midtones/Shadows (with LUT blur enabled):
|
||||||
|
|
||||||
|
<img src="https://github.com/invoke-ai/InvokeAI/assets/34005131/19aa718a-70c1-4668-8169-d68f4bd13771" width="300" />
|
||||||
|
<img src="https://github.com/invoke-ai/InvokeAI/assets/34005131/0a440e43-697f-4d17-82ee-f287467df0a5" width="300" />
|
||||||
|
<img src="https://github.com/invoke-ai/InvokeAI/assets/34005131/0701fd0f-2ca7-4fe2-8613-2b52547bafce" width="300" />
|
||||||
|
|
||||||
|
--------------------------------
|
||||||
### XY Image to Grid and Images to Grids nodes
|
### XY Image to Grid and Images to Grids nodes
|
||||||
|
|
||||||
**Description:** Image to grid nodes and supporting tools.
|
**Description:** Image to grid nodes and supporting tools.
|
||||||
|
|
||||||
1. "Images To Grids" node - Takes a collection of images and creates a grid(s) of images. If there are more images than the size of a single grid then mutilple grids will be created until it runs out of images.
|
1. "Images To Grids" node - Takes a collection of images and creates a grid(s) of images. If there are more images than the size of a single grid then multiple grids will be created until it runs out of images.
|
||||||
2. "XYImage To Grid" node - Converts a collection of XYImages into a labeled Grid of images. The XYImages collection has to be built using the supporoting nodes. See example node setups for more details.
|
2. "XYImage To Grid" node - Converts a collection of XYImages into a labeled Grid of images. The XYImages collection has to be built using the supporting nodes. See example node setups for more details.
|
||||||
|
|
||||||
|
|
||||||
See full docs here: https://github.com/skunkworxdark/XYGrid_nodes/edit/main/README.md
|
See full docs here: https://github.com/skunkworxdark/XYGrid_nodes/edit/main/README.md
|
||||||
|
|
||||||
**Node Link:** https://github.com/skunkworxdark/XYGrid_nodes
|
**Node Link:** https://github.com/skunkworxdark/XYGrid_nodes
|
||||||
|
|
||||||
--------------------------------
|
--------------------------------
|
||||||
|
|
||||||
### Image to Character Art Image Node's
|
|
||||||
|
|
||||||
**Description:** Group of nodes to convert an input image into ascii/unicode art Image
|
|
||||||
|
|
||||||
**Node Link:** https://github.com/mickr777/imagetoasciiimage
|
|
||||||
|
|
||||||
**Output Examples**
|
|
||||||
|
|
||||||
<img src="https://github.com/invoke-ai/InvokeAI/assets/115216705/8e061fcc-9a2c-4fa9-bcc7-c0f7b01e9056" width="300" />
|
|
||||||
<img src="https://github.com/mickr777/imagetoasciiimage/assets/115216705/3c4990eb-2f42-46b9-90f9-0088b939dc6a" width="300" /></br>
|
|
||||||
<img src="https://github.com/mickr777/imagetoasciiimage/assets/115216705/fee7f800-a4a8-41e2-a66b-c66e4343307e" width="300" />
|
|
||||||
<img src="https://github.com/mickr777/imagetoasciiimage/assets/115216705/1d9c1003-a45f-45c2-aac7-46470bb89330" width="300" />
|
|
||||||
|
|
||||||
--------------------------------
|
|
||||||
|
|
||||||
### Grid to Gif
|
|
||||||
|
|
||||||
**Description:** One node that turns a grid image into an image colletion, one node that turns an image collection into a gif
|
|
||||||
|
|
||||||
**Node Link:** https://github.com/mildmisery/invokeai-GridToGifNode/blob/main/GridToGif.py
|
|
||||||
|
|
||||||
**Example Node Graph:** https://github.com/mildmisery/invokeai-GridToGifNode/blob/main/Grid%20to%20Gif%20Example%20Workflow.json
|
|
||||||
|
|
||||||
**Output Examples**
|
|
||||||
|
|
||||||
<img src="https://raw.githubusercontent.com/mildmisery/invokeai-GridToGifNode/main/input.png" width="300" />
|
|
||||||
<img src="https://raw.githubusercontent.com/mildmisery/invokeai-GridToGifNode/main/output.gif" width="300" />
|
|
||||||
|
|
||||||
--------------------------------
|
|
||||||
|
|
||||||
### Example Node Template
|
### Example Node Template
|
||||||
|
|
||||||
**Description:** This node allows you to do super cool things with InvokeAI.
|
**Description:** This node allows you to do super cool things with InvokeAI.
|
||||||
@ -318,7 +331,7 @@ See full docs here: https://github.com/skunkworxdark/XYGrid_nodes/edit/main/READ
|
|||||||
|
|
||||||
**Output Examples**
|
**Output Examples**
|
||||||
|
|
||||||
![Example Image](https://invoke-ai.github.io/InvokeAI/assets/invoke_ai_banner.png){: style="height:115px;width:240px"}
|
</br><img src="https://invoke-ai.github.io/InvokeAI/assets/invoke_ai_banner.png" width="500" />
|
||||||
|
|
||||||
|
|
||||||
## Disclaimer
|
## Disclaimer
|
||||||
|
@ -46,6 +46,8 @@ class FaceResultData(TypedDict):
|
|||||||
y_center: float
|
y_center: float
|
||||||
mesh_width: int
|
mesh_width: int
|
||||||
mesh_height: int
|
mesh_height: int
|
||||||
|
chunk_x_offset: int
|
||||||
|
chunk_y_offset: int
|
||||||
|
|
||||||
|
|
||||||
class FaceResultDataWithId(FaceResultData):
|
class FaceResultDataWithId(FaceResultData):
|
||||||
@ -78,6 +80,48 @@ FONT_SIZE = 32
|
|||||||
FONT_STROKE_WIDTH = 4
|
FONT_STROKE_WIDTH = 4
|
||||||
|
|
||||||
|
|
||||||
|
def coalesce_faces(face1: FaceResultData, face2: FaceResultData) -> FaceResultData:
|
||||||
|
face1_x_offset = face1["chunk_x_offset"] - min(face1["chunk_x_offset"], face2["chunk_x_offset"])
|
||||||
|
face2_x_offset = face2["chunk_x_offset"] - min(face1["chunk_x_offset"], face2["chunk_x_offset"])
|
||||||
|
face1_y_offset = face1["chunk_y_offset"] - min(face1["chunk_y_offset"], face2["chunk_y_offset"])
|
||||||
|
face2_y_offset = face2["chunk_y_offset"] - min(face1["chunk_y_offset"], face2["chunk_y_offset"])
|
||||||
|
|
||||||
|
new_im_width = (
|
||||||
|
max(face1["image"].width, face2["image"].width)
|
||||||
|
+ max(face1["chunk_x_offset"], face2["chunk_x_offset"])
|
||||||
|
- min(face1["chunk_x_offset"], face2["chunk_x_offset"])
|
||||||
|
)
|
||||||
|
new_im_height = (
|
||||||
|
max(face1["image"].height, face2["image"].height)
|
||||||
|
+ max(face1["chunk_y_offset"], face2["chunk_y_offset"])
|
||||||
|
- min(face1["chunk_y_offset"], face2["chunk_y_offset"])
|
||||||
|
)
|
||||||
|
pil_image = Image.new(mode=face1["image"].mode, size=(new_im_width, new_im_height))
|
||||||
|
pil_image.paste(face1["image"], (face1_x_offset, face1_y_offset))
|
||||||
|
pil_image.paste(face2["image"], (face2_x_offset, face2_y_offset))
|
||||||
|
|
||||||
|
# Mask images are always from the origin
|
||||||
|
new_mask_im_width = max(face1["mask"].width, face2["mask"].width)
|
||||||
|
new_mask_im_height = max(face1["mask"].height, face2["mask"].height)
|
||||||
|
mask_pil = create_white_image(new_mask_im_width, new_mask_im_height)
|
||||||
|
black_image = create_black_image(face1["mask"].width, face1["mask"].height)
|
||||||
|
mask_pil.paste(black_image, (0, 0), ImageOps.invert(face1["mask"]))
|
||||||
|
black_image = create_black_image(face2["mask"].width, face2["mask"].height)
|
||||||
|
mask_pil.paste(black_image, (0, 0), ImageOps.invert(face2["mask"]))
|
||||||
|
|
||||||
|
new_face = FaceResultData(
|
||||||
|
image=pil_image,
|
||||||
|
mask=mask_pil,
|
||||||
|
x_center=max(face1["x_center"], face2["x_center"]),
|
||||||
|
y_center=max(face1["y_center"], face2["y_center"]),
|
||||||
|
mesh_width=max(face1["mesh_width"], face2["mesh_width"]),
|
||||||
|
mesh_height=max(face1["mesh_height"], face2["mesh_height"]),
|
||||||
|
chunk_x_offset=max(face1["chunk_x_offset"], face2["chunk_x_offset"]),
|
||||||
|
chunk_y_offset=max(face2["chunk_y_offset"], face2["chunk_y_offset"]),
|
||||||
|
)
|
||||||
|
return new_face
|
||||||
|
|
||||||
|
|
||||||
def prepare_faces_list(
|
def prepare_faces_list(
|
||||||
face_result_list: list[FaceResultData],
|
face_result_list: list[FaceResultData],
|
||||||
) -> list[FaceResultDataWithId]:
|
) -> list[FaceResultDataWithId]:
|
||||||
@ -91,7 +135,7 @@ def prepare_faces_list(
|
|||||||
should_add = True
|
should_add = True
|
||||||
candidate_x_center = candidate["x_center"]
|
candidate_x_center = candidate["x_center"]
|
||||||
candidate_y_center = candidate["y_center"]
|
candidate_y_center = candidate["y_center"]
|
||||||
for face in deduped_faces:
|
for idx, face in enumerate(deduped_faces):
|
||||||
face_center_x = face["x_center"]
|
face_center_x = face["x_center"]
|
||||||
face_center_y = face["y_center"]
|
face_center_y = face["y_center"]
|
||||||
face_radius_w = face["mesh_width"] / 2
|
face_radius_w = face["mesh_width"] / 2
|
||||||
@ -105,6 +149,7 @@ def prepare_faces_list(
|
|||||||
)
|
)
|
||||||
|
|
||||||
if p < 1: # Inside of the already-added face's radius
|
if p < 1: # Inside of the already-added face's radius
|
||||||
|
deduped_faces[idx] = coalesce_faces(face, candidate)
|
||||||
should_add = False
|
should_add = False
|
||||||
break
|
break
|
||||||
|
|
||||||
@ -138,7 +183,6 @@ def generate_face_box_mask(
|
|||||||
chunk_x_offset: int = 0,
|
chunk_x_offset: int = 0,
|
||||||
chunk_y_offset: int = 0,
|
chunk_y_offset: int = 0,
|
||||||
draw_mesh: bool = True,
|
draw_mesh: bool = True,
|
||||||
check_bounds: bool = True,
|
|
||||||
) -> list[FaceResultData]:
|
) -> list[FaceResultData]:
|
||||||
result = []
|
result = []
|
||||||
mask_pil = None
|
mask_pil = None
|
||||||
@ -211,33 +255,20 @@ def generate_face_box_mask(
|
|||||||
mask_pil = create_white_image(w + chunk_x_offset, h + chunk_y_offset)
|
mask_pil = create_white_image(w + chunk_x_offset, h + chunk_y_offset)
|
||||||
mask_pil.paste(init_mask_pil, (chunk_x_offset, chunk_y_offset))
|
mask_pil.paste(init_mask_pil, (chunk_x_offset, chunk_y_offset))
|
||||||
|
|
||||||
left_side = x_center - mesh_width
|
x_center = float(x_center)
|
||||||
right_side = x_center + mesh_width
|
y_center = float(y_center)
|
||||||
top_side = y_center - mesh_height
|
face = FaceResultData(
|
||||||
bottom_side = y_center + mesh_height
|
image=pil_image,
|
||||||
im_width, im_height = pil_image.size
|
mask=mask_pil or create_white_image(*pil_image.size),
|
||||||
over_w = im_width * 0.1
|
x_center=x_center + chunk_x_offset,
|
||||||
over_h = im_height * 0.1
|
y_center=y_center + chunk_y_offset,
|
||||||
if not check_bounds or (
|
mesh_width=mesh_width,
|
||||||
(left_side >= -over_w)
|
mesh_height=mesh_height,
|
||||||
and (right_side < im_width + over_w)
|
chunk_x_offset=chunk_x_offset,
|
||||||
and (top_side >= -over_h)
|
chunk_y_offset=chunk_y_offset,
|
||||||
and (bottom_side < im_height + over_h)
|
)
|
||||||
):
|
|
||||||
x_center = float(x_center)
|
|
||||||
y_center = float(y_center)
|
|
||||||
face = FaceResultData(
|
|
||||||
image=pil_image,
|
|
||||||
mask=mask_pil or create_white_image(*pil_image.size),
|
|
||||||
x_center=x_center + chunk_x_offset,
|
|
||||||
y_center=y_center + chunk_y_offset,
|
|
||||||
mesh_width=mesh_width,
|
|
||||||
mesh_height=mesh_height,
|
|
||||||
)
|
|
||||||
|
|
||||||
result.append(face)
|
result.append(face)
|
||||||
else:
|
|
||||||
context.services.logger.info("FaceTools --> Face out of bounds, ignoring.")
|
|
||||||
|
|
||||||
return result
|
return result
|
||||||
|
|
||||||
@ -346,7 +377,6 @@ def get_faces_list(
|
|||||||
chunk_x_offset=0,
|
chunk_x_offset=0,
|
||||||
chunk_y_offset=0,
|
chunk_y_offset=0,
|
||||||
draw_mesh=draw_mesh,
|
draw_mesh=draw_mesh,
|
||||||
check_bounds=False,
|
|
||||||
)
|
)
|
||||||
if should_chunk or len(result) == 0:
|
if should_chunk or len(result) == 0:
|
||||||
context.services.logger.info("FaceTools --> Chunking image (chunk toggled on, or no face found in full image).")
|
context.services.logger.info("FaceTools --> Chunking image (chunk toggled on, or no face found in full image).")
|
||||||
@ -360,24 +390,26 @@ def get_faces_list(
|
|||||||
if width > height:
|
if width > height:
|
||||||
# Landscape - slice the image horizontally
|
# Landscape - slice the image horizontally
|
||||||
fx = 0.0
|
fx = 0.0
|
||||||
steps = int(width * 2 / height)
|
steps = int(width * 2 / height) + 1
|
||||||
|
increment = (width - height) / (steps - 1)
|
||||||
while fx <= (width - height):
|
while fx <= (width - height):
|
||||||
x = int(fx)
|
x = int(fx)
|
||||||
image_chunks.append(image.crop((x, 0, x + height - 1, height - 1)))
|
image_chunks.append(image.crop((x, 0, x + height, height)))
|
||||||
x_offsets.append(x)
|
x_offsets.append(x)
|
||||||
y_offsets.append(0)
|
y_offsets.append(0)
|
||||||
fx += (width - height) / steps
|
fx += increment
|
||||||
context.services.logger.info(f"FaceTools --> Chunk starting at x = {x}")
|
context.services.logger.info(f"FaceTools --> Chunk starting at x = {x}")
|
||||||
elif height > width:
|
elif height > width:
|
||||||
# Portrait - slice the image vertically
|
# Portrait - slice the image vertically
|
||||||
fy = 0.0
|
fy = 0.0
|
||||||
steps = int(height * 2 / width)
|
steps = int(height * 2 / width) + 1
|
||||||
|
increment = (height - width) / (steps - 1)
|
||||||
while fy <= (height - width):
|
while fy <= (height - width):
|
||||||
y = int(fy)
|
y = int(fy)
|
||||||
image_chunks.append(image.crop((0, y, width - 1, y + width - 1)))
|
image_chunks.append(image.crop((0, y, width, y + width)))
|
||||||
x_offsets.append(0)
|
x_offsets.append(0)
|
||||||
y_offsets.append(y)
|
y_offsets.append(y)
|
||||||
fy += (height - width) / steps
|
fy += increment
|
||||||
context.services.logger.info(f"FaceTools --> Chunk starting at y = {y}")
|
context.services.logger.info(f"FaceTools --> Chunk starting at y = {y}")
|
||||||
|
|
||||||
for idx in range(len(image_chunks)):
|
for idx in range(len(image_chunks)):
|
||||||
@ -404,7 +436,7 @@ def get_faces_list(
|
|||||||
return all_faces
|
return all_faces
|
||||||
|
|
||||||
|
|
||||||
@invocation("face_off", title="FaceOff", tags=["image", "faceoff", "face", "mask"], category="image", version="1.0.1")
|
@invocation("face_off", title="FaceOff", tags=["image", "faceoff", "face", "mask"], category="image", version="1.0.2")
|
||||||
class FaceOffInvocation(BaseInvocation):
|
class FaceOffInvocation(BaseInvocation):
|
||||||
"""Bound, extract, and mask a face from an image using MediaPipe detection"""
|
"""Bound, extract, and mask a face from an image using MediaPipe detection"""
|
||||||
|
|
||||||
@ -498,7 +530,7 @@ class FaceOffInvocation(BaseInvocation):
|
|||||||
return output
|
return output
|
||||||
|
|
||||||
|
|
||||||
@invocation("face_mask_detection", title="FaceMask", tags=["image", "face", "mask"], category="image", version="1.0.1")
|
@invocation("face_mask_detection", title="FaceMask", tags=["image", "face", "mask"], category="image", version="1.0.2")
|
||||||
class FaceMaskInvocation(BaseInvocation):
|
class FaceMaskInvocation(BaseInvocation):
|
||||||
"""Face mask creation using mediapipe face detection"""
|
"""Face mask creation using mediapipe face detection"""
|
||||||
|
|
||||||
@ -616,7 +648,7 @@ class FaceMaskInvocation(BaseInvocation):
|
|||||||
|
|
||||||
|
|
||||||
@invocation(
|
@invocation(
|
||||||
"face_identifier", title="FaceIdentifier", tags=["image", "face", "identifier"], category="image", version="1.0.1"
|
"face_identifier", title="FaceIdentifier", tags=["image", "face", "identifier"], category="image", version="1.0.2"
|
||||||
)
|
)
|
||||||
class FaceIdentifierInvocation(BaseInvocation):
|
class FaceIdentifierInvocation(BaseInvocation):
|
||||||
"""Outputs an image with detected face IDs printed on each face. For use with other FaceTools."""
|
"""Outputs an image with detected face IDs printed on each face. For use with other FaceTools."""
|
||||||
|
@ -44,28 +44,31 @@ class CoreMetadata(BaseModelExcludeNull):
|
|||||||
"""Core generation metadata for an image generated in InvokeAI."""
|
"""Core generation metadata for an image generated in InvokeAI."""
|
||||||
|
|
||||||
app_version: str = Field(default=__version__, description="The version of InvokeAI used to generate this image")
|
app_version: str = Field(default=__version__, description="The version of InvokeAI used to generate this image")
|
||||||
generation_mode: str = Field(
|
generation_mode: Optional[str] = Field(
|
||||||
|
default=None,
|
||||||
description="The generation mode that output this image",
|
description="The generation mode that output this image",
|
||||||
)
|
)
|
||||||
created_by: Optional[str] = Field(description="The name of the creator of the image")
|
created_by: Optional[str] = Field(description="The name of the creator of the image")
|
||||||
positive_prompt: str = Field(description="The positive prompt parameter")
|
positive_prompt: Optional[str] = Field(default=None, description="The positive prompt parameter")
|
||||||
negative_prompt: str = Field(description="The negative prompt parameter")
|
negative_prompt: Optional[str] = Field(default=None, description="The negative prompt parameter")
|
||||||
width: int = Field(description="The width parameter")
|
width: Optional[int] = Field(default=None, description="The width parameter")
|
||||||
height: int = Field(description="The height parameter")
|
height: Optional[int] = Field(default=None, description="The height parameter")
|
||||||
seed: int = Field(description="The seed used for noise generation")
|
seed: Optional[int] = Field(default=None, description="The seed used for noise generation")
|
||||||
rand_device: str = Field(description="The device used for random number generation")
|
rand_device: Optional[str] = Field(default=None, description="The device used for random number generation")
|
||||||
cfg_scale: float = Field(description="The classifier-free guidance scale parameter")
|
cfg_scale: Optional[float] = Field(default=None, description="The classifier-free guidance scale parameter")
|
||||||
steps: int = Field(description="The number of steps used for inference")
|
steps: Optional[int] = Field(default=None, description="The number of steps used for inference")
|
||||||
scheduler: str = Field(description="The scheduler used for inference")
|
scheduler: Optional[str] = Field(default=None, description="The scheduler used for inference")
|
||||||
clip_skip: Optional[int] = Field(
|
clip_skip: Optional[int] = Field(
|
||||||
default=None,
|
default=None,
|
||||||
description="The number of skipped CLIP layers",
|
description="The number of skipped CLIP layers",
|
||||||
)
|
)
|
||||||
model: MainModelField = Field(description="The main model used for inference")
|
model: Optional[MainModelField] = Field(default=None, description="The main model used for inference")
|
||||||
controlnets: list[ControlField] = Field(description="The ControlNets used for inference")
|
controlnets: Optional[list[ControlField]] = Field(default=None, description="The ControlNets used for inference")
|
||||||
ipAdapters: list[IPAdapterMetadataField] = Field(description="The IP Adapters used for inference")
|
ipAdapters: Optional[list[IPAdapterMetadataField]] = Field(
|
||||||
t2iAdapters: list[T2IAdapterField] = Field(description="The IP Adapters used for inference")
|
default=None, description="The IP Adapters used for inference"
|
||||||
loras: list[LoRAMetadataField] = Field(description="The LoRAs used for inference")
|
)
|
||||||
|
t2iAdapters: Optional[list[T2IAdapterField]] = Field(default=None, description="The IP Adapters used for inference")
|
||||||
|
loras: Optional[list[LoRAMetadataField]] = Field(default=None, description="The LoRAs used for inference")
|
||||||
vae: Optional[VAEModelField] = Field(
|
vae: Optional[VAEModelField] = Field(
|
||||||
default=None,
|
default=None,
|
||||||
description="The VAE used for decoding, if the main model's default was not used",
|
description="The VAE used for decoding, if the main model's default was not used",
|
||||||
@ -122,27 +125,34 @@ class MetadataAccumulatorOutput(BaseInvocationOutput):
|
|||||||
class MetadataAccumulatorInvocation(BaseInvocation):
|
class MetadataAccumulatorInvocation(BaseInvocation):
|
||||||
"""Outputs a Core Metadata Object"""
|
"""Outputs a Core Metadata Object"""
|
||||||
|
|
||||||
generation_mode: str = InputField(
|
generation_mode: Optional[str] = InputField(
|
||||||
|
default=None,
|
||||||
description="The generation mode that output this image",
|
description="The generation mode that output this image",
|
||||||
)
|
)
|
||||||
positive_prompt: str = InputField(description="The positive prompt parameter")
|
positive_prompt: Optional[str] = InputField(default=None, description="The positive prompt parameter")
|
||||||
negative_prompt: str = InputField(description="The negative prompt parameter")
|
negative_prompt: Optional[str] = InputField(default=None, description="The negative prompt parameter")
|
||||||
width: int = InputField(description="The width parameter")
|
width: Optional[int] = InputField(default=None, description="The width parameter")
|
||||||
height: int = InputField(description="The height parameter")
|
height: Optional[int] = InputField(default=None, description="The height parameter")
|
||||||
seed: int = InputField(description="The seed used for noise generation")
|
seed: Optional[int] = InputField(default=None, description="The seed used for noise generation")
|
||||||
rand_device: str = InputField(description="The device used for random number generation")
|
rand_device: Optional[str] = InputField(default=None, description="The device used for random number generation")
|
||||||
cfg_scale: float = InputField(description="The classifier-free guidance scale parameter")
|
cfg_scale: Optional[float] = InputField(default=None, description="The classifier-free guidance scale parameter")
|
||||||
steps: int = InputField(description="The number of steps used for inference")
|
steps: Optional[int] = InputField(default=None, description="The number of steps used for inference")
|
||||||
scheduler: str = InputField(description="The scheduler used for inference")
|
scheduler: Optional[str] = InputField(default=None, description="The scheduler used for inference")
|
||||||
clip_skip: Optional[int] = Field(
|
clip_skip: Optional[int] = InputField(
|
||||||
default=None,
|
default=None,
|
||||||
description="The number of skipped CLIP layers",
|
description="The number of skipped CLIP layers",
|
||||||
)
|
)
|
||||||
model: MainModelField = InputField(description="The main model used for inference")
|
model: Optional[MainModelField] = InputField(default=None, description="The main model used for inference")
|
||||||
controlnets: list[ControlField] = InputField(description="The ControlNets used for inference")
|
controlnets: Optional[list[ControlField]] = InputField(
|
||||||
ipAdapters: list[IPAdapterMetadataField] = InputField(description="The IP Adapters used for inference")
|
default=None, description="The ControlNets used for inference"
|
||||||
t2iAdapters: list[T2IAdapterField] = Field(description="The IP Adapters used for inference")
|
)
|
||||||
loras: list[LoRAMetadataField] = InputField(description="The LoRAs used for inference")
|
ipAdapters: Optional[list[IPAdapterMetadataField]] = InputField(
|
||||||
|
default=None, description="The IP Adapters used for inference"
|
||||||
|
)
|
||||||
|
t2iAdapters: Optional[list[T2IAdapterField]] = InputField(
|
||||||
|
default=None, description="The IP Adapters used for inference"
|
||||||
|
)
|
||||||
|
loras: Optional[list[LoRAMetadataField]] = InputField(default=None, description="The LoRAs used for inference")
|
||||||
strength: Optional[float] = InputField(
|
strength: Optional[float] = InputField(
|
||||||
default=None,
|
default=None,
|
||||||
description="The strength used for latents-to-latents",
|
description="The strength used for latents-to-latents",
|
||||||
@ -158,9 +168,11 @@ class MetadataAccumulatorInvocation(BaseInvocation):
|
|||||||
|
|
||||||
# High resolution fix metadata.
|
# High resolution fix metadata.
|
||||||
hrf_width: Optional[int] = InputField(
|
hrf_width: Optional[int] = InputField(
|
||||||
|
default=None,
|
||||||
description="The high resolution fix height and width multipler.",
|
description="The high resolution fix height and width multipler.",
|
||||||
)
|
)
|
||||||
hrf_height: Optional[int] = InputField(
|
hrf_height: Optional[int] = InputField(
|
||||||
|
default=None,
|
||||||
description="The high resolution fix height and width multipler.",
|
description="The high resolution fix height and width multipler.",
|
||||||
)
|
)
|
||||||
hrf_strength: Optional[float] = InputField(
|
hrf_strength: Optional[float] = InputField(
|
||||||
|
@ -55,8 +55,10 @@ class MemorySnapshot:
|
|||||||
|
|
||||||
try:
|
try:
|
||||||
malloc_info = LibcUtil().mallinfo2()
|
malloc_info = LibcUtil().mallinfo2()
|
||||||
except OSError:
|
except (OSError, AttributeError):
|
||||||
# This is expected in environments that do not have the 'libc.so.6' shared library.
|
# OSError: This is expected in environments that do not have the 'libc.so.6' shared library.
|
||||||
|
# AttributeError: This is expected in environments that have `libc.so.6` but do not have the `mallinfo2` (e.g. glibc < 2.33)
|
||||||
|
# TODO: Does `mallinfo` work?
|
||||||
malloc_info = None
|
malloc_info = None
|
||||||
|
|
||||||
return cls(process_ram, vram, malloc_info)
|
return cls(process_ram, vram, malloc_info)
|
||||||
|
@ -54,42 +54,42 @@
|
|||||||
]
|
]
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@chakra-ui/anatomy": "^2.2.0",
|
"@chakra-ui/anatomy": "^2.2.1",
|
||||||
"@chakra-ui/icons": "^2.1.0",
|
"@chakra-ui/icons": "^2.1.1",
|
||||||
"@chakra-ui/react": "^2.8.0",
|
"@chakra-ui/react": "^2.8.1",
|
||||||
"@chakra-ui/styled-system": "^2.9.1",
|
"@chakra-ui/styled-system": "^2.9.1",
|
||||||
"@chakra-ui/theme-tools": "^2.1.0",
|
"@chakra-ui/theme-tools": "^2.1.1",
|
||||||
"@dagrejs/graphlib": "^2.1.13",
|
"@dagrejs/graphlib": "^2.1.13",
|
||||||
"@dnd-kit/core": "^6.0.8",
|
"@dnd-kit/core": "^6.0.8",
|
||||||
"@dnd-kit/modifiers": "^6.0.1",
|
"@dnd-kit/modifiers": "^6.0.1",
|
||||||
"@dnd-kit/utilities": "^3.2.1",
|
"@dnd-kit/utilities": "^3.2.1",
|
||||||
"@emotion/react": "^11.11.1",
|
"@emotion/react": "^11.11.1",
|
||||||
"@emotion/styled": "^11.11.0",
|
"@emotion/styled": "^11.11.0",
|
||||||
"@floating-ui/react-dom": "^2.0.1",
|
"@floating-ui/react-dom": "^2.0.2",
|
||||||
"@fontsource-variable/inter": "^5.0.8",
|
"@fontsource-variable/inter": "^5.0.13",
|
||||||
"@fontsource/inter": "^5.0.8",
|
"@fontsource/inter": "^5.0.13",
|
||||||
"@mantine/core": "^6.0.19",
|
"@mantine/core": "^6.0.19",
|
||||||
"@mantine/form": "^6.0.19",
|
"@mantine/form": "^6.0.19",
|
||||||
"@mantine/hooks": "^6.0.19",
|
"@mantine/hooks": "^6.0.19",
|
||||||
"@nanostores/react": "^0.7.1",
|
"@nanostores/react": "^0.7.1",
|
||||||
"@reduxjs/toolkit": "^1.9.5",
|
"@reduxjs/toolkit": "^1.9.7",
|
||||||
"@roarr/browser-log-writer": "^1.1.5",
|
"@roarr/browser-log-writer": "^1.3.0",
|
||||||
"@stevebel/png": "^1.5.1",
|
"@stevebel/png": "^1.5.1",
|
||||||
"compare-versions": "^6.1.0",
|
"compare-versions": "^6.1.0",
|
||||||
"dateformat": "^5.0.3",
|
"dateformat": "^5.0.3",
|
||||||
"formik": "^2.4.3",
|
"formik": "^2.4.5",
|
||||||
"framer-motion": "^10.16.1",
|
"framer-motion": "^10.16.4",
|
||||||
"fuse.js": "^6.6.2",
|
"fuse.js": "^6.6.2",
|
||||||
"i18next": "^23.4.4",
|
"i18next": "^23.5.1",
|
||||||
"i18next-browser-languagedetector": "^7.0.2",
|
"i18next-browser-languagedetector": "^7.0.2",
|
||||||
"i18next-http-backend": "^2.2.1",
|
"i18next-http-backend": "^2.2.2",
|
||||||
"konva": "^9.2.0",
|
"konva": "^9.2.2",
|
||||||
"lodash-es": "^4.17.21",
|
"lodash-es": "^4.17.21",
|
||||||
"nanostores": "^0.9.2",
|
"nanostores": "^0.9.2",
|
||||||
"new-github-issue-url": "^1.0.0",
|
"new-github-issue-url": "^1.0.0",
|
||||||
"openapi-fetch": "^0.7.4",
|
"openapi-fetch": "^0.7.10",
|
||||||
"overlayscrollbars": "^2.2.0",
|
"overlayscrollbars": "^2.3.2",
|
||||||
"overlayscrollbars-react": "^0.5.0",
|
"overlayscrollbars-react": "^0.5.2",
|
||||||
"patch-package": "^8.0.0",
|
"patch-package": "^8.0.0",
|
||||||
"query-string": "^8.1.0",
|
"query-string": "^8.1.0",
|
||||||
"react": "^18.2.0",
|
"react": "^18.2.0",
|
||||||
@ -98,25 +98,25 @@
|
|||||||
"react-dropzone": "^14.2.3",
|
"react-dropzone": "^14.2.3",
|
||||||
"react-error-boundary": "^4.0.11",
|
"react-error-boundary": "^4.0.11",
|
||||||
"react-hotkeys-hook": "4.4.1",
|
"react-hotkeys-hook": "4.4.1",
|
||||||
"react-i18next": "^13.1.2",
|
"react-i18next": "^13.3.0",
|
||||||
"react-icons": "^4.10.1",
|
"react-icons": "^4.11.0",
|
||||||
"react-konva": "^18.2.10",
|
"react-konva": "^18.2.10",
|
||||||
"react-redux": "^8.1.2",
|
"react-redux": "^8.1.3",
|
||||||
"react-resizable-panels": "^0.0.55",
|
"react-resizable-panels": "^0.0.55",
|
||||||
"react-use": "^17.4.0",
|
"react-use": "^17.4.0",
|
||||||
"react-virtuoso": "^4.5.0",
|
"react-virtuoso": "^4.6.1",
|
||||||
"react-zoom-pan-pinch": "^3.0.8",
|
"react-zoom-pan-pinch": "^3.2.0",
|
||||||
"reactflow": "^11.8.3",
|
"reactflow": "^11.9.3",
|
||||||
"redux-dynamic-middlewares": "^2.2.0",
|
"redux-dynamic-middlewares": "^2.2.0",
|
||||||
"redux-remember": "^4.0.1",
|
"redux-remember": "^4.0.4",
|
||||||
"roarr": "^7.15.1",
|
"roarr": "^7.15.1",
|
||||||
"serialize-error": "^11.0.1",
|
"serialize-error": "^11.0.2",
|
||||||
"socket.io-client": "^4.7.2",
|
"socket.io-client": "^4.7.2",
|
||||||
"type-fest": "^4.2.0",
|
"type-fest": "^4.4.0",
|
||||||
"use-debounce": "^9.0.4",
|
"use-debounce": "^9.0.4",
|
||||||
"use-image": "^1.1.1",
|
"use-image": "^1.1.1",
|
||||||
"uuid": "^9.0.0",
|
"uuid": "^9.0.1",
|
||||||
"zod": "^3.22.2",
|
"zod": "^3.22.4",
|
||||||
"zod-validation-error": "^1.5.0"
|
"zod-validation-error": "^1.5.0"
|
||||||
},
|
},
|
||||||
"peerDependencies": {
|
"peerDependencies": {
|
||||||
@ -129,40 +129,40 @@
|
|||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@chakra-ui/cli": "^2.4.1",
|
"@chakra-ui/cli": "^2.4.1",
|
||||||
"@types/dateformat": "^5.0.0",
|
"@types/dateformat": "^5.0.0",
|
||||||
"@types/lodash-es": "^4.14.194",
|
"@types/lodash-es": "^4.17.9",
|
||||||
"@types/node": "^20.5.1",
|
"@types/node": "^20.8.6",
|
||||||
"@types/react": "^18.2.20",
|
"@types/react": "^18.2.28",
|
||||||
"@types/react-dom": "^18.2.6",
|
"@types/react-dom": "^18.2.13",
|
||||||
"@types/react-redux": "^7.1.25",
|
"@types/react-redux": "^7.1.27",
|
||||||
"@types/react-transition-group": "^4.4.6",
|
"@types/react-transition-group": "^4.4.7",
|
||||||
"@types/uuid": "^9.0.2",
|
"@types/uuid": "^9.0.5",
|
||||||
"@typescript-eslint/eslint-plugin": "^6.4.1",
|
"@typescript-eslint/eslint-plugin": "^6.7.5",
|
||||||
"@typescript-eslint/parser": "^6.4.1",
|
"@typescript-eslint/parser": "^6.7.5",
|
||||||
"@vitejs/plugin-react-swc": "^3.3.2",
|
"@vitejs/plugin-react-swc": "^3.4.0",
|
||||||
"axios": "^1.4.0",
|
"axios": "^1.5.1",
|
||||||
"babel-plugin-transform-imports": "^2.0.0",
|
"babel-plugin-transform-imports": "^2.0.0",
|
||||||
"concurrently": "^8.2.0",
|
"concurrently": "^8.2.1",
|
||||||
"eslint": "^8.47.0",
|
"eslint": "^8.51.0",
|
||||||
"eslint-config-prettier": "^9.0.0",
|
"eslint-config-prettier": "^9.0.0",
|
||||||
"eslint-plugin-prettier": "^5.0.0",
|
"eslint-plugin-prettier": "^5.0.1",
|
||||||
"eslint-plugin-react": "^7.33.2",
|
"eslint-plugin-react": "^7.33.2",
|
||||||
"eslint-plugin-react-hooks": "^4.6.0",
|
"eslint-plugin-react-hooks": "^4.6.0",
|
||||||
"form-data": "^4.0.0",
|
"form-data": "^4.0.0",
|
||||||
"husky": "^8.0.3",
|
"husky": "^8.0.3",
|
||||||
"lint-staged": "^14.0.1",
|
"lint-staged": "^15.0.1",
|
||||||
"madge": "^6.1.0",
|
"madge": "^6.1.0",
|
||||||
"openapi-types": "^12.1.3",
|
"openapi-types": "^12.1.3",
|
||||||
"openapi-typescript": "^6.5.2",
|
"openapi-typescript": "^6.7.0",
|
||||||
"postinstall-postinstall": "^2.1.0",
|
"postinstall-postinstall": "^2.1.0",
|
||||||
"prettier": "^3.0.2",
|
"prettier": "^3.0.3",
|
||||||
"rollup-plugin-visualizer": "^5.9.2",
|
"rollup-plugin-visualizer": "^5.9.2",
|
||||||
"ts-toolbelt": "^9.6.0",
|
"ts-toolbelt": "^9.6.0",
|
||||||
"typescript": "^5.2.2",
|
"typescript": "^5.2.2",
|
||||||
"vite": "^4.4.9",
|
"vite": "^4.4.11",
|
||||||
"vite-plugin-css-injected-by-js": "^3.3.0",
|
"vite-plugin-css-injected-by-js": "^3.3.0",
|
||||||
"vite-plugin-dts": "^3.5.2",
|
"vite-plugin-dts": "^3.6.0",
|
||||||
"vite-plugin-eslint": "^1.8.1",
|
"vite-plugin-eslint": "^1.8.1",
|
||||||
"vite-tsconfig-paths": "^4.2.0",
|
"vite-tsconfig-paths": "^4.2.1",
|
||||||
"yarn": "^1.22.19"
|
"yarn": "^1.22.19"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1115,6 +1115,7 @@
|
|||||||
"showProgressInViewer": "Show Progress Images in Viewer",
|
"showProgressInViewer": "Show Progress Images in Viewer",
|
||||||
"ui": "User Interface",
|
"ui": "User Interface",
|
||||||
"useSlidersForAll": "Use Sliders For All Options",
|
"useSlidersForAll": "Use Sliders For All Options",
|
||||||
|
"clearIntermediatesDisabled": "Queue must be empty to clear intermediates",
|
||||||
"clearIntermediatesDesc1": "Clearing intermediates will reset your Canvas and ControlNet state.",
|
"clearIntermediatesDesc1": "Clearing intermediates will reset your Canvas and ControlNet state.",
|
||||||
"clearIntermediatesDesc2": "Intermediate images are byproducts of generation, different from the result images in the gallery. Clearing intermediates will free disk space.",
|
"clearIntermediatesDesc2": "Intermediate images are byproducts of generation, different from the result images in the gallery. Clearing intermediates will free disk space.",
|
||||||
"clearIntermediatesDesc3": "Your gallery images will not be deleted.",
|
"clearIntermediatesDesc3": "Your gallery images will not be deleted.",
|
||||||
|
@ -87,7 +87,8 @@
|
|||||||
"learnMore": "Per saperne di più",
|
"learnMore": "Per saperne di più",
|
||||||
"ipAdapter": "Adattatore IP",
|
"ipAdapter": "Adattatore IP",
|
||||||
"t2iAdapter": "Adattatore T2I",
|
"t2iAdapter": "Adattatore T2I",
|
||||||
"controlAdapter": "Adattatore di Controllo"
|
"controlAdapter": "Adattatore di Controllo",
|
||||||
|
"controlNet": "ControlNet"
|
||||||
},
|
},
|
||||||
"gallery": {
|
"gallery": {
|
||||||
"generations": "Generazioni",
|
"generations": "Generazioni",
|
||||||
@ -471,7 +472,8 @@
|
|||||||
"useCustomConfig": "Utilizza configurazione personalizzata",
|
"useCustomConfig": "Utilizza configurazione personalizzata",
|
||||||
"closeAdvanced": "Chiudi Avanzate",
|
"closeAdvanced": "Chiudi Avanzate",
|
||||||
"modelType": "Tipo di modello",
|
"modelType": "Tipo di modello",
|
||||||
"customConfigFileLocation": "Posizione del file di configurazione personalizzato"
|
"customConfigFileLocation": "Posizione del file di configurazione personalizzato",
|
||||||
|
"vaePrecision": "Precisione VAE"
|
||||||
},
|
},
|
||||||
"parameters": {
|
"parameters": {
|
||||||
"images": "Immagini",
|
"images": "Immagini",
|
||||||
@ -573,9 +575,9 @@
|
|||||||
"systemBusy": "Sistema occupato",
|
"systemBusy": "Sistema occupato",
|
||||||
"unableToInvoke": "Impossibile invocare",
|
"unableToInvoke": "Impossibile invocare",
|
||||||
"systemDisconnected": "Sistema disconnesso",
|
"systemDisconnected": "Sistema disconnesso",
|
||||||
"noControlImageForControlAdapter": "L'adattatore di controllo {{number}} non ha un'immagine di controllo",
|
"noControlImageForControlAdapter": "L'adattatore di controllo #{{number}} non ha un'immagine di controllo",
|
||||||
"noModelForControlAdapter": "Nessun modello selezionato per l'adattatore di controllo {{number}}.",
|
"noModelForControlAdapter": "Nessun modello selezionato per l'adattatore di controllo #{{number}}.",
|
||||||
"incompatibleBaseModelForControlAdapter": "Il modello dell'adattatore di controllo {{number}} non è compatibile con il modello principale.",
|
"incompatibleBaseModelForControlAdapter": "Il modello dell'adattatore di controllo #{{number}} non è compatibile con il modello principale.",
|
||||||
"missingNodeTemplate": "Modello di nodo mancante"
|
"missingNodeTemplate": "Modello di nodo mancante"
|
||||||
},
|
},
|
||||||
"enableNoiseSettings": "Abilita le impostazioni del rumore",
|
"enableNoiseSettings": "Abilita le impostazioni del rumore",
|
||||||
@ -628,8 +630,8 @@
|
|||||||
"clearIntermediates": "Cancella le immagini intermedie",
|
"clearIntermediates": "Cancella le immagini intermedie",
|
||||||
"clearIntermediatesDesc3": "Le immagini della galleria non verranno eliminate.",
|
"clearIntermediatesDesc3": "Le immagini della galleria non verranno eliminate.",
|
||||||
"clearIntermediatesDesc2": "Le immagini intermedie sono sottoprodotti della generazione, diversi dalle immagini risultanti nella galleria. La cancellazione degli intermedi libererà spazio su disco.",
|
"clearIntermediatesDesc2": "Le immagini intermedie sono sottoprodotti della generazione, diversi dalle immagini risultanti nella galleria. La cancellazione degli intermedi libererà spazio su disco.",
|
||||||
"intermediatesCleared_one": "Cancellata 1 immagine intermedia",
|
"intermediatesCleared_one": "Cancellata {{count}} immagine intermedia",
|
||||||
"intermediatesCleared_many": "Cancellate {{number}} immagini intermedie",
|
"intermediatesCleared_many": "Cancellate {{count}} immagini intermedie",
|
||||||
"intermediatesCleared_other": "",
|
"intermediatesCleared_other": "",
|
||||||
"clearIntermediatesDesc1": "La cancellazione delle immagini intermedie ripristinerà lo stato di Tela Unificata e ControlNet.",
|
"clearIntermediatesDesc1": "La cancellazione delle immagini intermedie ripristinerà lo stato di Tela Unificata e ControlNet.",
|
||||||
"intermediatesClearedFailed": "Problema con la cancellazione delle immagini intermedie"
|
"intermediatesClearedFailed": "Problema con la cancellazione delle immagini intermedie"
|
||||||
@ -682,8 +684,8 @@
|
|||||||
"nodesUnrecognizedTypes": "Impossibile caricare. Il grafico ha tipi di dati non riconosciuti",
|
"nodesUnrecognizedTypes": "Impossibile caricare. Il grafico ha tipi di dati non riconosciuti",
|
||||||
"nodesNotValidJSON": "JSON non valido",
|
"nodesNotValidJSON": "JSON non valido",
|
||||||
"nodesBrokenConnections": "Impossibile caricare. Alcune connessioni sono interrotte.",
|
"nodesBrokenConnections": "Impossibile caricare. Alcune connessioni sono interrotte.",
|
||||||
"baseModelChangedCleared_one": "Il modello base è stato modificato, cancellato o disabilitato {{number}} sotto-modello incompatibile",
|
"baseModelChangedCleared_one": "Il modello base è stato modificato, cancellato o disabilitato {{count}} sotto-modello incompatibile",
|
||||||
"baseModelChangedCleared_many": "",
|
"baseModelChangedCleared_many": "Il modello base è stato modificato, cancellato o disabilitato {{count}} sotto-modelli incompatibili",
|
||||||
"baseModelChangedCleared_other": "",
|
"baseModelChangedCleared_other": "",
|
||||||
"imageSavingFailed": "Salvataggio dell'immagine non riuscito",
|
"imageSavingFailed": "Salvataggio dell'immagine non riuscito",
|
||||||
"canvasSentControlnetAssets": "Tela inviata a ControlNet & Risorse",
|
"canvasSentControlnetAssets": "Tela inviata a ControlNet & Risorse",
|
||||||
@ -897,7 +899,63 @@
|
|||||||
"notesDescription": "Aggiunge note sul tuo flusso di lavoro",
|
"notesDescription": "Aggiunge note sul tuo flusso di lavoro",
|
||||||
"unknownField": "Campo sconosciuto",
|
"unknownField": "Campo sconosciuto",
|
||||||
"unknownNode": "Nodo sconosciuto",
|
"unknownNode": "Nodo sconosciuto",
|
||||||
"vaeFieldDescription": "Sotto modello VAE."
|
"vaeFieldDescription": "Sotto modello VAE.",
|
||||||
|
"booleanPolymorphicDescription": "Una raccolta di booleani.",
|
||||||
|
"missingTemplate": "Modello mancante",
|
||||||
|
"outputSchemaNotFound": "Schema di output non trovato",
|
||||||
|
"colorFieldDescription": "Un colore RGBA.",
|
||||||
|
"maybeIncompatible": "Potrebbe essere incompatibile con quello installato",
|
||||||
|
"noNodeSelected": "Nessun nodo selezionato",
|
||||||
|
"colorPolymorphic": "Colore polimorfico",
|
||||||
|
"booleanCollectionDescription": "Una raccolta di booleani.",
|
||||||
|
"colorField": "Colore",
|
||||||
|
"nodeTemplate": "Modello di nodo",
|
||||||
|
"nodeOpacity": "Opacità del nodo",
|
||||||
|
"pickOne": "Sceglierne uno",
|
||||||
|
"outputField": "Campo di output",
|
||||||
|
"nodeSearch": "Cerca nodi",
|
||||||
|
"nodeOutputs": "Uscite del nodo",
|
||||||
|
"collectionItem": "Oggetto della raccolta",
|
||||||
|
"noConnectionInProgress": "Nessuna connessione in corso",
|
||||||
|
"noConnectionData": "Nessun dato di connessione",
|
||||||
|
"outputFields": "Campi di output",
|
||||||
|
"cannotDuplicateConnection": "Impossibile creare connessioni duplicate",
|
||||||
|
"booleanPolymorphic": "Polimorfico booleano",
|
||||||
|
"colorPolymorphicDescription": "Una collezione di colori polimorfici.",
|
||||||
|
"missingCanvaInitImage": "Immagine iniziale della tela mancante",
|
||||||
|
"clipFieldDescription": "Sottomodelli di tokenizzatore e codificatore di testo.",
|
||||||
|
"noImageFoundState": "Nessuna immagine iniziale trovata nello stato",
|
||||||
|
"clipField": "CLIP",
|
||||||
|
"noMatchingNodes": "Nessun nodo corrispondente",
|
||||||
|
"noFieldType": "Nessun tipo di campo",
|
||||||
|
"colorCollection": "Una collezione di colori.",
|
||||||
|
"noOutputSchemaName": "Nessun nome dello schema di output trovato nell'oggetto di riferimento",
|
||||||
|
"boolean": "Booleani",
|
||||||
|
"missingCanvaInitMaskImages": "Immagini di inizializzazione e maschera della tela mancanti",
|
||||||
|
"oNNXModelField": "Modello ONNX",
|
||||||
|
"node": "Nodo",
|
||||||
|
"booleanDescription": "I booleani sono veri o falsi.",
|
||||||
|
"collection": "Raccolta",
|
||||||
|
"cannotConnectInputToInput": "Impossibile collegare Input a Input",
|
||||||
|
"cannotConnectOutputToOutput": "Impossibile collegare Output ad Output",
|
||||||
|
"booleanCollection": "Raccolta booleana",
|
||||||
|
"cannotConnectToSelf": "Impossibile connettersi a se stesso",
|
||||||
|
"mismatchedVersion": "Ha una versione non corrispondente",
|
||||||
|
"outputNode": "Nodo di Output",
|
||||||
|
"loadingNodes": "Caricamento nodi...",
|
||||||
|
"oNNXModelFieldDescription": "Campo del modello ONNX.",
|
||||||
|
"denoiseMaskFieldDescription": "La maschera di riduzione del rumore può essere passata tra i nodi",
|
||||||
|
"floatCollectionDescription": "Una raccolta di numeri virgola mobile.",
|
||||||
|
"enum": "Enumeratore",
|
||||||
|
"float": "In virgola mobile",
|
||||||
|
"doesNotExist": "non esiste",
|
||||||
|
"currentImageDescription": "Visualizza l'immagine corrente nell'editor dei nodi",
|
||||||
|
"fieldTypesMustMatch": "I tipi di campo devono corrispondere",
|
||||||
|
"edge": "Bordo",
|
||||||
|
"enumDescription": "Gli enumeratori sono valori che possono essere una delle diverse opzioni.",
|
||||||
|
"denoiseMaskField": "Maschera riduzione rumore",
|
||||||
|
"currentImage": "Immagine corrente",
|
||||||
|
"floatCollection": "Raccolta in virgola mobile"
|
||||||
},
|
},
|
||||||
"boards": {
|
"boards": {
|
||||||
"autoAddBoard": "Aggiungi automaticamente bacheca",
|
"autoAddBoard": "Aggiungi automaticamente bacheca",
|
||||||
@ -983,8 +1041,12 @@
|
|||||||
"addControlNet": "Aggiungi $t(common.controlNet)",
|
"addControlNet": "Aggiungi $t(common.controlNet)",
|
||||||
"controlNetT2IMutexDesc": "$t(common.controlNet) e $t(common.t2iAdapter) contemporaneamente non sono attualmente supportati.",
|
"controlNetT2IMutexDesc": "$t(common.controlNet) e $t(common.t2iAdapter) contemporaneamente non sono attualmente supportati.",
|
||||||
"addIPAdapter": "Aggiungi $t(common.ipAdapter)",
|
"addIPAdapter": "Aggiungi $t(common.ipAdapter)",
|
||||||
"controlAdapter": "Adattatore di Controllo",
|
"controlAdapter_one": "Adattatore di Controllo",
|
||||||
"megaControl": "Mega ControlNet"
|
"controlAdapter_many": "Adattatori di Controllo",
|
||||||
|
"controlAdapter_other": "Adattatori di Controllo",
|
||||||
|
"megaControl": "Mega ControlNet",
|
||||||
|
"minConfidence": "Confidenza minima",
|
||||||
|
"scribble": "Scribble"
|
||||||
},
|
},
|
||||||
"queue": {
|
"queue": {
|
||||||
"queueFront": "Aggiungi all'inizio della coda",
|
"queueFront": "Aggiungi all'inizio della coda",
|
||||||
@ -1011,7 +1073,9 @@
|
|||||||
"pause": "Sospendi",
|
"pause": "Sospendi",
|
||||||
"pruneTooltip": "Rimuovi {{item_count}} elementi completati",
|
"pruneTooltip": "Rimuovi {{item_count}} elementi completati",
|
||||||
"cancelSucceeded": "Elemento annullato",
|
"cancelSucceeded": "Elemento annullato",
|
||||||
"batchQueuedDesc": "Aggiunte {{item_count}} sessioni a {{direction}} della coda",
|
"batchQueuedDesc_one": "Aggiunta {{count}} sessione a {{direction}} della coda",
|
||||||
|
"batchQueuedDesc_many": "Aggiunte {{count}} sessioni a {{direction}} della coda",
|
||||||
|
"batchQueuedDesc_other": "",
|
||||||
"graphQueued": "Grafico in coda",
|
"graphQueued": "Grafico in coda",
|
||||||
"batch": "Lotto",
|
"batch": "Lotto",
|
||||||
"clearQueueAlertDialog": "Lo svuotamento della coda annulla immediatamente tutti gli elementi in elaborazione e cancella completamente la coda.",
|
"clearQueueAlertDialog": "Lo svuotamento della coda annulla immediatamente tutti gli elementi in elaborazione e cancella completamente la coda.",
|
||||||
@ -1100,7 +1164,9 @@
|
|||||||
},
|
},
|
||||||
"compositingMaskAdjustments": {
|
"compositingMaskAdjustments": {
|
||||||
"heading": "Regolazioni della maschera",
|
"heading": "Regolazioni della maschera",
|
||||||
"paragraphs": ["Regola la maschera."]
|
"paragraphs": [
|
||||||
|
"Regola la maschera."
|
||||||
|
]
|
||||||
},
|
},
|
||||||
"compositingCoherenceSteps": {
|
"compositingCoherenceSteps": {
|
||||||
"heading": "Passi",
|
"heading": "Passi",
|
||||||
@ -1111,11 +1177,15 @@
|
|||||||
},
|
},
|
||||||
"compositingBlur": {
|
"compositingBlur": {
|
||||||
"heading": "Sfocatura",
|
"heading": "Sfocatura",
|
||||||
"paragraphs": ["Il raggio di sfocatura della maschera."]
|
"paragraphs": [
|
||||||
|
"Il raggio di sfocatura della maschera."
|
||||||
|
]
|
||||||
},
|
},
|
||||||
"compositingCoherenceMode": {
|
"compositingCoherenceMode": {
|
||||||
"heading": "Modalità",
|
"heading": "Modalità",
|
||||||
"paragraphs": ["La modalità del Passaggio di Coerenza."]
|
"paragraphs": [
|
||||||
|
"La modalità del Passaggio di Coerenza."
|
||||||
|
]
|
||||||
},
|
},
|
||||||
"clipSkip": {
|
"clipSkip": {
|
||||||
"paragraphs": [
|
"paragraphs": [
|
||||||
@ -1255,7 +1325,9 @@
|
|||||||
]
|
]
|
||||||
},
|
},
|
||||||
"infillMethod": {
|
"infillMethod": {
|
||||||
"paragraphs": ["Metodo per riempire l'area selezionata."],
|
"paragraphs": [
|
||||||
|
"Metodo per riempire l'area selezionata."
|
||||||
|
],
|
||||||
"heading": "Metodo di riempimento"
|
"heading": "Metodo di riempimento"
|
||||||
},
|
},
|
||||||
"controlNetWeight": {
|
"controlNetWeight": {
|
||||||
@ -1271,7 +1343,9 @@
|
|||||||
]
|
]
|
||||||
},
|
},
|
||||||
"controlNetControlMode": {
|
"controlNetControlMode": {
|
||||||
"paragraphs": ["Attribuisce più peso al prompt o a ControlNet."],
|
"paragraphs": [
|
||||||
|
"Attribuisce più peso al prompt o a ControlNet."
|
||||||
|
],
|
||||||
"heading": "Modalità di controllo"
|
"heading": "Modalità di controllo"
|
||||||
},
|
},
|
||||||
"paramSteps": {
|
"paramSteps": {
|
||||||
@ -1290,7 +1364,8 @@
|
|||||||
"controlNet": {
|
"controlNet": {
|
||||||
"paragraphs": [
|
"paragraphs": [
|
||||||
"ControlNet fornisce una guida al processo di generazione, aiutando a creare immagini con composizione, struttura o stile controllati, a seconda del modello selezionato."
|
"ControlNet fornisce una guida al processo di generazione, aiutando a creare immagini con composizione, struttura o stile controllati, a seconda del modello selezionato."
|
||||||
]
|
],
|
||||||
|
"heading": "ControlNet"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"sdxl": {
|
"sdxl": {
|
||||||
@ -1335,6 +1410,8 @@
|
|||||||
"createdBy": "Creato da",
|
"createdBy": "Creato da",
|
||||||
"workflow": "Flusso di lavoro",
|
"workflow": "Flusso di lavoro",
|
||||||
"steps": "Passi",
|
"steps": "Passi",
|
||||||
"scheduler": "Campionatore"
|
"scheduler": "Campionatore",
|
||||||
|
"recallParameters": "Richiama i parametri",
|
||||||
|
"noRecallParameters": "Nessun parametro da richiamare trovato"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -79,7 +79,18 @@
|
|||||||
"modelManager": "Modelbeheer",
|
"modelManager": "Modelbeheer",
|
||||||
"darkMode": "Donkere modus",
|
"darkMode": "Donkere modus",
|
||||||
"lightMode": "Lichte modus",
|
"lightMode": "Lichte modus",
|
||||||
"communityLabel": "Gemeenschap"
|
"communityLabel": "Gemeenschap",
|
||||||
|
"t2iAdapter": "T2I-adapter",
|
||||||
|
"on": "Aan",
|
||||||
|
"nodeEditor": "Knooppunteditor",
|
||||||
|
"ipAdapter": "IP-adapter",
|
||||||
|
"controlAdapter": "Control-adapter",
|
||||||
|
"auto": "Autom.",
|
||||||
|
"controlNet": "ControlNet",
|
||||||
|
"statusProcessing": "Bezig met verwerken",
|
||||||
|
"imageFailedToLoad": "Kan afbeelding niet laden",
|
||||||
|
"learnMore": "Meer informatie",
|
||||||
|
"advanced": "Uitgebreid"
|
||||||
},
|
},
|
||||||
"gallery": {
|
"gallery": {
|
||||||
"generations": "Gegenereerde afbeeldingen",
|
"generations": "Gegenereerde afbeeldingen",
|
||||||
@ -100,7 +111,17 @@
|
|||||||
"deleteImagePermanent": "Gewiste afbeeldingen kunnen niet worden hersteld.",
|
"deleteImagePermanent": "Gewiste afbeeldingen kunnen niet worden hersteld.",
|
||||||
"assets": "Eigen onderdelen",
|
"assets": "Eigen onderdelen",
|
||||||
"images": "Afbeeldingen",
|
"images": "Afbeeldingen",
|
||||||
"autoAssignBoardOnClick": "Ken automatisch bord toe bij klikken"
|
"autoAssignBoardOnClick": "Ken automatisch bord toe bij klikken",
|
||||||
|
"featuresWillReset": "Als je deze afbeelding verwijdert, dan worden deze functies onmiddellijk teruggezet.",
|
||||||
|
"loading": "Bezig met laden",
|
||||||
|
"unableToLoad": "Kan galerij niet laden",
|
||||||
|
"preparingDownload": "Bezig met voorbereiden van download",
|
||||||
|
"preparingDownloadFailed": "Fout bij voorbereiden van download",
|
||||||
|
"downloadSelection": "Download selectie",
|
||||||
|
"currentlyInUse": "Deze afbeelding is momenteel in gebruik door de volgende functies:",
|
||||||
|
"copy": "Kopieer",
|
||||||
|
"download": "Download",
|
||||||
|
"setCurrentImage": "Stel in als huidige afbeelding"
|
||||||
},
|
},
|
||||||
"hotkeys": {
|
"hotkeys": {
|
||||||
"keyboardShortcuts": "Sneltoetsen",
|
"keyboardShortcuts": "Sneltoetsen",
|
||||||
@ -332,7 +353,7 @@
|
|||||||
"config": "Configuratie",
|
"config": "Configuratie",
|
||||||
"configValidationMsg": "Pad naar het configuratiebestand van je model.",
|
"configValidationMsg": "Pad naar het configuratiebestand van je model.",
|
||||||
"modelLocation": "Locatie model",
|
"modelLocation": "Locatie model",
|
||||||
"modelLocationValidationMsg": "Pad naar waar je model zich bevindt.",
|
"modelLocationValidationMsg": "Geef het pad naar een lokale map waar je Diffusers-model wordt bewaard",
|
||||||
"vaeLocation": "Locatie VAE",
|
"vaeLocation": "Locatie VAE",
|
||||||
"vaeLocationValidationMsg": "Pad naar waar je VAE zich bevindt.",
|
"vaeLocationValidationMsg": "Pad naar waar je VAE zich bevindt.",
|
||||||
"width": "Breedte",
|
"width": "Breedte",
|
||||||
@ -444,7 +465,17 @@
|
|||||||
"syncModelsDesc": "Als je modellen niet meer synchroon zijn met de backend, kan je ze met deze optie verversen. Dit wordt typisch gebruikt in het geval je het models.yaml bestand met de hand bewerkt of als je modellen aan de InvokeAI root map toevoegt nadat de applicatie gestart werd.",
|
"syncModelsDesc": "Als je modellen niet meer synchroon zijn met de backend, kan je ze met deze optie verversen. Dit wordt typisch gebruikt in het geval je het models.yaml bestand met de hand bewerkt of als je modellen aan de InvokeAI root map toevoegt nadat de applicatie gestart werd.",
|
||||||
"loraModels": "LoRA's",
|
"loraModels": "LoRA's",
|
||||||
"onnxModels": "Onnx",
|
"onnxModels": "Onnx",
|
||||||
"oliveModels": "Olives"
|
"oliveModels": "Olives",
|
||||||
|
"noModels": "Geen modellen gevonden",
|
||||||
|
"predictionType": "Soort voorspelling (voor Stable Diffusion 2.x-modellen en incidentele Stable Diffusion 1.x-modellen)",
|
||||||
|
"quickAdd": "Voeg snel toe",
|
||||||
|
"simpleModelDesc": "Geef een pad naar een lokaal Diffusers-model, lokale-checkpoint- / safetensors-model, een HuggingFace-repo-ID of een url naar een checkpoint- / Diffusers-model.",
|
||||||
|
"advanced": "Uitgebreid",
|
||||||
|
"useCustomConfig": "Gebruik eigen configuratie",
|
||||||
|
"closeAdvanced": "Sluit uitgebreid",
|
||||||
|
"modelType": "Soort model",
|
||||||
|
"customConfigFileLocation": "Locatie eigen configuratiebestand",
|
||||||
|
"vaePrecision": "Nauwkeurigheid VAE"
|
||||||
},
|
},
|
||||||
"parameters": {
|
"parameters": {
|
||||||
"images": "Afbeeldingen",
|
"images": "Afbeeldingen",
|
||||||
@ -465,7 +496,7 @@
|
|||||||
"type": "Soort",
|
"type": "Soort",
|
||||||
"strength": "Sterkte",
|
"strength": "Sterkte",
|
||||||
"upscaling": "Opschalen",
|
"upscaling": "Opschalen",
|
||||||
"upscale": "Schaal op",
|
"upscale": "Vergroot (Shift + U)",
|
||||||
"upscaleImage": "Schaal afbeelding op",
|
"upscaleImage": "Schaal afbeelding op",
|
||||||
"scale": "Schaal",
|
"scale": "Schaal",
|
||||||
"otherOptions": "Andere opties",
|
"otherOptions": "Andere opties",
|
||||||
@ -496,7 +527,7 @@
|
|||||||
"useInitImg": "Gebruik initiële afbeelding",
|
"useInitImg": "Gebruik initiële afbeelding",
|
||||||
"info": "Info",
|
"info": "Info",
|
||||||
"initialImage": "Initiële afbeelding",
|
"initialImage": "Initiële afbeelding",
|
||||||
"showOptionsPanel": "Toon deelscherm Opties",
|
"showOptionsPanel": "Toon deelscherm Opties (O of T)",
|
||||||
"symmetry": "Symmetrie",
|
"symmetry": "Symmetrie",
|
||||||
"hSymmetryStep": "Stap horiz. symmetrie",
|
"hSymmetryStep": "Stap horiz. symmetrie",
|
||||||
"vSymmetryStep": "Stap vert. symmetrie",
|
"vSymmetryStep": "Stap vert. symmetrie",
|
||||||
@ -504,7 +535,8 @@
|
|||||||
"immediate": "Annuleer direct",
|
"immediate": "Annuleer direct",
|
||||||
"isScheduled": "Annuleren",
|
"isScheduled": "Annuleren",
|
||||||
"setType": "Stel annuleervorm in",
|
"setType": "Stel annuleervorm in",
|
||||||
"schedule": "Annuleer na huidige iteratie"
|
"schedule": "Annuleer na huidige iteratie",
|
||||||
|
"cancel": "Annuleer"
|
||||||
},
|
},
|
||||||
"general": "Algemeen",
|
"general": "Algemeen",
|
||||||
"copyImage": "Kopieer afbeelding",
|
"copyImage": "Kopieer afbeelding",
|
||||||
@ -520,7 +552,7 @@
|
|||||||
"boundingBoxWidth": "Tekenvak breedte",
|
"boundingBoxWidth": "Tekenvak breedte",
|
||||||
"boundingBoxHeight": "Tekenvak hoogte",
|
"boundingBoxHeight": "Tekenvak hoogte",
|
||||||
"clipSkip": "Overslaan CLIP",
|
"clipSkip": "Overslaan CLIP",
|
||||||
"aspectRatio": "Verhouding",
|
"aspectRatio": "Beeldverhouding",
|
||||||
"negativePromptPlaceholder": "Negatieve prompt",
|
"negativePromptPlaceholder": "Negatieve prompt",
|
||||||
"controlNetControlMode": "Aansturingsmodus",
|
"controlNetControlMode": "Aansturingsmodus",
|
||||||
"positivePromptPlaceholder": "Positieve prompt",
|
"positivePromptPlaceholder": "Positieve prompt",
|
||||||
@ -532,7 +564,46 @@
|
|||||||
"coherenceSteps": "Stappen",
|
"coherenceSteps": "Stappen",
|
||||||
"coherenceStrength": "Sterkte",
|
"coherenceStrength": "Sterkte",
|
||||||
"seamHighThreshold": "Hoog",
|
"seamHighThreshold": "Hoog",
|
||||||
"seamLowThreshold": "Laag"
|
"seamLowThreshold": "Laag",
|
||||||
|
"invoke": {
|
||||||
|
"noNodesInGraph": "Geen knooppunten in graaf",
|
||||||
|
"noModelSelected": "Geen model ingesteld",
|
||||||
|
"invoke": "Start",
|
||||||
|
"noPrompts": "Geen prompts gegenereerd",
|
||||||
|
"systemBusy": "Systeem is bezig",
|
||||||
|
"noInitialImageSelected": "Geen initiële afbeelding gekozen",
|
||||||
|
"missingInputForField": "{{nodeLabel}} -> {{fieldLabel}} invoer ontbreekt",
|
||||||
|
"noControlImageForControlAdapter": "Controle-adapter #{{number}} heeft geen controle-afbeelding",
|
||||||
|
"noModelForControlAdapter": "Control-adapter #{{number}} heeft geen model ingesteld staan.",
|
||||||
|
"unableToInvoke": "Kan niet starten",
|
||||||
|
"incompatibleBaseModelForControlAdapter": "Model van controle-adapter #{{number}} is ongeldig in combinatie met het hoofdmodel.",
|
||||||
|
"systemDisconnected": "Systeem is niet verbonden",
|
||||||
|
"missingNodeTemplate": "Knooppuntsjabloon ontbreekt",
|
||||||
|
"readyToInvoke": "Klaar om te starten",
|
||||||
|
"missingFieldTemplate": "Veldsjabloon ontbreekt",
|
||||||
|
"addingImagesTo": "Bezig met toevoegen van afbeeldingen aan"
|
||||||
|
},
|
||||||
|
"seamlessX&Y": "Naadloos X en Y",
|
||||||
|
"isAllowedToUpscale": {
|
||||||
|
"useX2Model": "Afbeelding is te groot om te vergroten met het x4-model. Gebruik hiervoor het x2-model",
|
||||||
|
"tooLarge": "Afbeelding is te groot om te vergoten. Kies een kleinere afbeelding"
|
||||||
|
},
|
||||||
|
"aspectRatioFree": "Vrij",
|
||||||
|
"cpuNoise": "CPU-ruis",
|
||||||
|
"patchmatchDownScaleSize": "Verklein",
|
||||||
|
"gpuNoise": "GPU-ruis",
|
||||||
|
"seamlessX": "Naadloos X",
|
||||||
|
"useCpuNoise": "Gebruik CPU-ruis",
|
||||||
|
"clipSkipWithLayerCount": "Overslaan CLIP {{layerCount}}",
|
||||||
|
"seamlessY": "Naadloos Y",
|
||||||
|
"manualSeed": "Handmatige seedwaarde",
|
||||||
|
"imageActions": "Afbeeldingshandeling",
|
||||||
|
"randomSeed": "Willekeurige seedwaarde",
|
||||||
|
"iterations": "Iteraties",
|
||||||
|
"iterationsWithCount_one": "{{count}} iteratie",
|
||||||
|
"iterationsWithCount_other": "{{count}} iteraties",
|
||||||
|
"enableNoiseSettings": "Schakel ruisinstellingen in",
|
||||||
|
"coherenceMode": "Modus"
|
||||||
},
|
},
|
||||||
"settings": {
|
"settings": {
|
||||||
"models": "Modellen",
|
"models": "Modellen",
|
||||||
@ -561,7 +632,16 @@
|
|||||||
"experimental": "Experimenteel",
|
"experimental": "Experimenteel",
|
||||||
"alternateCanvasLayout": "Omwisselen Canvas Layout",
|
"alternateCanvasLayout": "Omwisselen Canvas Layout",
|
||||||
"enableNodesEditor": "Knopen Editor Inschakelen",
|
"enableNodesEditor": "Knopen Editor Inschakelen",
|
||||||
"autoChangeDimensions": "Werk bij wijziging afmetingen bij naar modelstandaard"
|
"autoChangeDimensions": "Werk bij wijziging afmetingen bij naar modelstandaard",
|
||||||
|
"clearIntermediates": "Wis tussentijdse afbeeldingen",
|
||||||
|
"clearIntermediatesDesc3": "Je galerijafbeeldingen zullen niet worden verwijderd.",
|
||||||
|
"clearIntermediatesWithCount_one": "Wis {{count}} tussentijdse afbeelding",
|
||||||
|
"clearIntermediatesWithCount_other": "Wis {{count}} tussentijdse afbeeldingen",
|
||||||
|
"clearIntermediatesDesc2": "Tussentijdse afbeeldingen zijn nevenproducten bij een generatie, die afwijken van de uitvoerafbeeldingen in de galerij. Het wissen van tussentijdse afbeeldingen zal schijfruimte vrijmaken.",
|
||||||
|
"intermediatesCleared_one": "{{count}} tussentijdse afbeelding gewist",
|
||||||
|
"intermediatesCleared_other": "{{count}} tussentijdse afbeeldingen gewist",
|
||||||
|
"clearIntermediatesDesc1": "Het wissen van tussentijdse onderdelen zet de staat van je canvas en ControlNet terug.",
|
||||||
|
"intermediatesClearedFailed": "Fout bij wissen van tussentijdse afbeeldingen"
|
||||||
},
|
},
|
||||||
"toast": {
|
"toast": {
|
||||||
"tempFoldersEmptied": "Tijdelijke map geleegd",
|
"tempFoldersEmptied": "Tijdelijke map geleegd",
|
||||||
@ -610,7 +690,42 @@
|
|||||||
"nodesCorruptedGraph": "Kan niet laden. Graph lijkt corrupt.",
|
"nodesCorruptedGraph": "Kan niet laden. Graph lijkt corrupt.",
|
||||||
"nodesUnrecognizedTypes": "Laden mislukt. Graph heeft onherkenbare types",
|
"nodesUnrecognizedTypes": "Laden mislukt. Graph heeft onherkenbare types",
|
||||||
"nodesBrokenConnections": "Laden mislukt. Sommige verbindingen zijn verbroken.",
|
"nodesBrokenConnections": "Laden mislukt. Sommige verbindingen zijn verbroken.",
|
||||||
"nodesNotValidGraph": "Geen geldige knooppunten graph"
|
"nodesNotValidGraph": "Geen geldige knooppunten graph",
|
||||||
|
"baseModelChangedCleared_one": "Basismodel is gewijzigd: {{count}} niet-compatibel submodel weggehaald of uitgeschakeld",
|
||||||
|
"baseModelChangedCleared_other": "Basismodel is gewijzigd: {{count}} niet-compatibele submodellen weggehaald of uitgeschakeld",
|
||||||
|
"imageSavingFailed": "Fout bij bewaren afbeelding",
|
||||||
|
"canvasSentControlnetAssets": "Canvas gestuurd naar ControlNet en Assets",
|
||||||
|
"problemCopyingCanvasDesc": "Kan basislaag niet exporteren",
|
||||||
|
"loadedWithWarnings": "Werkstroom geladen met waarschuwingen",
|
||||||
|
"setInitialImage": "Ingesteld als initiële afbeelding",
|
||||||
|
"canvasCopiedClipboard": "Canvas gekopieerd naar klembord",
|
||||||
|
"setControlImage": "Ingesteld als controle-afbeelding",
|
||||||
|
"setNodeField": "Ingesteld als knooppuntveld",
|
||||||
|
"problemSavingMask": "Fout bij bewaren masker",
|
||||||
|
"problemSavingCanvasDesc": "Kan basislaag niet exporteren",
|
||||||
|
"maskSavedAssets": "Masker bewaard in Assets",
|
||||||
|
"modelAddFailed": "Fout bij toevoegen model",
|
||||||
|
"problemDownloadingCanvas": "Fout bij downloaden van canvas",
|
||||||
|
"problemMergingCanvas": "Fout bij samenvoegen canvas",
|
||||||
|
"setCanvasInitialImage": "Ingesteld als initiële canvasafbeelding",
|
||||||
|
"imageUploaded": "Afbeelding geüpload",
|
||||||
|
"addedToBoard": "Toegevoegd aan bord",
|
||||||
|
"workflowLoaded": "Werkstroom geladen",
|
||||||
|
"modelAddedSimple": "Model toegevoegd",
|
||||||
|
"problemImportingMaskDesc": "Kan masker niet exporteren",
|
||||||
|
"problemCopyingCanvas": "Fout bij kopiëren canvas",
|
||||||
|
"problemSavingCanvas": "Fout bij bewaren canvas",
|
||||||
|
"canvasDownloaded": "Canvas gedownload",
|
||||||
|
"setIPAdapterImage": "Ingesteld als IP-adapterafbeelding",
|
||||||
|
"problemMergingCanvasDesc": "Kan basislaag niet exporteren",
|
||||||
|
"problemDownloadingCanvasDesc": "Kan basislaag niet exporteren",
|
||||||
|
"problemSavingMaskDesc": "Kan masker niet exporteren",
|
||||||
|
"imageSaved": "Afbeelding bewaard",
|
||||||
|
"maskSentControlnetAssets": "Masker gestuurd naar ControlNet en Assets",
|
||||||
|
"canvasSavedGallery": "Canvas bewaard in galerij",
|
||||||
|
"imageUploadFailed": "Fout bij uploaden afbeelding",
|
||||||
|
"modelAdded": "Model toegevoegd: {{modelName}}",
|
||||||
|
"problemImportingMask": "Fout bij importeren masker"
|
||||||
},
|
},
|
||||||
"tooltip": {
|
"tooltip": {
|
||||||
"feature": {
|
"feature": {
|
||||||
@ -685,7 +800,9 @@
|
|||||||
"betaDarkenOutside": "Verduister buiten tekenvak",
|
"betaDarkenOutside": "Verduister buiten tekenvak",
|
||||||
"betaLimitToBox": "Beperk tot tekenvak",
|
"betaLimitToBox": "Beperk tot tekenvak",
|
||||||
"betaPreserveMasked": "Behoud masker",
|
"betaPreserveMasked": "Behoud masker",
|
||||||
"antialiasing": "Anti-aliasing"
|
"antialiasing": "Anti-aliasing",
|
||||||
|
"showResultsOn": "Toon resultaten (aan)",
|
||||||
|
"showResultsOff": "Toon resultaten (uit)"
|
||||||
},
|
},
|
||||||
"accessibility": {
|
"accessibility": {
|
||||||
"exitViewer": "Stop viewer",
|
"exitViewer": "Stop viewer",
|
||||||
@ -707,7 +824,9 @@
|
|||||||
"toggleAutoscroll": "Autom. scrollen aan/uit",
|
"toggleAutoscroll": "Autom. scrollen aan/uit",
|
||||||
"toggleLogViewer": "Logboekviewer aan/uit",
|
"toggleLogViewer": "Logboekviewer aan/uit",
|
||||||
"showOptionsPanel": "Toon zijscherm",
|
"showOptionsPanel": "Toon zijscherm",
|
||||||
"menu": "Menu"
|
"menu": "Menu",
|
||||||
|
"showGalleryPanel": "Toon deelscherm Galerij",
|
||||||
|
"loadMore": "Laad meer"
|
||||||
},
|
},
|
||||||
"ui": {
|
"ui": {
|
||||||
"showProgressImages": "Toon voortgangsafbeeldingen",
|
"showProgressImages": "Toon voortgangsafbeeldingen",
|
||||||
@ -730,6 +849,661 @@
|
|||||||
"resetWorkflow": "Herstel werkstroom",
|
"resetWorkflow": "Herstel werkstroom",
|
||||||
"resetWorkflowDesc": "Weet je zeker dat je deze werkstroom wilt herstellen?",
|
"resetWorkflowDesc": "Weet je zeker dat je deze werkstroom wilt herstellen?",
|
||||||
"resetWorkflowDesc2": "Herstel van een werkstroom haalt alle knooppunten, randen en werkstroomdetails weg.",
|
"resetWorkflowDesc2": "Herstel van een werkstroom haalt alle knooppunten, randen en werkstroomdetails weg.",
|
||||||
"downloadWorkflow": "Download JSON van werkstroom"
|
"downloadWorkflow": "Download JSON van werkstroom",
|
||||||
|
"booleanPolymorphicDescription": "Een verzameling Booleanse waarden.",
|
||||||
|
"scheduler": "Planner",
|
||||||
|
"inputField": "Invoerveld",
|
||||||
|
"controlFieldDescription": "Controlegegevens doorgegeven tussen knooppunten.",
|
||||||
|
"skippingUnknownOutputType": "Overslaan van onbekend soort uitvoerveld",
|
||||||
|
"latentsFieldDescription": "Latents kunnen worden doorgegeven tussen knooppunten.",
|
||||||
|
"denoiseMaskFieldDescription": "Ontruisingsmasker kan worden doorgegeven tussen knooppunten",
|
||||||
|
"floatCollectionDescription": "Een verzameling zwevende-kommagetallen.",
|
||||||
|
"missingTemplate": "Ontbrekende sjabloon",
|
||||||
|
"outputSchemaNotFound": "Uitvoerschema niet gevonden",
|
||||||
|
"ipAdapterPolymorphicDescription": "Een verzameling IP-adapters.",
|
||||||
|
"workflowDescription": "Korte beschrijving",
|
||||||
|
"latentsPolymorphicDescription": "Latents kunnen worden doorgegeven tussen knooppunten.",
|
||||||
|
"colorFieldDescription": "Een RGBA-kleur.",
|
||||||
|
"mainModelField": "Model",
|
||||||
|
"unhandledInputProperty": "Onverwerkt invoerkenmerk",
|
||||||
|
"versionUnknown": " Versie onbekend",
|
||||||
|
"ipAdapterCollection": "Verzameling IP-adapters",
|
||||||
|
"conditioningCollection": "Verzameling conditionering",
|
||||||
|
"maybeIncompatible": "Is mogelijk niet compatibel met geïnstalleerde knooppunten",
|
||||||
|
"ipAdapterPolymorphic": "Polymorfisme IP-adapter",
|
||||||
|
"noNodeSelected": "Geen knooppunt gekozen",
|
||||||
|
"addNode": "Voeg knooppunt toe",
|
||||||
|
"unableToValidateWorkflow": "Kan werkstroom niet valideren",
|
||||||
|
"enum": "Enumeratie",
|
||||||
|
"integerPolymorphicDescription": "Een verzameling gehele getallen.",
|
||||||
|
"noOutputRecorded": "Geen uitvoer opgenomen",
|
||||||
|
"updateApp": "Werk app bij",
|
||||||
|
"conditioningCollectionDescription": "Conditionering kan worden doorgegeven tussen knooppunten.",
|
||||||
|
"colorPolymorphic": "Polymorfisme kleur",
|
||||||
|
"colorCodeEdgesHelp": "Kleurgecodeerde randen op basis van hun verbonden velden",
|
||||||
|
"collectionDescription": "Beschrijving",
|
||||||
|
"float": "Zwevende-kommagetal",
|
||||||
|
"workflowContact": "Contactpersoon",
|
||||||
|
"skippingReservedFieldType": "Overslaan van gereserveerd veldsoort",
|
||||||
|
"animatedEdges": "Geanimeerde randen",
|
||||||
|
"booleanCollectionDescription": "Een verzameling van Booleanse waarden.",
|
||||||
|
"sDXLMainModelFieldDescription": "SDXL-modelveld.",
|
||||||
|
"conditioningPolymorphic": "Polymorfisme conditionering",
|
||||||
|
"integer": "Geheel getal",
|
||||||
|
"colorField": "Kleur",
|
||||||
|
"boardField": "Bord",
|
||||||
|
"nodeTemplate": "Sjabloon knooppunt",
|
||||||
|
"latentsCollection": "Verzameling latents",
|
||||||
|
"problemReadingWorkflow": "Fout bij lezen van werkstroom uit afbeelding",
|
||||||
|
"sourceNode": "Bronknooppunt",
|
||||||
|
"nodeOpacity": "Dekking knooppunt",
|
||||||
|
"pickOne": "Kies er een",
|
||||||
|
"collectionItemDescription": "Beschrijving",
|
||||||
|
"integerDescription": "Gehele getallen zijn getallen zonder een decimaalteken.",
|
||||||
|
"outputField": "Uitvoerveld",
|
||||||
|
"unableToLoadWorkflow": "Kan werkstroom niet valideren",
|
||||||
|
"snapToGrid": "Lijn uit op raster",
|
||||||
|
"stringPolymorphic": "Polymorfisme tekenreeks",
|
||||||
|
"conditioningPolymorphicDescription": "Conditionering kan worden doorgegeven tussen knooppunten.",
|
||||||
|
"noFieldsLinearview": "Geen velden toegevoegd aan lineaire weergave",
|
||||||
|
"skipped": "Overgeslagen",
|
||||||
|
"imagePolymorphic": "Polymorfisme afbeelding",
|
||||||
|
"nodeSearch": "Zoek naar knooppunten",
|
||||||
|
"updateNode": "Werk knooppunt bij",
|
||||||
|
"sDXLRefinerModelFieldDescription": "Beschrijving",
|
||||||
|
"imagePolymorphicDescription": "Een verzameling afbeeldingen.",
|
||||||
|
"floatPolymorphic": "Polymorfisme zwevende-kommagetal",
|
||||||
|
"version": "Versie",
|
||||||
|
"doesNotExist": "bestaat niet",
|
||||||
|
"ipAdapterCollectionDescription": "Een verzameling van IP-adapters.",
|
||||||
|
"stringCollectionDescription": "Een verzameling tekenreeksen.",
|
||||||
|
"unableToParseNode": "Kan knooppunt niet inlezen",
|
||||||
|
"controlCollection": "Controle-verzameling",
|
||||||
|
"validateConnections": "Valideer verbindingen en graaf",
|
||||||
|
"stringCollection": "Verzameling tekenreeksen",
|
||||||
|
"inputMayOnlyHaveOneConnection": "Invoer mag slechts een enkele verbinding hebben",
|
||||||
|
"notes": "Opmerkingen",
|
||||||
|
"uNetField": "UNet",
|
||||||
|
"nodeOutputs": "Uitvoer knooppunt",
|
||||||
|
"currentImageDescription": "Toont de huidige afbeelding in de knooppunteditor",
|
||||||
|
"validateConnectionsHelp": "Voorkom dat er ongeldige verbindingen worden gelegd en dat er ongeldige grafen worden aangeroepen",
|
||||||
|
"problemSettingTitle": "Fout bij instellen titel",
|
||||||
|
"ipAdapter": "IP-adapter",
|
||||||
|
"integerCollection": "Verzameling gehele getallen",
|
||||||
|
"collectionItem": "Verzamelingsonderdeel",
|
||||||
|
"noConnectionInProgress": "Geen verbinding bezig te maken",
|
||||||
|
"vaeModelField": "VAE",
|
||||||
|
"controlCollectionDescription": "Controlegegevens doorgegeven tussen knooppunten.",
|
||||||
|
"skippedReservedInput": "Overgeslagen gereserveerd invoerveld",
|
||||||
|
"workflowVersion": "Versie",
|
||||||
|
"noConnectionData": "Geen verbindingsgegevens",
|
||||||
|
"outputFields": "Uitvoervelden",
|
||||||
|
"fieldTypesMustMatch": "Veldsoorten moeten overeenkomen",
|
||||||
|
"workflow": "Werkstroom",
|
||||||
|
"edge": "Rand",
|
||||||
|
"inputNode": "Invoerknooppunt",
|
||||||
|
"enumDescription": "Enumeraties zijn waarden die uit een aantal opties moeten worden gekozen.",
|
||||||
|
"unkownInvocation": "Onbekende aanroepsoort",
|
||||||
|
"loRAModelFieldDescription": "Beschrijving",
|
||||||
|
"imageField": "Afbeelding",
|
||||||
|
"skippedReservedOutput": "Overgeslagen gereserveerd uitvoerveld",
|
||||||
|
"animatedEdgesHelp": "Animeer gekozen randen en randen verbonden met de gekozen knooppunten",
|
||||||
|
"cannotDuplicateConnection": "Kan geen dubbele verbindingen maken",
|
||||||
|
"booleanPolymorphic": "Polymorfisme Booleaanse waarden",
|
||||||
|
"unknownTemplate": "Onbekend sjabloon",
|
||||||
|
"noWorkflow": "Geen werkstroom",
|
||||||
|
"removeLinearView": "Verwijder uit lineaire weergave",
|
||||||
|
"colorCollectionDescription": "Beschrijving",
|
||||||
|
"integerCollectionDescription": "Een verzameling gehele getallen.",
|
||||||
|
"colorPolymorphicDescription": "Een verzameling kleuren.",
|
||||||
|
"sDXLMainModelField": "SDXL-model",
|
||||||
|
"workflowTags": "Labels",
|
||||||
|
"denoiseMaskField": "Ontruisingsmasker",
|
||||||
|
"schedulerDescription": "Beschrijving",
|
||||||
|
"missingCanvaInitImage": "Ontbrekende initialisatie-afbeelding voor canvas",
|
||||||
|
"conditioningFieldDescription": "Conditionering kan worden doorgegeven tussen knooppunten.",
|
||||||
|
"clipFieldDescription": "Submodellen voor tokenizer en text_encoder.",
|
||||||
|
"fullyContainNodesHelp": "Knooppunten moeten zich volledig binnen het keuzevak bevinden om te worden gekozen",
|
||||||
|
"noImageFoundState": "Geen initiële afbeelding gevonden in de staat",
|
||||||
|
"workflowValidation": "Validatiefout werkstroom",
|
||||||
|
"clipField": "Clip",
|
||||||
|
"stringDescription": "Tekenreeksen zijn tekst.",
|
||||||
|
"nodeType": "Soort knooppunt",
|
||||||
|
"noMatchingNodes": "Geen overeenkomende knooppunten",
|
||||||
|
"fullyContainNodes": "Omvat knooppunten volledig om ze te kiezen",
|
||||||
|
"integerPolymorphic": "Polymorfisme geheel getal",
|
||||||
|
"executionStateInProgress": "Bezig",
|
||||||
|
"noFieldType": "Geen soort veld",
|
||||||
|
"colorCollection": "Een verzameling kleuren.",
|
||||||
|
"executionStateError": "Fout",
|
||||||
|
"noOutputSchemaName": "Geen naam voor uitvoerschema gevonden in referentieobject",
|
||||||
|
"ipAdapterModel": "Model IP-adapter",
|
||||||
|
"latentsPolymorphic": "Polymorfisme latents",
|
||||||
|
"vaeModelFieldDescription": "Beschrijving",
|
||||||
|
"skippingInputNoTemplate": "Overslaan van invoerveld zonder sjabloon",
|
||||||
|
"ipAdapterDescription": "Een Afbeeldingsprompt-adapter (IP-adapter).",
|
||||||
|
"boolean": "Booleaanse waarden",
|
||||||
|
"missingCanvaInitMaskImages": "Ontbrekende initialisatie- en maskerafbeeldingen voor canvas",
|
||||||
|
"problemReadingMetadata": "Fout bij lezen van metagegevens uit afbeelding",
|
||||||
|
"stringPolymorphicDescription": "Een verzameling tekenreeksen.",
|
||||||
|
"oNNXModelField": "ONNX-model",
|
||||||
|
"executionStateCompleted": "Voltooid",
|
||||||
|
"node": "Knooppunt",
|
||||||
|
"skippingUnknownInputType": "Overslaan van onbekend soort invoerveld",
|
||||||
|
"workflowAuthor": "Auteur",
|
||||||
|
"currentImage": "Huidige afbeelding",
|
||||||
|
"controlField": "Controle",
|
||||||
|
"workflowName": "Naam",
|
||||||
|
"booleanDescription": "Booleanse waarden zijn waar en onwaar.",
|
||||||
|
"collection": "Verzameling",
|
||||||
|
"ipAdapterModelDescription": "Modelveld IP-adapter",
|
||||||
|
"cannotConnectInputToInput": "Kan invoer niet aan invoer verbinden",
|
||||||
|
"invalidOutputSchema": "Ongeldig uitvoerschema",
|
||||||
|
"boardFieldDescription": "Een galerijbord",
|
||||||
|
"floatDescription": "Zwevende-kommagetallen zijn getallen met een decimaalteken.",
|
||||||
|
"floatPolymorphicDescription": "Een verzameling zwevende-kommagetallen.",
|
||||||
|
"vaeField": "Vae",
|
||||||
|
"conditioningField": "Conditionering",
|
||||||
|
"unhandledOutputProperty": "Onverwerkt uitvoerkenmerk",
|
||||||
|
"workflowNotes": "Opmerkingen",
|
||||||
|
"string": "Tekenreeks",
|
||||||
|
"floatCollection": "Verzameling zwevende-kommagetallen",
|
||||||
|
"latentsField": "Latents",
|
||||||
|
"cannotConnectOutputToOutput": "Kan uitvoer niet aan uitvoer verbinden",
|
||||||
|
"booleanCollection": "Verzameling Booleaanse waarden",
|
||||||
|
"connectionWouldCreateCycle": "Verbinding zou cyclisch worden",
|
||||||
|
"cannotConnectToSelf": "Kan niet aan zichzelf verbinden",
|
||||||
|
"notesDescription": "Voeg opmerkingen toe aan je werkstroom",
|
||||||
|
"unknownField": "Onbekend veld",
|
||||||
|
"inputFields": "Invoervelden",
|
||||||
|
"colorCodeEdges": "Kleurgecodeerde randen",
|
||||||
|
"uNetFieldDescription": "UNet-submodel.",
|
||||||
|
"unknownNode": "Onbekend knooppunt",
|
||||||
|
"imageCollectionDescription": "Een verzameling afbeeldingen.",
|
||||||
|
"mismatchedVersion": "Heeft niet-overeenkomende versie",
|
||||||
|
"vaeFieldDescription": "Vae-submodel.",
|
||||||
|
"imageFieldDescription": "Afbeeldingen kunnen worden doorgegeven tussen knooppunten.",
|
||||||
|
"outputNode": "Uitvoerknooppunt",
|
||||||
|
"addNodeToolTip": "Voeg knooppunt toe (Shift+A, spatie)",
|
||||||
|
"loadingNodes": "Bezig met laden van knooppunten...",
|
||||||
|
"snapToGridHelp": "Lijn knooppunten uit op raster bij verplaatsing",
|
||||||
|
"workflowSettings": "Instellingen werkstroomeditor",
|
||||||
|
"mainModelFieldDescription": "Beschrijving",
|
||||||
|
"sDXLRefinerModelField": "Verfijningsmodel",
|
||||||
|
"loRAModelField": "LoRA",
|
||||||
|
"unableToParseEdge": "Kan rand niet inlezen",
|
||||||
|
"latentsCollectionDescription": "Latents kunnen worden doorgegeven tussen knooppunten.",
|
||||||
|
"oNNXModelFieldDescription": "ONNX-modelveld.",
|
||||||
|
"imageCollection": "Afbeeldingsverzameling"
|
||||||
|
},
|
||||||
|
"controlnet": {
|
||||||
|
"amult": "a_mult",
|
||||||
|
"resize": "Schaal",
|
||||||
|
"showAdvanced": "Toon uitgebreid",
|
||||||
|
"contentShuffleDescription": "Verschuift het materiaal in de afbeelding",
|
||||||
|
"bgth": "bg_th",
|
||||||
|
"addT2IAdapter": "Voeg $t(common.t2iAdapter) toe",
|
||||||
|
"pidi": "PIDI",
|
||||||
|
"importImageFromCanvas": "Importeer afbeelding uit canvas",
|
||||||
|
"lineartDescription": "Zet afbeelding om naar lineart",
|
||||||
|
"normalBae": "Normale BAE",
|
||||||
|
"importMaskFromCanvas": "Importeer masker uit canvas",
|
||||||
|
"hed": "HED",
|
||||||
|
"hideAdvanced": "Verberg uitgebreid",
|
||||||
|
"contentShuffle": "Verschuif materiaal",
|
||||||
|
"controlNetEnabledT2IDisabled": "$t(common.controlNet) ingeschakeld, $t(common.t2iAdapter)s uitgeschakeld",
|
||||||
|
"ipAdapterModel": "Adaptermodel",
|
||||||
|
"resetControlImage": "Zet controle-afbeelding terug",
|
||||||
|
"beginEndStepPercent": "Percentage begin-/eindstap",
|
||||||
|
"mlsdDescription": "Minimalistische herkenning lijnsegmenten",
|
||||||
|
"duplicate": "Maak kopie",
|
||||||
|
"balanced": "Gebalanceerd",
|
||||||
|
"f": "F",
|
||||||
|
"h": "H",
|
||||||
|
"prompt": "Prompt",
|
||||||
|
"depthMidasDescription": "Generatie van diepteblad via Midas",
|
||||||
|
"controlnet": "$t(controlnet.controlAdapter) #{{number}} ($t(common.controlNet))",
|
||||||
|
"openPoseDescription": "Menselijke pose-benadering via Openpose",
|
||||||
|
"control": "Controle",
|
||||||
|
"resizeMode": "Modus schaling",
|
||||||
|
"t2iEnabledControlNetDisabled": "$t(common.t2iAdapter) ingeschakeld, $t(common.controlNet)s uitgeschakeld",
|
||||||
|
"coarse": "Grof",
|
||||||
|
"weight": "Gewicht",
|
||||||
|
"selectModel": "Kies een model",
|
||||||
|
"crop": "Snij bij",
|
||||||
|
"depthMidas": "Diepte (Midas)",
|
||||||
|
"w": "B",
|
||||||
|
"processor": "Verwerker",
|
||||||
|
"addControlNet": "Voeg $t(common.controlNet) toe",
|
||||||
|
"none": "Geen",
|
||||||
|
"incompatibleBaseModel": "Niet-compatibel basismodel:",
|
||||||
|
"enableControlnet": "Schakel ControlNet in",
|
||||||
|
"detectResolution": "Herken resolutie",
|
||||||
|
"controlNetT2IMutexDesc": "Gelijktijdig gebruik van $t(common.controlNet) en $t(common.t2iAdapter) wordt op dit moment niet ondersteund.",
|
||||||
|
"ip_adapter": "$t(controlnet.controlAdapter) #{{number}} ($t(common.ipAdapter))",
|
||||||
|
"pidiDescription": "PIDI-afbeeldingsverwerking",
|
||||||
|
"mediapipeFace": "Mediapipe - Gezicht",
|
||||||
|
"mlsd": "M-LSD",
|
||||||
|
"controlMode": "Controlemodus",
|
||||||
|
"fill": "Vul",
|
||||||
|
"cannyDescription": "Herkenning Canny-rand",
|
||||||
|
"addIPAdapter": "Voeg $t(common.ipAdapter) toe",
|
||||||
|
"lineart": "Lineart",
|
||||||
|
"colorMapDescription": "Genereert een kleurenblad van de afbeelding",
|
||||||
|
"lineartAnimeDescription": "Lineartverwerking in anime-stijl",
|
||||||
|
"t2i_adapter": "$t(controlnet.controlAdapter) #{{number}} ($t(common.t2iAdapter))",
|
||||||
|
"minConfidence": "Min. vertrouwensniveau",
|
||||||
|
"imageResolution": "Resolutie afbeelding",
|
||||||
|
"megaControl": "Zeer veel controle",
|
||||||
|
"depthZoe": "Diepte (Zoe)",
|
||||||
|
"colorMap": "Kleur",
|
||||||
|
"lowThreshold": "Lage drempelwaarde",
|
||||||
|
"autoConfigure": "Configureer verwerker automatisch",
|
||||||
|
"highThreshold": "Hoge drempelwaarde",
|
||||||
|
"normalBaeDescription": "Normale BAE-verwerking",
|
||||||
|
"noneDescription": "Geen verwerking toegepast",
|
||||||
|
"saveControlImage": "Bewaar controle-afbeelding",
|
||||||
|
"openPose": "Openpose",
|
||||||
|
"toggleControlNet": "Zet deze ControlNet aan/uit",
|
||||||
|
"delete": "Verwijder",
|
||||||
|
"controlAdapter_one": "Control-adapter",
|
||||||
|
"controlAdapter_other": "Control-adapters",
|
||||||
|
"safe": "Veilig",
|
||||||
|
"colorMapTileSize": "Grootte tegel",
|
||||||
|
"lineartAnime": "Lineart-anime",
|
||||||
|
"ipAdapterImageFallback": "Geen IP-adapterafbeelding gekozen",
|
||||||
|
"mediapipeFaceDescription": "Gezichtsherkenning met Mediapipe",
|
||||||
|
"canny": "Canny",
|
||||||
|
"depthZoeDescription": "Generatie van diepteblad via Zoe",
|
||||||
|
"hedDescription": "Herkenning van holistisch-geneste randen",
|
||||||
|
"setControlImageDimensions": "Stel afmetingen controle-afbeelding in op B/H",
|
||||||
|
"scribble": "Krabbel",
|
||||||
|
"resetIPAdapterImage": "Zet IP-adapterafbeelding terug",
|
||||||
|
"handAndFace": "Hand en gezicht",
|
||||||
|
"enableIPAdapter": "Schakel IP-adapter in",
|
||||||
|
"maxFaces": "Max. gezichten"
|
||||||
|
},
|
||||||
|
"dynamicPrompts": {
|
||||||
|
"seedBehaviour": {
|
||||||
|
"perPromptDesc": "Gebruik een verschillende seedwaarde per afbeelding",
|
||||||
|
"perIterationLabel": "Seedwaarde per iteratie",
|
||||||
|
"perIterationDesc": "Gebruik een verschillende seedwaarde per iteratie",
|
||||||
|
"perPromptLabel": "Seedwaarde per afbeelding",
|
||||||
|
"label": "Gedrag seedwaarde"
|
||||||
|
},
|
||||||
|
"enableDynamicPrompts": "Schakel dynamische prompts in",
|
||||||
|
"combinatorial": "Combinatorische generatie",
|
||||||
|
"maxPrompts": "Max. prompts",
|
||||||
|
"promptsWithCount_one": "{{count}} prompt",
|
||||||
|
"promptsWithCount_other": "{{count}} prompts",
|
||||||
|
"dynamicPrompts": "Dynamische prompts"
|
||||||
|
},
|
||||||
|
"popovers": {
|
||||||
|
"noiseUseCPU": {
|
||||||
|
"paragraphs": [
|
||||||
|
"Bestuurt of ruis wordt gegenereerd op de CPU of de GPU.",
|
||||||
|
"Met CPU-ruis ingeschakeld zal een bepaalde seedwaarde dezelfde afbeelding opleveren op welke machine dan ook.",
|
||||||
|
"Er is geen prestatieverschil bij het inschakelen van CPU-ruis."
|
||||||
|
],
|
||||||
|
"heading": "Gebruik CPU-ruis"
|
||||||
|
},
|
||||||
|
"paramScheduler": {
|
||||||
|
"paragraphs": [
|
||||||
|
"De planner bepaalt hoe per keer ruis wordt toegevoegd aan een afbeelding of hoe een monster wordt bijgewerkt op basis van de uitvoer van een model."
|
||||||
|
],
|
||||||
|
"heading": "Planner"
|
||||||
|
},
|
||||||
|
"scaleBeforeProcessing": {
|
||||||
|
"paragraphs": [
|
||||||
|
"Schaalt het gekozen gebied naar de grootte die het meest geschikt is voor het model, vooraf aan het proces van het afbeeldingen genereren."
|
||||||
|
],
|
||||||
|
"heading": "Schaal vooraf aan verwerking"
|
||||||
|
},
|
||||||
|
"compositingMaskAdjustments": {
|
||||||
|
"heading": "Aanpassingen masker",
|
||||||
|
"paragraphs": [
|
||||||
|
"Pas het masker aan."
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"paramRatio": {
|
||||||
|
"heading": "Beeldverhouding",
|
||||||
|
"paragraphs": [
|
||||||
|
"De beeldverhouding van de afmetingen van de afbeelding die wordt gegenereerd.",
|
||||||
|
"Een afbeeldingsgrootte (in aantal pixels) equivalent aan 512x512 wordt aanbevolen voor SD1.5-modellen. Een grootte-equivalent van 1024x1024 wordt aanbevolen voor SDXL-modellen."
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"compositingCoherenceSteps": {
|
||||||
|
"heading": "Stappen",
|
||||||
|
"paragraphs": [
|
||||||
|
"Het aantal te gebruiken ontruisingsstappen in de coherentiefase.",
|
||||||
|
"Gelijk aan de hoofdparameter Stappen."
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"dynamicPrompts": {
|
||||||
|
"paragraphs": [
|
||||||
|
"Dynamische prompts vormt een enkele prompt om in vele.",
|
||||||
|
"De basissyntax is \"a {red|green|blue} ball\". Dit zal de volgende drie prompts geven: \"a red ball\", \"a green ball\" en \"a blue ball\".",
|
||||||
|
"Gebruik de syntax zo vaak als je wilt in een enkele prompt, maar zorg ervoor dat het aantal gegenereerde prompts in lijn ligt met de instelling Max. prompts."
|
||||||
|
],
|
||||||
|
"heading": "Dynamische prompts"
|
||||||
|
},
|
||||||
|
"paramVAE": {
|
||||||
|
"paragraphs": [
|
||||||
|
"Het model gebruikt voor het vertalen van AI-uitvoer naar de uiteindelijke afbeelding."
|
||||||
|
],
|
||||||
|
"heading": "VAE"
|
||||||
|
},
|
||||||
|
"compositingBlur": {
|
||||||
|
"heading": "Vervaging",
|
||||||
|
"paragraphs": [
|
||||||
|
"De vervagingsstraal van het masker."
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"paramIterations": {
|
||||||
|
"paragraphs": [
|
||||||
|
"Het aantal te genereren afbeeldingen.",
|
||||||
|
"Als dynamische prompts is ingeschakeld, dan zal elke prompt dit aantal keer gegenereerd worden."
|
||||||
|
],
|
||||||
|
"heading": "Iteraties"
|
||||||
|
},
|
||||||
|
"paramVAEPrecision": {
|
||||||
|
"heading": "Nauwkeurigheid VAE",
|
||||||
|
"paragraphs": [
|
||||||
|
"De nauwkeurigheid gebruikt tijdens de VAE-codering en -decodering. FP16/halve nauwkeurig is efficiënter, ten koste van kleine afbeeldingsvariaties."
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"compositingCoherenceMode": {
|
||||||
|
"heading": "Modus",
|
||||||
|
"paragraphs": [
|
||||||
|
"De modus van de coherentiefase."
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"paramSeed": {
|
||||||
|
"paragraphs": [
|
||||||
|
"Bestuurt de startruis die gebruikt wordt bij het genereren.",
|
||||||
|
"Schakel \"Willekeurige seedwaarde\" uit om identieke resultaten te krijgen met dezelfde generatie-instellingen."
|
||||||
|
],
|
||||||
|
"heading": "Seedwaarde"
|
||||||
|
},
|
||||||
|
"controlNetResizeMode": {
|
||||||
|
"heading": "Schaalmodus",
|
||||||
|
"paragraphs": [
|
||||||
|
"Hoe de ControlNet-afbeelding zal worden geschaald aan de uitvoergrootte van de afbeelding."
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"controlNetBeginEnd": {
|
||||||
|
"paragraphs": [
|
||||||
|
"Op welke stappen van het ontruisingsproces ControlNet worden toegepast.",
|
||||||
|
"ControlNets die worden toegepast aan het begin begeleiden het compositieproces. ControlNets die worden toegepast aan het eind zorgen voor details."
|
||||||
|
],
|
||||||
|
"heading": "Percentage begin- / eindstap"
|
||||||
|
},
|
||||||
|
"dynamicPromptsSeedBehaviour": {
|
||||||
|
"paragraphs": [
|
||||||
|
"Bestuurt hoe de seedwaarde wordt gebruikt bij het genereren van prompts.",
|
||||||
|
"Per iteratie zal een unieke seedwaarde worden gebruikt voor elke iteratie. Gebruik dit om de promptvariaties binnen een enkele seedwaarde te verkennen.",
|
||||||
|
"Bijvoorbeeld: als je vijf prompts heb, dan zal voor elke afbeelding dezelfde seedwaarde gebruikt worden.",
|
||||||
|
"De optie Per afbeelding zal een unieke seedwaarde voor elke afbeelding gebruiken. Dit biedt meer variatie."
|
||||||
|
],
|
||||||
|
"heading": "Gedrag seedwaarde"
|
||||||
|
},
|
||||||
|
"clipSkip": {
|
||||||
|
"paragraphs": [
|
||||||
|
"Kies hoeveel CLIP-modellagen je wilt overslaan.",
|
||||||
|
"Bepaalde modellen werken beter met bepaalde Overslaan CLIP-instellingen.",
|
||||||
|
"Een hogere waarde geeft meestal een minder gedetailleerde afbeelding."
|
||||||
|
],
|
||||||
|
"heading": "Overslaan CLIP"
|
||||||
|
},
|
||||||
|
"paramModel": {
|
||||||
|
"heading": "Model",
|
||||||
|
"paragraphs": [
|
||||||
|
"Model gebruikt voor de ontruisingsstappen.",
|
||||||
|
"Verschillende modellen zijn meestal getraind zich te specialiseren in het maken van bepaalde esthetische resultaten en materiaal."
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"compositingCoherencePass": {
|
||||||
|
"heading": "Coherentiefase",
|
||||||
|
"paragraphs": [
|
||||||
|
"Een tweede ronde ontruising helpt bij het samenstellen van de erin- of eruitgetekende afbeelding."
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"paramDenoisingStrength": {
|
||||||
|
"paragraphs": [
|
||||||
|
"Hoeveel ruis wordt toegevoegd aan de invoerafbeelding.",
|
||||||
|
"0 geeft een identieke afbeelding, waarbij 1 een volledig nieuwe afbeelding geeft."
|
||||||
|
],
|
||||||
|
"heading": "Ontruisingssterkte"
|
||||||
|
},
|
||||||
|
"compositingStrength": {
|
||||||
|
"heading": "Sterkte",
|
||||||
|
"paragraphs": [
|
||||||
|
"Ontruisingssterkte voor de coherentiefase.",
|
||||||
|
"Gelijk aan de parameter Ontruisingssterkte Afbeelding naar afbeelding."
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"paramNegativeConditioning": {
|
||||||
|
"paragraphs": [
|
||||||
|
"Het generatieproces voorkomt de gegeven begrippen in de negatieve prompt. Gebruik dit om bepaalde zaken of voorwerpen uit te sluiten van de uitvoerafbeelding.",
|
||||||
|
"Ondersteunt Compel-syntax en -embeddingen."
|
||||||
|
],
|
||||||
|
"heading": "Negatieve prompt"
|
||||||
|
},
|
||||||
|
"compositingBlurMethod": {
|
||||||
|
"heading": "Vervagingsmethode",
|
||||||
|
"paragraphs": [
|
||||||
|
"De methode van de vervaging die wordt toegepast op het gemaskeerd gebied."
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"dynamicPromptsMaxPrompts": {
|
||||||
|
"heading": "Max. prompts",
|
||||||
|
"paragraphs": [
|
||||||
|
"Beperkt het aantal prompts die kunnen worden gegenereerd door dynamische prompts."
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"infillMethod": {
|
||||||
|
"paragraphs": [
|
||||||
|
"Methode om een gekozen gebied in te vullen."
|
||||||
|
],
|
||||||
|
"heading": "Invulmethode"
|
||||||
|
},
|
||||||
|
"controlNetWeight": {
|
||||||
|
"heading": "Gewicht",
|
||||||
|
"paragraphs": [
|
||||||
|
"Hoe sterk ControlNet effect heeft op de gegeneerde afbeelding."
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"controlNet": {
|
||||||
|
"heading": "ControlNet",
|
||||||
|
"paragraphs": [
|
||||||
|
"ControlNets biedt begeleiding aan het generatieproces, waarbij hulp wordt geboden bij het maken van afbeelding met aangestuurde compositie, structuur of stijl, afhankelijk van het gekozen model."
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"paramCFGScale": {
|
||||||
|
"heading": "CFG-schaal",
|
||||||
|
"paragraphs": [
|
||||||
|
"Bestuurt hoeveel je prompt invloed heeft op het generatieproces."
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"controlNetControlMode": {
|
||||||
|
"paragraphs": [
|
||||||
|
"Geeft meer gewicht aan ofwel de prompt danwel ControlNet."
|
||||||
|
],
|
||||||
|
"heading": "Controlemodus"
|
||||||
|
},
|
||||||
|
"paramSteps": {
|
||||||
|
"heading": "Stappen",
|
||||||
|
"paragraphs": [
|
||||||
|
"Het aantal uit te voeren stappen tijdens elke generatie.",
|
||||||
|
"Hogere stappenaantallen geven meestal betere afbeeldingen ten koste van een grotere benodigde generatietijd."
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"paramPositiveConditioning": {
|
||||||
|
"heading": "Positieve prompt",
|
||||||
|
"paragraphs": [
|
||||||
|
"Begeleidt het generartieproces. Gebruik een woord of frase naar keuze.",
|
||||||
|
"Syntaxes en embeddings voor Compel en dynamische prompts."
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"lora": {
|
||||||
|
"heading": "Gewicht LoRA",
|
||||||
|
"paragraphs": [
|
||||||
|
"Een hogere LoRA-gewicht zal leiden tot een groter effect op de uiteindelijke afbeelding."
|
||||||
|
]
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"metadata": {
|
||||||
|
"seamless": "Naadloos",
|
||||||
|
"positivePrompt": "Positieve prompt",
|
||||||
|
"negativePrompt": "Negatieve prompt",
|
||||||
|
"generationMode": "Generatiemodus",
|
||||||
|
"Threshold": "Drempelwaarde ruis",
|
||||||
|
"metadata": "Metagegevens",
|
||||||
|
"strength": "Sterkte Afbeelding naar afbeelding",
|
||||||
|
"seed": "Seedwaarde",
|
||||||
|
"imageDetails": "Afbeeldingsdetails",
|
||||||
|
"perlin": "Perlin-ruis",
|
||||||
|
"model": "Model",
|
||||||
|
"noImageDetails": "Geen afbeeldingsdetails gevonden",
|
||||||
|
"hiresFix": "Optimalisatie voor hoge resolutie",
|
||||||
|
"cfgScale": "CFG-schaal",
|
||||||
|
"fit": "Schaal aanpassen in Afbeelding naar afbeelding",
|
||||||
|
"initImage": "Initiële afbeelding",
|
||||||
|
"recallParameters": "Opnieuw aan te roepen parameters",
|
||||||
|
"height": "Hoogte",
|
||||||
|
"variations": "Paren seedwaarde-gewicht",
|
||||||
|
"noMetaData": "Geen metagegevens gevonden",
|
||||||
|
"width": "Breedte",
|
||||||
|
"createdBy": "Gemaakt door",
|
||||||
|
"workflow": "Werkstroom",
|
||||||
|
"steps": "Stappen",
|
||||||
|
"scheduler": "Planner",
|
||||||
|
"noRecallParameters": "Geen opnieuw uit te voeren parameters gevonden"
|
||||||
|
},
|
||||||
|
"queue": {
|
||||||
|
"status": "Status",
|
||||||
|
"pruneSucceeded": "{{item_count}} voltooide onderdelen uit wachtrij gesnoeid",
|
||||||
|
"cancelTooltip": "Annuleer huidig onderdeel",
|
||||||
|
"queueEmpty": "Wachtrij leeg",
|
||||||
|
"pauseSucceeded": "Verwerker onderbroken",
|
||||||
|
"in_progress": "Bezig",
|
||||||
|
"queueFront": "Voeg toe aan voorkant van wachtrij",
|
||||||
|
"notReady": "Kan niet in wachtrij plaatsen",
|
||||||
|
"batchFailedToQueue": "Fout bij reeks in wachtrij plaatsen",
|
||||||
|
"completed": "Voltooid",
|
||||||
|
"queueBack": "Voeg toe aan wachtrij",
|
||||||
|
"batchValues": "Reekswaarden",
|
||||||
|
"cancelFailed": "Fout bij annuleren onderdeel",
|
||||||
|
"queueCountPrediction": "Voeg {{predicted}} toe aan wachtrij",
|
||||||
|
"batchQueued": "Reeks in wachtrij geplaatst",
|
||||||
|
"pauseFailed": "Fout bij onderbreken verwerker",
|
||||||
|
"clearFailed": "Fout bij wissen van wachtrij",
|
||||||
|
"queuedCount": "{{pending}} wachtend",
|
||||||
|
"front": "begin",
|
||||||
|
"clearSucceeded": "Wachtrij gewist",
|
||||||
|
"pause": "Onderbreek",
|
||||||
|
"pruneTooltip": "Snoei {{item_count}} voltooide onderdelen",
|
||||||
|
"cancelSucceeded": "Onderdeel geannuleerd",
|
||||||
|
"batchQueuedDesc_one": "Voeg {{count}} sessie toe aan het {{direction}} van de wachtrij",
|
||||||
|
"batchQueuedDesc_other": "Voeg {{count}} sessies toe aan het {{direction}} van de wachtrij",
|
||||||
|
"graphQueued": "Graaf in wachtrij geplaatst",
|
||||||
|
"queue": "Wachtrij",
|
||||||
|
"batch": "Reeks",
|
||||||
|
"clearQueueAlertDialog": "Als je de wachtrij onmiddellijk wist, dan worden alle onderdelen die bezig zijn geannuleerd en wordt de gehele wachtrij gewist.",
|
||||||
|
"pending": "Wachtend",
|
||||||
|
"completedIn": "Voltooid na",
|
||||||
|
"resumeFailed": "Fout bij hervatten verwerker",
|
||||||
|
"clear": "Wis",
|
||||||
|
"prune": "Snoei",
|
||||||
|
"total": "Totaal",
|
||||||
|
"canceled": "Geannuleerd",
|
||||||
|
"pruneFailed": "Fout bij snoeien van wachtrij",
|
||||||
|
"cancelBatchSucceeded": "Reeks geannuleerd",
|
||||||
|
"clearTooltip": "Annuleer en wis alle onderdelen",
|
||||||
|
"current": "Huidig",
|
||||||
|
"pauseTooltip": "Onderbreek verwerker",
|
||||||
|
"failed": "Mislukt",
|
||||||
|
"cancelItem": "Annuleer onderdeel",
|
||||||
|
"next": "Volgende",
|
||||||
|
"cancelBatch": "Annuleer reeks",
|
||||||
|
"back": "eind",
|
||||||
|
"cancel": "Annuleer",
|
||||||
|
"session": "Sessie",
|
||||||
|
"queueTotal": "Totaal {{total}}",
|
||||||
|
"resumeSucceeded": "Verwerker hervat",
|
||||||
|
"enqueueing": "Toevoegen van reeks aan wachtrij",
|
||||||
|
"resumeTooltip": "Hervat verwerker",
|
||||||
|
"queueMaxExceeded": "Max. aantal van {{max_queue_size}} overschreden, {{skip}} worden overgeslagen",
|
||||||
|
"resume": "Hervat",
|
||||||
|
"cancelBatchFailed": "Fout bij annuleren van reeks",
|
||||||
|
"clearQueueAlertDialog2": "Weet je zeker dat je de wachtrij wilt wissen?",
|
||||||
|
"item": "Onderdeel",
|
||||||
|
"graphFailedToQueue": "Fout bij toevoegen graaf aan wachtrij"
|
||||||
|
},
|
||||||
|
"sdxl": {
|
||||||
|
"refinerStart": "Startwaarde verfijner",
|
||||||
|
"selectAModel": "Kies een model",
|
||||||
|
"scheduler": "Planner",
|
||||||
|
"cfgScale": "CFG-schaal",
|
||||||
|
"negStylePrompt": "Negatieve-stijlprompt",
|
||||||
|
"noModelsAvailable": "Geen modellen beschikbaar",
|
||||||
|
"refiner": "Verfijner",
|
||||||
|
"negAestheticScore": "Negatieve aantrekkelijkheidsscore",
|
||||||
|
"useRefiner": "Gebruik verfijner",
|
||||||
|
"denoisingStrength": "Sterkte ontruising",
|
||||||
|
"refinermodel": "Verfijnermodel",
|
||||||
|
"posAestheticScore": "Positieve aantrekkelijkheidsscore",
|
||||||
|
"concatPromptStyle": "Plak prompt- en stijltekst aan elkaar",
|
||||||
|
"loading": "Bezig met laden...",
|
||||||
|
"steps": "Stappen",
|
||||||
|
"posStylePrompt": "Positieve-stijlprompt"
|
||||||
|
},
|
||||||
|
"models": {
|
||||||
|
"noMatchingModels": "Geen overeenkomend modellen",
|
||||||
|
"loading": "bezig met laden",
|
||||||
|
"noMatchingLoRAs": "Geen overeenkomende LoRA's",
|
||||||
|
"noLoRAsAvailable": "Geen LoRA's beschikbaar",
|
||||||
|
"noModelsAvailable": "Geen modellen beschikbaar",
|
||||||
|
"selectModel": "Kies een model",
|
||||||
|
"selectLoRA": "Kies een LoRA"
|
||||||
|
},
|
||||||
|
"boards": {
|
||||||
|
"autoAddBoard": "Voeg automatisch bord toe",
|
||||||
|
"topMessage": "Dit bord bevat afbeeldingen die in gebruik zijn door de volgende functies:",
|
||||||
|
"move": "Verplaats",
|
||||||
|
"menuItemAutoAdd": "Voeg dit automatisch toe aan bord",
|
||||||
|
"myBoard": "Mijn bord",
|
||||||
|
"searchBoard": "Zoek borden...",
|
||||||
|
"noMatching": "Geen overeenkomende borden",
|
||||||
|
"selectBoard": "Kies een bord",
|
||||||
|
"cancel": "Annuleer",
|
||||||
|
"addBoard": "Voeg bord toe",
|
||||||
|
"bottomMessage": "Als je dit bord en alle afbeeldingen erop verwijdert, dan worden alle functies teruggezet die ervan gebruik maken.",
|
||||||
|
"uncategorized": "Zonder categorie",
|
||||||
|
"downloadBoard": "Download bord",
|
||||||
|
"changeBoard": "Wijzig bord",
|
||||||
|
"loading": "Bezig met laden...",
|
||||||
|
"clearSearch": "Maak zoekopdracht leeg"
|
||||||
|
},
|
||||||
|
"invocationCache": {
|
||||||
|
"disable": "Schakel uit",
|
||||||
|
"misses": "Mislukt cacheverzoek",
|
||||||
|
"enableFailed": "Fout bij inschakelen aanroepcache",
|
||||||
|
"invocationCache": "Aanroepcache",
|
||||||
|
"clearSucceeded": "Aanroepcache gewist",
|
||||||
|
"enableSucceeded": "Aanroepcache ingeschakeld",
|
||||||
|
"clearFailed": "Fout bij wissen aanroepcache",
|
||||||
|
"hits": "Gelukt cacheverzoek",
|
||||||
|
"disableSucceeded": "Aanroepcache uitgeschakeld",
|
||||||
|
"disableFailed": "Fout bij uitschakelen aanroepcache",
|
||||||
|
"enable": "Schakel in",
|
||||||
|
"clear": "Wis",
|
||||||
|
"maxCacheSize": "Max. grootte cache",
|
||||||
|
"cacheSize": "Grootte cache"
|
||||||
|
},
|
||||||
|
"embedding": {
|
||||||
|
"noMatchingEmbedding": "Geen overeenkomende embeddings",
|
||||||
|
"addEmbedding": "Voeg embedding toe",
|
||||||
|
"incompatibleModel": "Niet-compatibel basismodel:"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -88,7 +88,9 @@
|
|||||||
"t2iAdapter": "T2I Adapter",
|
"t2iAdapter": "T2I Adapter",
|
||||||
"ipAdapter": "IP Adapter",
|
"ipAdapter": "IP Adapter",
|
||||||
"controlAdapter": "Control Adapter",
|
"controlAdapter": "Control Adapter",
|
||||||
"controlNet": "ControlNet"
|
"controlNet": "ControlNet",
|
||||||
|
"on": "开",
|
||||||
|
"auto": "自动"
|
||||||
},
|
},
|
||||||
"gallery": {
|
"gallery": {
|
||||||
"generations": "生成的图像",
|
"generations": "生成的图像",
|
||||||
@ -472,7 +474,8 @@
|
|||||||
"vae": "VAE",
|
"vae": "VAE",
|
||||||
"oliveModels": "Olive",
|
"oliveModels": "Olive",
|
||||||
"loraModels": "LoRA",
|
"loraModels": "LoRA",
|
||||||
"alpha": "Alpha"
|
"alpha": "Alpha",
|
||||||
|
"vaePrecision": "VAE 精度"
|
||||||
},
|
},
|
||||||
"parameters": {
|
"parameters": {
|
||||||
"images": "图像",
|
"images": "图像",
|
||||||
@ -595,7 +598,11 @@
|
|||||||
"useX2Model": "图像太大,无法使用 x4 模型,使用 x2 模型作为替代",
|
"useX2Model": "图像太大,无法使用 x4 模型,使用 x2 模型作为替代",
|
||||||
"tooLarge": "图像太大无法进行放大,请选择更小的图像"
|
"tooLarge": "图像太大无法进行放大,请选择更小的图像"
|
||||||
},
|
},
|
||||||
"iterationsWithCount_other": "{{count}} 次迭代生成"
|
"iterationsWithCount_other": "{{count}} 次迭代生成",
|
||||||
|
"seamlessX&Y": "无缝 X & Y",
|
||||||
|
"aspectRatioFree": "自由",
|
||||||
|
"seamlessX": "无缝 X",
|
||||||
|
"seamlessY": "无缝 Y"
|
||||||
},
|
},
|
||||||
"settings": {
|
"settings": {
|
||||||
"models": "模型",
|
"models": "模型",
|
||||||
@ -628,9 +635,10 @@
|
|||||||
"clearIntermediates": "清除中间产物",
|
"clearIntermediates": "清除中间产物",
|
||||||
"clearIntermediatesDesc3": "您图库中的图像不会被删除。",
|
"clearIntermediatesDesc3": "您图库中的图像不会被删除。",
|
||||||
"clearIntermediatesDesc2": "中间产物图像是生成过程中产生的副产品,与图库中的结果图像不同。清除中间产物可释放磁盘空间。",
|
"clearIntermediatesDesc2": "中间产物图像是生成过程中产生的副产品,与图库中的结果图像不同。清除中间产物可释放磁盘空间。",
|
||||||
"intermediatesCleared_other": "已清除 {{number}} 个中间产物",
|
"intermediatesCleared_other": "已清除 {{count}} 个中间产物",
|
||||||
"clearIntermediatesDesc1": "清除中间产物会重置您的画布和 ControlNet 状态。",
|
"clearIntermediatesDesc1": "清除中间产物会重置您的画布和 ControlNet 状态。",
|
||||||
"intermediatesClearedFailed": "清除中间产物时出现问题"
|
"intermediatesClearedFailed": "清除中间产物时出现问题",
|
||||||
|
"clearIntermediatesWithCount_other": "清除 {{count}} 个中间产物"
|
||||||
},
|
},
|
||||||
"toast": {
|
"toast": {
|
||||||
"tempFoldersEmptied": "临时文件夹已清空",
|
"tempFoldersEmptied": "临时文件夹已清空",
|
||||||
@ -713,7 +721,7 @@
|
|||||||
"canvasSavedGallery": "画布已保存到图库",
|
"canvasSavedGallery": "画布已保存到图库",
|
||||||
"imageUploadFailed": "图像上传失败",
|
"imageUploadFailed": "图像上传失败",
|
||||||
"problemImportingMask": "导入遮罩时出现问题",
|
"problemImportingMask": "导入遮罩时出现问题",
|
||||||
"baseModelChangedCleared_other": "基础模型已更改, 已清除或禁用 {{number}} 个不兼容的子模型"
|
"baseModelChangedCleared_other": "基础模型已更改, 已清除或禁用 {{count}} 个不兼容的子模型"
|
||||||
},
|
},
|
||||||
"unifiedCanvas": {
|
"unifiedCanvas": {
|
||||||
"layer": "图层",
|
"layer": "图层",
|
||||||
@ -1002,7 +1010,27 @@
|
|||||||
"booleanCollection": "布尔值合集",
|
"booleanCollection": "布尔值合集",
|
||||||
"imageCollectionDescription": "一个图像合集。",
|
"imageCollectionDescription": "一个图像合集。",
|
||||||
"loRAModelField": "LoRA",
|
"loRAModelField": "LoRA",
|
||||||
"imageCollection": "图像合集"
|
"imageCollection": "图像合集",
|
||||||
|
"ipAdapterPolymorphicDescription": "一个 IP-Adapters Collection 合集。",
|
||||||
|
"ipAdapterCollection": "IP-Adapters 合集",
|
||||||
|
"conditioningCollection": "条件合集",
|
||||||
|
"ipAdapterPolymorphic": "IP-Adapters 多态",
|
||||||
|
"conditioningCollectionDescription": "条件可以在节点间传递。",
|
||||||
|
"colorPolymorphic": "颜色多态",
|
||||||
|
"conditioningPolymorphic": "条件多态",
|
||||||
|
"latentsCollection": "Latents 合集",
|
||||||
|
"stringPolymorphic": "字符多态",
|
||||||
|
"conditioningPolymorphicDescription": "条件可以在节点间传递。",
|
||||||
|
"imagePolymorphic": "图像多态",
|
||||||
|
"floatPolymorphic": "浮点多态",
|
||||||
|
"ipAdapterCollectionDescription": "一个 IP-Adapters Collection 合集。",
|
||||||
|
"ipAdapter": "IP-Adapter",
|
||||||
|
"booleanPolymorphic": "布尔多态",
|
||||||
|
"conditioningFieldDescription": "条件可以在节点间传递。",
|
||||||
|
"integerPolymorphic": "整数多态",
|
||||||
|
"latentsPolymorphic": "Latents 多态",
|
||||||
|
"conditioningField": "条件",
|
||||||
|
"latentsField": "Latents"
|
||||||
},
|
},
|
||||||
"controlnet": {
|
"controlnet": {
|
||||||
"resize": "直接缩放",
|
"resize": "直接缩放",
|
||||||
@ -1086,7 +1114,7 @@
|
|||||||
"depthZoe": "Depth (Zoe)",
|
"depthZoe": "Depth (Zoe)",
|
||||||
"colorMap": "Color",
|
"colorMap": "Color",
|
||||||
"openPose": "Openpose",
|
"openPose": "Openpose",
|
||||||
"controlAdapter": "Control Adapter",
|
"controlAdapter_other": "Control Adapters",
|
||||||
"lineartAnime": "Lineart Anime",
|
"lineartAnime": "Lineart Anime",
|
||||||
"canny": "Canny"
|
"canny": "Canny"
|
||||||
},
|
},
|
||||||
@ -1140,7 +1168,7 @@
|
|||||||
"queuedCount": "{{pending}} 待处理",
|
"queuedCount": "{{pending}} 待处理",
|
||||||
"front": "前",
|
"front": "前",
|
||||||
"pruneTooltip": "修剪 {{item_count}} 个已完成的项目",
|
"pruneTooltip": "修剪 {{item_count}} 个已完成的项目",
|
||||||
"batchQueuedDesc": "在队列的 {{direction}} 中添加了 {{item_count}} 个会话",
|
"batchQueuedDesc_other": "在队列的 {{direction}} 中添加了 {{count}} 个会话",
|
||||||
"graphQueued": "节点图已加入队列",
|
"graphQueued": "节点图已加入队列",
|
||||||
"back": "后",
|
"back": "后",
|
||||||
"session": "会话",
|
"session": "会话",
|
||||||
@ -1191,7 +1219,9 @@
|
|||||||
"steps": "步数",
|
"steps": "步数",
|
||||||
"scheduler": "调度器",
|
"scheduler": "调度器",
|
||||||
"seamless": "无缝",
|
"seamless": "无缝",
|
||||||
"fit": "图生图适应"
|
"fit": "图生图匹配",
|
||||||
|
"recallParameters": "召回参数",
|
||||||
|
"noRecallParameters": "未找到要召回的参数"
|
||||||
},
|
},
|
||||||
"models": {
|
"models": {
|
||||||
"noMatchingModels": "无相匹配的模型",
|
"noMatchingModels": "无相匹配的模型",
|
||||||
@ -1242,7 +1272,9 @@
|
|||||||
"popovers": {
|
"popovers": {
|
||||||
"compositingMaskAdjustments": {
|
"compositingMaskAdjustments": {
|
||||||
"heading": "遮罩调整",
|
"heading": "遮罩调整",
|
||||||
"paragraphs": ["调整遮罩。"]
|
"paragraphs": [
|
||||||
|
"调整遮罩。"
|
||||||
|
]
|
||||||
},
|
},
|
||||||
"paramRatio": {
|
"paramRatio": {
|
||||||
"heading": "纵横比",
|
"heading": "纵横比",
|
||||||
@ -1260,7 +1292,9 @@
|
|||||||
},
|
},
|
||||||
"compositingBlur": {
|
"compositingBlur": {
|
||||||
"heading": "模糊",
|
"heading": "模糊",
|
||||||
"paragraphs": ["遮罩模糊半径。"]
|
"paragraphs": [
|
||||||
|
"遮罩模糊半径。"
|
||||||
|
]
|
||||||
},
|
},
|
||||||
"noiseUseCPU": {
|
"noiseUseCPU": {
|
||||||
"heading": "使用 CPU 噪声",
|
"heading": "使用 CPU 噪声",
|
||||||
@ -1278,11 +1312,15 @@
|
|||||||
},
|
},
|
||||||
"compositingCoherenceMode": {
|
"compositingCoherenceMode": {
|
||||||
"heading": "模式",
|
"heading": "模式",
|
||||||
"paragraphs": ["一致性层模式。"]
|
"paragraphs": [
|
||||||
|
"一致性层模式。"
|
||||||
|
]
|
||||||
},
|
},
|
||||||
"controlNetResizeMode": {
|
"controlNetResizeMode": {
|
||||||
"heading": "缩放模式",
|
"heading": "缩放模式",
|
||||||
"paragraphs": ["ControlNet 输入图像适应输出图像大小的方法。"]
|
"paragraphs": [
|
||||||
|
"ControlNet 输入图像适应输出图像大小的方法。"
|
||||||
|
]
|
||||||
},
|
},
|
||||||
"clipSkip": {
|
"clipSkip": {
|
||||||
"paragraphs": [
|
"paragraphs": [
|
||||||
@ -1308,7 +1346,9 @@
|
|||||||
},
|
},
|
||||||
"compositingCoherencePass": {
|
"compositingCoherencePass": {
|
||||||
"heading": "一致性层",
|
"heading": "一致性层",
|
||||||
"paragraphs": ["第二轮去噪有助于合成内补/外扩图像。"]
|
"paragraphs": [
|
||||||
|
"第二轮去噪有助于合成内补/外扩图像。"
|
||||||
|
]
|
||||||
},
|
},
|
||||||
"compositingStrength": {
|
"compositingStrength": {
|
||||||
"heading": "强度",
|
"heading": "强度",
|
||||||
@ -1326,7 +1366,9 @@
|
|||||||
},
|
},
|
||||||
"compositingBlurMethod": {
|
"compositingBlurMethod": {
|
||||||
"heading": "模糊方式",
|
"heading": "模糊方式",
|
||||||
"paragraphs": ["应用于遮罩区域的模糊方法。"]
|
"paragraphs": [
|
||||||
|
"应用于遮罩区域的模糊方法。"
|
||||||
|
]
|
||||||
},
|
},
|
||||||
"paramScheduler": {
|
"paramScheduler": {
|
||||||
"heading": "调度器",
|
"heading": "调度器",
|
||||||
@ -1336,11 +1378,15 @@
|
|||||||
},
|
},
|
||||||
"controlNetWeight": {
|
"controlNetWeight": {
|
||||||
"heading": "权重",
|
"heading": "权重",
|
||||||
"paragraphs": ["ControlNet 对生成图像的影响强度。"]
|
"paragraphs": [
|
||||||
|
"ControlNet 对生成图像的影响强度。"
|
||||||
|
]
|
||||||
},
|
},
|
||||||
"paramCFGScale": {
|
"paramCFGScale": {
|
||||||
"heading": "CFG 等级",
|
"heading": "CFG 等级",
|
||||||
"paragraphs": ["控制提示词对生成过程的影响程度。"]
|
"paragraphs": [
|
||||||
|
"控制提示词对生成过程的影响程度。"
|
||||||
|
]
|
||||||
},
|
},
|
||||||
"paramSteps": {
|
"paramSteps": {
|
||||||
"heading": "步数",
|
"heading": "步数",
|
||||||
@ -1358,11 +1404,15 @@
|
|||||||
},
|
},
|
||||||
"lora": {
|
"lora": {
|
||||||
"heading": "LoRA 权重",
|
"heading": "LoRA 权重",
|
||||||
"paragraphs": ["更高的 LoRA 权重会对最终图像产生更大的影响。"]
|
"paragraphs": [
|
||||||
|
"更高的 LoRA 权重会对最终图像产生更大的影响。"
|
||||||
|
]
|
||||||
},
|
},
|
||||||
"infillMethod": {
|
"infillMethod": {
|
||||||
"heading": "填充方法",
|
"heading": "填充方法",
|
||||||
"paragraphs": ["填充选定区域的方式。"]
|
"paragraphs": [
|
||||||
|
"填充选定区域的方式。"
|
||||||
|
]
|
||||||
},
|
},
|
||||||
"controlNetBeginEnd": {
|
"controlNetBeginEnd": {
|
||||||
"heading": "开始 / 结束步数百分比",
|
"heading": "开始 / 结束步数百分比",
|
||||||
@ -1373,7 +1423,9 @@
|
|||||||
},
|
},
|
||||||
"scaleBeforeProcessing": {
|
"scaleBeforeProcessing": {
|
||||||
"heading": "处理前缩放",
|
"heading": "处理前缩放",
|
||||||
"paragraphs": ["生成图像前将所选区域缩放为最适合模型的大小。"]
|
"paragraphs": [
|
||||||
|
"生成图像前将所选区域缩放为最适合模型的大小。"
|
||||||
|
]
|
||||||
},
|
},
|
||||||
"paramDenoisingStrength": {
|
"paramDenoisingStrength": {
|
||||||
"heading": "去噪强度",
|
"heading": "去噪强度",
|
||||||
@ -1391,7 +1443,9 @@
|
|||||||
},
|
},
|
||||||
"controlNetControlMode": {
|
"controlNetControlMode": {
|
||||||
"heading": "控制模式",
|
"heading": "控制模式",
|
||||||
"paragraphs": ["给提示词或 ControlNet 增加更大的权重。"]
|
"paragraphs": [
|
||||||
|
"给提示词或 ControlNet 增加更大的权重。"
|
||||||
|
]
|
||||||
},
|
},
|
||||||
"dynamicPrompts": {
|
"dynamicPrompts": {
|
||||||
"paragraphs": [
|
"paragraphs": [
|
||||||
@ -1402,7 +1456,9 @@
|
|||||||
"heading": "动态提示词"
|
"heading": "动态提示词"
|
||||||
},
|
},
|
||||||
"paramVAE": {
|
"paramVAE": {
|
||||||
"paragraphs": ["用于将 AI 输出转换成最终图像的模型。"],
|
"paragraphs": [
|
||||||
|
"用于将 AI 输出转换成最终图像的模型。"
|
||||||
|
],
|
||||||
"heading": "VAE"
|
"heading": "VAE"
|
||||||
},
|
},
|
||||||
"dynamicPromptsSeedBehaviour": {
|
"dynamicPromptsSeedBehaviour": {
|
||||||
@ -1416,7 +1472,9 @@
|
|||||||
},
|
},
|
||||||
"dynamicPromptsMaxPrompts": {
|
"dynamicPromptsMaxPrompts": {
|
||||||
"heading": "最大提示词数量",
|
"heading": "最大提示词数量",
|
||||||
"paragraphs": ["限制动态提示词可生成的提示词数量。"]
|
"paragraphs": [
|
||||||
|
"限制动态提示词可生成的提示词数量。"
|
||||||
|
]
|
||||||
},
|
},
|
||||||
"controlNet": {
|
"controlNet": {
|
||||||
"paragraphs": [
|
"paragraphs": [
|
||||||
|
@ -44,7 +44,7 @@ export const addCanvasMergedListener = () => {
|
|||||||
}
|
}
|
||||||
|
|
||||||
const baseLayerRect = canvasBaseLayer.getClientRect({
|
const baseLayerRect = canvasBaseLayer.getClientRect({
|
||||||
relativeTo: canvasBaseLayer.getParent(),
|
relativeTo: canvasBaseLayer.getParent() ?? undefined,
|
||||||
});
|
});
|
||||||
|
|
||||||
const imageDTO = await dispatch(
|
const imageDTO = await dispatch(
|
||||||
|
@ -30,6 +30,7 @@ import {
|
|||||||
isCanvasMaskLine,
|
isCanvasMaskLine,
|
||||||
} from './canvasTypes';
|
} from './canvasTypes';
|
||||||
import { appSocketQueueItemStatusChanged } from 'services/events/actions';
|
import { appSocketQueueItemStatusChanged } from 'services/events/actions';
|
||||||
|
import { queueApi } from 'services/api/endpoints/queue';
|
||||||
|
|
||||||
export const initialLayerState: CanvasLayerState = {
|
export const initialLayerState: CanvasLayerState = {
|
||||||
objects: [],
|
objects: [],
|
||||||
@ -812,6 +813,20 @@ export const canvasSlice = createSlice({
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
builder.addMatcher(
|
||||||
|
queueApi.endpoints.clearQueue.matchFulfilled,
|
||||||
|
(state) => {
|
||||||
|
state.batchIds = [];
|
||||||
|
}
|
||||||
|
);
|
||||||
|
builder.addMatcher(
|
||||||
|
queueApi.endpoints.cancelByBatchIds.matchFulfilled,
|
||||||
|
(state, action) => {
|
||||||
|
state.batchIds = state.batchIds.filter(
|
||||||
|
(id) => !action.meta.arg.originalArgs.batch_ids.includes(id)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
);
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -86,7 +86,7 @@ export const addT2IAdaptersToLinearGraph = (
|
|||||||
|
|
||||||
graph.nodes[t2iAdapterNode.id] = t2iAdapterNode as T2IAdapterInvocation;
|
graph.nodes[t2iAdapterNode.id] = t2iAdapterNode as T2IAdapterInvocation;
|
||||||
|
|
||||||
if (metadataAccumulator?.ipAdapters) {
|
if (metadataAccumulator?.t2iAdapters) {
|
||||||
// metadata accumulator only needs a control field - not the whole node
|
// metadata accumulator only needs a control field - not the whole node
|
||||||
// extract what we need and add to the accumulator
|
// extract what we need and add to the accumulator
|
||||||
const t2iAdapterField = omit(t2iAdapterNode, [
|
const t2iAdapterField = omit(t2iAdapterNode, [
|
||||||
|
@ -3,6 +3,7 @@ import { useAppDispatch } from 'app/store/storeHooks';
|
|||||||
import { controlAdaptersReset } from 'features/controlAdapters/store/controlAdaptersSlice';
|
import { controlAdaptersReset } from 'features/controlAdapters/store/controlAdaptersSlice';
|
||||||
import { useCallback, useEffect } from 'react';
|
import { useCallback, useEffect } from 'react';
|
||||||
import { useTranslation } from 'react-i18next';
|
import { useTranslation } from 'react-i18next';
|
||||||
|
import { useGetQueueStatusQuery } from 'services/api/endpoints/queue';
|
||||||
import IAIButton from '../../../../common/components/IAIButton';
|
import IAIButton from '../../../../common/components/IAIButton';
|
||||||
import {
|
import {
|
||||||
useClearIntermediatesMutation,
|
useClearIntermediatesMutation,
|
||||||
@ -22,7 +23,16 @@ export default function SettingsClearIntermediates() {
|
|||||||
const [clearIntermediates, { isLoading: isLoadingClearIntermediates }] =
|
const [clearIntermediates, { isLoading: isLoadingClearIntermediates }] =
|
||||||
useClearIntermediatesMutation();
|
useClearIntermediatesMutation();
|
||||||
|
|
||||||
|
const { data: queueStatus } = useGetQueueStatusQuery();
|
||||||
|
const hasPendingItems =
|
||||||
|
queueStatus &&
|
||||||
|
(queueStatus.queue.in_progress > 0 || queueStatus.queue.pending > 0);
|
||||||
|
|
||||||
const handleClickClearIntermediates = useCallback(() => {
|
const handleClickClearIntermediates = useCallback(() => {
|
||||||
|
if (hasPendingItems) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
clearIntermediates()
|
clearIntermediates()
|
||||||
.unwrap()
|
.unwrap()
|
||||||
.then((clearedCount) => {
|
.then((clearedCount) => {
|
||||||
@ -43,7 +53,7 @@ export default function SettingsClearIntermediates() {
|
|||||||
})
|
})
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
}, [t, clearIntermediates, dispatch]);
|
}, [t, clearIntermediates, dispatch, hasPendingItems]);
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
// update the count on mount
|
// update the count on mount
|
||||||
@ -54,10 +64,13 @@ export default function SettingsClearIntermediates() {
|
|||||||
<StyledFlex>
|
<StyledFlex>
|
||||||
<Heading size="sm">{t('settings.clearIntermediates')}</Heading>
|
<Heading size="sm">{t('settings.clearIntermediates')}</Heading>
|
||||||
<IAIButton
|
<IAIButton
|
||||||
|
tooltip={
|
||||||
|
hasPendingItems ? t('settings.clearIntermediatesDisabled') : undefined
|
||||||
|
}
|
||||||
colorScheme="warning"
|
colorScheme="warning"
|
||||||
onClick={handleClickClearIntermediates}
|
onClick={handleClickClearIntermediates}
|
||||||
isLoading={isLoadingClearIntermediates}
|
isLoading={isLoadingClearIntermediates}
|
||||||
isDisabled={!intermediatesCount}
|
isDisabled={!intermediatesCount || hasPendingItems}
|
||||||
>
|
>
|
||||||
{t('settings.clearIntermediatesWithCount', {
|
{t('settings.clearIntermediatesWithCount', {
|
||||||
count: intermediatesCount ?? 0,
|
count: intermediatesCount ?? 0,
|
||||||
|
File diff suppressed because one or more lines are too long
File diff suppressed because it is too large
Load Diff
@ -11,7 +11,10 @@ def test_libc_util_mallinfo2():
|
|||||||
# TODO: Set the expected result preemptively based on the system properties.
|
# TODO: Set the expected result preemptively based on the system properties.
|
||||||
pytest.xfail("libc shared library is not available on this system.")
|
pytest.xfail("libc shared library is not available on this system.")
|
||||||
|
|
||||||
info = libc.mallinfo2()
|
try:
|
||||||
|
info = libc.mallinfo2()
|
||||||
|
except AttributeError:
|
||||||
|
pytest.xfail("`mallinfo2` is not available on this system, likely due to glibc < 2.33.")
|
||||||
|
|
||||||
assert info.arena > 0
|
assert info.arena > 0
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user