mirror of
https://github.com/Comfy-Org/ComfyUI_frontend.git
synced 2026-03-15 18:07:35 +00:00
Compare commits
6 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
5d7fd4b22b | ||
|
|
17ad24907c | ||
|
|
3fe70be39d | ||
|
|
afd561eb83 | ||
|
|
808d63996c | ||
|
|
cf1ff71651 |
208
src/components/common/ListExplorer.vue
Normal file
208
src/components/common/ListExplorer.vue
Normal file
@@ -0,0 +1,208 @@
|
||||
<template>
|
||||
<div class="h-full overflow-hidden pb-1">
|
||||
<div class="flex item-center">
|
||||
<div
|
||||
v-for="item in columns"
|
||||
:key="item.key"
|
||||
class="flex justify-between items-center px-2 overflow-hidden hover:bg-blue-600/40 cursor-pointer"
|
||||
:style="{ flexBasis: `${item.width}px`, height: '36px' }"
|
||||
@click="changeSort(item)"
|
||||
>
|
||||
<span class="whitespace-nowrap overflow-hidden text-ellipsis">
|
||||
{{ $t(`g.${item.key}`) }}
|
||||
</span>
|
||||
<span
|
||||
v-show="item.key === sortField"
|
||||
:class="[
|
||||
'text-xs pi',
|
||||
sortDirection === 'asc' ? 'pi-angle-up' : 'pi-angle-down'
|
||||
]"
|
||||
></span>
|
||||
</div>
|
||||
</div>
|
||||
<div :style="{ height: 'calc(100% - 36px)' }">
|
||||
<VirtualScroll :items="sortedItems" :item-size="36">
|
||||
<template #item="{ item: row }">
|
||||
<div
|
||||
class="h-full py-px"
|
||||
@click="emit('itemClick', row, $event)"
|
||||
@dblclick="emit('itemDbClick', row, $event)"
|
||||
>
|
||||
<div
|
||||
:class="[
|
||||
'flex items-center h-full hover:bg-blue-600/40',
|
||||
selectedKeys.includes(row.key) ? 'bg-blue-700/40' : ''
|
||||
]"
|
||||
>
|
||||
<div
|
||||
v-for="(item, index) in columns"
|
||||
:key="item.key"
|
||||
class="flex items-center px-2 py-1 overflow-hidden select-none"
|
||||
:style="{ flexBasis: `${item.width}px`, textAlign: item.align }"
|
||||
>
|
||||
<span v-if="index === 0" :class="['mr-2 pi', row.icon]"></span>
|
||||
<span class="whitespace-nowrap overflow-hidden text-ellipsis">
|
||||
{{ (row._display as any)[item.key] }}
|
||||
</span>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</template>
|
||||
</VirtualScroll>
|
||||
</div>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script setup lang="ts" generic="T">
|
||||
import { computed, provide, ref } from 'vue'
|
||||
import { useI18n } from 'vue-i18n'
|
||||
|
||||
import { formatSize } from '@/utils/formatUtil'
|
||||
|
||||
import VirtualScroll from './VirtualScroll.vue'
|
||||
|
||||
const { t } = useI18n()
|
||||
|
||||
type SortDirection = 'asc' | 'desc'
|
||||
|
||||
type Item = {
|
||||
key: string
|
||||
name: string
|
||||
type: string
|
||||
modifyTime: number
|
||||
size: number
|
||||
}
|
||||
|
||||
type RecordString<T> = Record<keyof T, any>
|
||||
|
||||
type ResolvedItem<T> = T & {
|
||||
icon: string
|
||||
_display: RecordString<T>
|
||||
}
|
||||
|
||||
interface Column {
|
||||
key: string
|
||||
width: number
|
||||
align?: 'left' | 'right'
|
||||
defaultSort?: SortDirection
|
||||
renderText: (val: any, row: Item) => string
|
||||
}
|
||||
|
||||
const props = defineProps<{
|
||||
items: Item[]
|
||||
}>()
|
||||
|
||||
const selectedKeys = defineModel<string[]>({ default: [] })
|
||||
|
||||
const emit = defineEmits<{
|
||||
itemClick: [Item, MouseEvent]
|
||||
itemDbClick: [Item, MouseEvent]
|
||||
}>()
|
||||
|
||||
const columns = ref<Column[]>([
|
||||
{
|
||||
key: 'name',
|
||||
width: 300,
|
||||
renderText: (val) => val
|
||||
},
|
||||
{
|
||||
key: 'modifyTime',
|
||||
width: 200,
|
||||
defaultSort: 'desc',
|
||||
renderText: (val) =>
|
||||
new Date(val).toLocaleDateString() +
|
||||
' ' +
|
||||
new Date(val).toLocaleTimeString()
|
||||
},
|
||||
{
|
||||
key: 'type',
|
||||
width: 100,
|
||||
renderText: (val) => t(`g.${val}`)
|
||||
},
|
||||
{
|
||||
key: 'size',
|
||||
width: 120,
|
||||
defaultSort: 'desc',
|
||||
align: 'right',
|
||||
renderText: (val, item) => (item.type === 'folder' ? '' : formatSize(val))
|
||||
}
|
||||
])
|
||||
|
||||
provide('listExplorerColumns', columns)
|
||||
|
||||
const sortDirection = ref<SortDirection>('asc')
|
||||
const sortField = ref('name')
|
||||
|
||||
const iconMapLegacy = (icon: string) => {
|
||||
const prefix = 'pi-'
|
||||
const legacy: Record<string, string> = {
|
||||
audio: 'headphones'
|
||||
}
|
||||
return prefix + (legacy[icon] || icon)
|
||||
}
|
||||
|
||||
const renderedItems = computed(() => {
|
||||
const columnRenderText = columns.value.reduce(
|
||||
(acc, column) => {
|
||||
acc[column.key] = column.renderText
|
||||
return acc
|
||||
},
|
||||
{} as Record<string, (val: any, row: Item) => string>
|
||||
)
|
||||
|
||||
return props.items.map((item) => {
|
||||
const display = Object.entries(item).reduce(
|
||||
(acc, [key, value]) => {
|
||||
acc[key] = columnRenderText[key]?.(value, item) ?? value
|
||||
return acc
|
||||
},
|
||||
{} as Record<string, any>
|
||||
)
|
||||
return { ...item, icon: iconMapLegacy(item.type), _display: display }
|
||||
})
|
||||
})
|
||||
|
||||
const sortedItems = computed(() => {
|
||||
const folderItems: ResolvedItem<Item>[] = []
|
||||
const fileItems: ResolvedItem<Item>[] = []
|
||||
|
||||
for (const item of renderedItems.value) {
|
||||
if (item.type === 'folder') {
|
||||
folderItems.push(item)
|
||||
} else {
|
||||
fileItems.push(item)
|
||||
}
|
||||
}
|
||||
|
||||
const direction = sortDirection.value === 'asc' ? 1 : -1
|
||||
|
||||
const sorting = (a: ResolvedItem<Item>, b: ResolvedItem<Item>) => {
|
||||
const aValue = (a as any)[sortField.value]
|
||||
const bValue = (b as any)[sortField.value]
|
||||
|
||||
const result =
|
||||
typeof aValue === 'string'
|
||||
? aValue.localeCompare(bValue)
|
||||
: aValue - bValue
|
||||
|
||||
return result * direction
|
||||
}
|
||||
|
||||
folderItems.sort(sorting)
|
||||
fileItems.sort(sorting)
|
||||
|
||||
const folderFirstField = ['modifyTime', 'type']
|
||||
return direction > 0 || folderFirstField.includes(sortField.value)
|
||||
? [...folderItems, ...fileItems]
|
||||
: [...fileItems, ...folderItems]
|
||||
})
|
||||
|
||||
const changeSort = (column: Column) => {
|
||||
if (column.key === sortField.value) {
|
||||
sortDirection.value = sortDirection.value === 'asc' ? 'desc' : 'asc'
|
||||
} else {
|
||||
sortField.value = column.key
|
||||
sortDirection.value = column.defaultSort ?? 'asc'
|
||||
}
|
||||
}
|
||||
</script>
|
||||
85
src/components/common/VirtualScroll.vue
Normal file
85
src/components/common/VirtualScroll.vue
Normal file
@@ -0,0 +1,85 @@
|
||||
<template>
|
||||
<div ref="container" class="scroll-container">
|
||||
<div :style="{ height: `${state.start * itemSize}px` }"></div>
|
||||
<div :style="contentStyle">
|
||||
<div
|
||||
v-for="item in renderedItems"
|
||||
:key="item.key"
|
||||
:style="{ height: `${itemSize}px` }"
|
||||
data-virtual-item
|
||||
>
|
||||
<slot name="item" :item="item"></slot>
|
||||
</div>
|
||||
</div>
|
||||
<div
|
||||
:style="{ height: `${(items.length - state.end) * itemSize}px` }"
|
||||
></div>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script setup lang="ts" generic="T">
|
||||
import { useElementSize, useScroll } from '@vueuse/core'
|
||||
import { clamp } from 'es-toolkit'
|
||||
import { type CSSProperties, computed, ref } from 'vue'
|
||||
|
||||
type Item = T & { key: string }
|
||||
|
||||
const props = defineProps<{
|
||||
items: Item[]
|
||||
itemSize: number
|
||||
contentStyle?: Partial<CSSProperties>
|
||||
scrollThrottle?: number
|
||||
}>()
|
||||
|
||||
const { scrollThrottle = 64 } = props
|
||||
|
||||
const container = ref<HTMLElement | null>(null)
|
||||
const { height } = useElementSize(container)
|
||||
const { y: scrollY } = useScroll(container, {
|
||||
throttle: scrollThrottle,
|
||||
eventListenerOptions: { passive: true }
|
||||
})
|
||||
|
||||
const viewRows = computed(() => Math.ceil(height.value / props.itemSize))
|
||||
const offsetRows = computed(() => Math.floor(scrollY.value / props.itemSize))
|
||||
|
||||
const state = computed(() => {
|
||||
const bufferRows = viewRows.value
|
||||
|
||||
const fromRow = offsetRows.value - bufferRows
|
||||
const toRow = offsetRows.value + bufferRows + viewRows.value
|
||||
|
||||
return {
|
||||
start: clamp(fromRow, 0, props.items.length),
|
||||
end: clamp(toRow, fromRow, props.items.length)
|
||||
}
|
||||
})
|
||||
|
||||
const renderedItems = computed(() => {
|
||||
return props.items.slice(state.value.start, state.value.end)
|
||||
})
|
||||
|
||||
const reset = () => {}
|
||||
|
||||
defineExpose({
|
||||
reset
|
||||
})
|
||||
</script>
|
||||
|
||||
<style scoped>
|
||||
.scroll-container {
|
||||
height: 100%;
|
||||
overflow-y: auto;
|
||||
|
||||
/* Firefox */
|
||||
scrollbar-width: none;
|
||||
|
||||
&::-webkit-scrollbar {
|
||||
width: 1px;
|
||||
}
|
||||
|
||||
&::-webkit-scrollbar-thumb {
|
||||
background-color: transparent;
|
||||
}
|
||||
}
|
||||
</style>
|
||||
253
src/components/sidebar/tabs/OutputExplorerSidebarTab.vue
Normal file
253
src/components/sidebar/tabs/OutputExplorerSidebarTab.vue
Normal file
@@ -0,0 +1,253 @@
|
||||
<template>
|
||||
<SidebarTabTemplate :title="$t('sideToolbar.outputExplorer')">
|
||||
<template #tool-buttons>
|
||||
<Button
|
||||
v-tooltip.bottom="$t('g.back')"
|
||||
icon="pi pi-arrow-up"
|
||||
severity="secondary"
|
||||
text
|
||||
:disabled="!currentFolder"
|
||||
@click="handleBackParentFolder"
|
||||
/>
|
||||
<Button
|
||||
v-tooltip.bottom="$t('g.refresh')"
|
||||
icon="pi pi-refresh"
|
||||
severity="secondary"
|
||||
text
|
||||
@click="loadFolderItems"
|
||||
/>
|
||||
</template>
|
||||
<template #header>
|
||||
<SearchBox
|
||||
v-model:modelValue="searchQuery"
|
||||
class="model-lib-search-box p-2 2xl:p-4"
|
||||
:placeholder="$t('g.searchIn', ['output'])"
|
||||
@search="handleSearch"
|
||||
/>
|
||||
</template>
|
||||
<template #body>
|
||||
<div class="h-full overflow-hidden">
|
||||
<ListExplorer
|
||||
class="flex-1"
|
||||
:style="{ height: 'calc(100% - 36px)' }"
|
||||
:items="renderedItems"
|
||||
@item-db-click="handleDbClickItem"
|
||||
></ListExplorer>
|
||||
<div class="h-8 flex items-center px-2 text-sm">
|
||||
<div class="flex gap-1">
|
||||
{{ $t('g.itemsCount', [itemsCount]) }}
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</template>
|
||||
</SidebarTabTemplate>
|
||||
|
||||
<Teleport to="body">
|
||||
<div
|
||||
v-show="previewVisible"
|
||||
class="fixed left-0 top-0 z-[5000] flex h-full w-full items-center justify-center bg-black/70"
|
||||
>
|
||||
<div class="absolute right-3 top-3">
|
||||
<Button
|
||||
icon="pi pi-times"
|
||||
severity="secondary"
|
||||
rounded
|
||||
@click="closePreview"
|
||||
></Button>
|
||||
</div>
|
||||
<div class="h-full w-full select-none p-10">
|
||||
<img
|
||||
v-if="currentItem?.type === 'image'"
|
||||
class="h-full w-full object-contain"
|
||||
:src="`/api/output/${folderPrefix}${currentItem?.name}`"
|
||||
alt="preview"
|
||||
/>
|
||||
<video
|
||||
v-if="currentItem?.type === 'video'"
|
||||
class="h-full w-full object-contain"
|
||||
:src="`/api/output/${folderPrefix}${currentItem?.name}`"
|
||||
controls
|
||||
></video>
|
||||
<div
|
||||
v-if="currentItem?.type === 'audio'"
|
||||
class="w-full h-full flex items-center justify-center"
|
||||
>
|
||||
<div
|
||||
class="px-8 pt-6 rounded-full"
|
||||
:style="{ background: 'var(--p-button-secondary-background)' }"
|
||||
>
|
||||
<div class="text-center mb-2">{{ currentItem?.name }}</div>
|
||||
<audio
|
||||
:src="`/api/output/${folderPrefix}${currentItem?.name}`"
|
||||
controls
|
||||
></audio>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<div class="absolute left-2 top-1/2">
|
||||
<Button
|
||||
icon="pi pi-angle-left"
|
||||
severity="secondary"
|
||||
rounded
|
||||
@click="openPreviousItem"
|
||||
></Button>
|
||||
</div>
|
||||
<div class="absolute right-2 top-1/2">
|
||||
<Button
|
||||
icon="pi pi-angle-right"
|
||||
severity="secondary"
|
||||
rounded
|
||||
@click="openNextItem"
|
||||
></Button>
|
||||
</div>
|
||||
</div>
|
||||
</Teleport>
|
||||
</template>
|
||||
|
||||
<script setup lang="ts">
|
||||
import Button from 'primevue/button'
|
||||
import { computed, onMounted, ref } from 'vue'
|
||||
|
||||
import ListExplorer from '@/components/common/ListExplorer.vue'
|
||||
import SearchBox from '@/components/common/SearchBox.vue'
|
||||
import SidebarTabTemplate from '@/components/sidebar/tabs/SidebarTabTemplate.vue'
|
||||
import { api } from '@/scripts/api'
|
||||
|
||||
interface OutputItem {
|
||||
key: string
|
||||
name: string
|
||||
type: 'folder' | 'image' | 'video' | 'audio'
|
||||
size: number
|
||||
createTime: number
|
||||
modifyTime: number
|
||||
}
|
||||
|
||||
const searchQuery = ref<string>('')
|
||||
|
||||
const folderPaths = ref<OutputItem[]>([])
|
||||
const currentFolder = computed(() => {
|
||||
return folderPaths.value.map((item) => item.name).join('/')
|
||||
})
|
||||
const currentFolderItems = ref<OutputItem[]>([])
|
||||
const folderPrefix = computed(() => {
|
||||
return currentFolder.value ? `${currentFolder.value}/` : ''
|
||||
})
|
||||
|
||||
const filterContent = ref('')
|
||||
|
||||
const itemsCount = computed(() => {
|
||||
return currentFolderItems.value.length.toLocaleString()
|
||||
})
|
||||
|
||||
const renderedItems = computed(() => {
|
||||
const query = filterContent.value
|
||||
let items = currentFolderItems.value
|
||||
|
||||
if (query) {
|
||||
items = items.filter((item) => {
|
||||
return item.name.toLowerCase().includes(query.toLowerCase())
|
||||
})
|
||||
}
|
||||
|
||||
// Convert OutputItem to Item format expected by ListExplorer
|
||||
return items.map((item) => ({
|
||||
key: item.key,
|
||||
name: item.name,
|
||||
type: item.type,
|
||||
size: item.size,
|
||||
modifyTime: item.modifyTime
|
||||
}))
|
||||
})
|
||||
|
||||
const handleSearch = async (query: string) => {
|
||||
filterContent.value = query
|
||||
}
|
||||
|
||||
const previewVisible = ref(false)
|
||||
const currentItem = ref<OutputItem | null>(null)
|
||||
const currentItemIndex = ref(-1)
|
||||
const currentTypeItems = ref<OutputItem[]>([])
|
||||
|
||||
const closePreview = () => {
|
||||
previewVisible.value = false
|
||||
currentItem.value = null
|
||||
}
|
||||
|
||||
const openPreviousItem = () => {
|
||||
currentItemIndex.value--
|
||||
if (currentItemIndex.value < 0) {
|
||||
currentItemIndex.value = currentTypeItems.value.length - 1
|
||||
}
|
||||
const item = currentTypeItems.value[currentItemIndex.value]
|
||||
currentItem.value = item
|
||||
}
|
||||
|
||||
const openNextItem = () => {
|
||||
currentItemIndex.value++
|
||||
if (currentItemIndex.value > currentTypeItems.value.length - 1) {
|
||||
currentItemIndex.value = 0
|
||||
}
|
||||
const item = currentTypeItems.value[currentItemIndex.value]
|
||||
currentItem.value = item
|
||||
}
|
||||
|
||||
const openItemPreview = (item: OutputItem) => {
|
||||
previewVisible.value = true
|
||||
currentItem.value = item
|
||||
|
||||
const itemType = item.type
|
||||
currentTypeItems.value = currentFolderItems.value.filter(
|
||||
(o) => o.type === itemType
|
||||
)
|
||||
|
||||
currentItemIndex.value = currentTypeItems.value.indexOf(item)
|
||||
}
|
||||
|
||||
const loadFolderItems = async () => {
|
||||
const resData = await api.getOutputFolderItems(currentFolder.value)
|
||||
currentFolderItems.value = resData.map((item: any) => ({
|
||||
key: item.name,
|
||||
...item
|
||||
}))
|
||||
}
|
||||
|
||||
const openFolder = async (item: OutputItem, pathIndex: number) => {
|
||||
folderPaths.value.splice(pathIndex)
|
||||
folderPaths.value.push(item)
|
||||
await loadFolderItems()
|
||||
}
|
||||
|
||||
const handleBackParentFolder = async () => {
|
||||
folderPaths.value.pop()
|
||||
await loadFolderItems()
|
||||
}
|
||||
|
||||
const handleDbClickItem = (item: any, _event: MouseEvent) => {
|
||||
// Find the original OutputItem from currentFolderItems
|
||||
const originalItem = currentFolderItems.value.find(
|
||||
(outputItem) => outputItem.key === item.key
|
||||
)
|
||||
if (!originalItem) return
|
||||
|
||||
if (originalItem.type === 'folder') {
|
||||
void openFolder(originalItem, folderPaths.value.length)
|
||||
} else {
|
||||
openItemPreview(originalItem)
|
||||
}
|
||||
}
|
||||
|
||||
onMounted(async () => {
|
||||
await loadFolderItems()
|
||||
})
|
||||
</script>
|
||||
|
||||
<style scoped>
|
||||
:deep(.pi-fake-spacer) {
|
||||
height: 1px;
|
||||
width: 16px;
|
||||
}
|
||||
|
||||
:deep(audio::-webkit-media-controls-enclosure) {
|
||||
background-color: inherit;
|
||||
}
|
||||
</style>
|
||||
18
src/composables/sidebarTabs/outputExplorerSidebarTab.ts
Normal file
18
src/composables/sidebarTabs/outputExplorerSidebarTab.ts
Normal file
@@ -0,0 +1,18 @@
|
||||
import { markRaw } from 'vue'
|
||||
import { useI18n } from 'vue-i18n'
|
||||
|
||||
import OutputExplorerSidebarTab from '@/components/sidebar/tabs/OutputExplorerSidebarTab.vue'
|
||||
import type { SidebarTabExtension } from '@/types/extensionTypes'
|
||||
|
||||
export const useOutputExplorerSidebarTab = (): SidebarTabExtension => {
|
||||
const { t } = useI18n()
|
||||
|
||||
return {
|
||||
id: 'output-explorer',
|
||||
icon: 'pi pi-image',
|
||||
title: t('sideToolbar.outputExplorer'),
|
||||
tooltip: t('sideToolbar.outputExplorer'),
|
||||
component: markRaw(OutputExplorerSidebarTab),
|
||||
type: 'vue'
|
||||
}
|
||||
}
|
||||
@@ -54,6 +54,12 @@ export const CORE_KEYBINDINGS: Keybinding[] = [
|
||||
},
|
||||
commandId: 'Workspace.ToggleSidebarTab.model-library'
|
||||
},
|
||||
{
|
||||
combo: {
|
||||
key: 'e'
|
||||
},
|
||||
commandId: 'Workspace.ToggleSidebarTab.output-explorer'
|
||||
},
|
||||
{
|
||||
combo: {
|
||||
key: 's',
|
||||
|
||||
@@ -277,6 +277,10 @@
|
||||
"label": "تبديل الشريط الجانبي لمكتبة العقد",
|
||||
"tooltip": "مكتبة العقد"
|
||||
},
|
||||
"Workspace_ToggleSidebarTab_output-explorer": {
|
||||
"label": "تبديل الشريط الجانبي لمستكشف النتائج",
|
||||
"tooltip": "مستكشف النتائج"
|
||||
},
|
||||
"Workspace_ToggleSidebarTab_queue": {
|
||||
"label": "تبديل الشريط الجانبي لقائمة الانتظار",
|
||||
"tooltip": "قائمة الانتظار"
|
||||
|
||||
File diff suppressed because it is too large
Load Diff
@@ -277,6 +277,10 @@
|
||||
"label": "Toggle Node Library Sidebar",
|
||||
"tooltip": "Node Library"
|
||||
},
|
||||
"Workspace_ToggleSidebarTab_output-explorer": {
|
||||
"label": "Toggle Output Explorer Sidebar",
|
||||
"tooltip": "Output Explorer"
|
||||
},
|
||||
"Workspace_ToggleSidebarTab_queue": {
|
||||
"label": "Toggle Queue Sidebar",
|
||||
"tooltip": "Queue"
|
||||
|
||||
@@ -146,7 +146,16 @@
|
||||
"micPermissionDenied": "Microphone permission denied",
|
||||
"noAudioRecorded": "No audio recorded",
|
||||
"nodesRunning": "nodes running",
|
||||
"duplicate": "Duplicate"
|
||||
"duplicate": "Duplicate",
|
||||
"audio": "Audio",
|
||||
"folder": "Folder",
|
||||
"image": "Image",
|
||||
"itemsCount": "{0} Items",
|
||||
"modifyTime": "Modify Time",
|
||||
"searchIn": "Search in {0}",
|
||||
"size": "Size",
|
||||
"type": "Type",
|
||||
"video": "Video"
|
||||
},
|
||||
"manager": {
|
||||
"title": "Custom Nodes Manager",
|
||||
@@ -497,7 +506,8 @@
|
||||
"bookmarks": "Bookmarks",
|
||||
"open": "Open"
|
||||
}
|
||||
}
|
||||
},
|
||||
"outputExplorer": "Output Explorer"
|
||||
},
|
||||
"helpCenter": {
|
||||
"docs": "Docs",
|
||||
@@ -1036,6 +1046,7 @@
|
||||
"Focus Mode": "Focus Mode",
|
||||
"Model Library": "Model Library",
|
||||
"Node Library": "Node Library",
|
||||
"Output Explorer": "Output Explorer",
|
||||
"Queue Panel": "Queue Panel",
|
||||
"Workflows": "Workflows"
|
||||
},
|
||||
|
||||
@@ -277,6 +277,10 @@
|
||||
"label": "Alternar Barra Lateral de Biblioteca de Nodos",
|
||||
"tooltip": "Biblioteca de Nodos"
|
||||
},
|
||||
"Workspace_ToggleSidebarTab_output-explorer": {
|
||||
"label": "Alternar barra lateral del Explorador de Salidas",
|
||||
"tooltip": "Explorador de Salidas"
|
||||
},
|
||||
"Workspace_ToggleSidebarTab_queue": {
|
||||
"label": "Alternar Barra Lateral de Cola",
|
||||
"tooltip": "Cola"
|
||||
|
||||
@@ -1,12 +1,12 @@
|
||||
{
|
||||
"apiNodesCostBreakdown": {
|
||||
"costPerRun": "Costo por ejecución",
|
||||
"title": "Nodo(s) de API",
|
||||
"title": "Nodo(s) API",
|
||||
"totalCost": "Costo total"
|
||||
},
|
||||
"apiNodesSignInDialog": {
|
||||
"message": "Este flujo de trabajo contiene nodos de API, que requieren que inicies sesión en tu cuenta para poder ejecutar.",
|
||||
"title": "Se requiere iniciar sesión para usar los nodos de API"
|
||||
"message": "Este flujo de trabajo contiene nodos API, que requieren que inicies sesión en tu cuenta para ejecutarse.",
|
||||
"title": "Inicio de sesión requerido para usar nodos API"
|
||||
},
|
||||
"auth": {
|
||||
"apiKey": {
|
||||
@@ -86,7 +86,7 @@
|
||||
"clearWorkflow": "Limpiar flujo de trabajo",
|
||||
"deleteWorkflow": "Eliminar flujo de trabajo",
|
||||
"duplicate": "Duplicar",
|
||||
"enterNewName": "Ingrese un nuevo nombre"
|
||||
"enterNewName": "Introduce un nuevo nombre"
|
||||
},
|
||||
"chatHistory": {
|
||||
"cancelEdit": "Cancelar",
|
||||
@@ -97,7 +97,7 @@
|
||||
},
|
||||
"clipboard": {
|
||||
"errorMessage": "Error al copiar al portapapeles",
|
||||
"errorNotSupported": "API del portapapeles no soportada en su navegador",
|
||||
"errorNotSupported": "La API del portapapeles no es compatible con tu navegador",
|
||||
"successMessage": "Copiado al portapapeles"
|
||||
},
|
||||
"color": {
|
||||
@@ -108,54 +108,54 @@
|
||||
"cyan": "Cian",
|
||||
"default": "Predeterminado",
|
||||
"green": "Verde",
|
||||
"noColor": "Sin Color",
|
||||
"pale_blue": "Azul Pálido",
|
||||
"noColor": "Sin color",
|
||||
"pale_blue": "Azul pálido",
|
||||
"pink": "Rosa",
|
||||
"purple": "Morado",
|
||||
"purple": "Púrpura",
|
||||
"red": "Rojo",
|
||||
"yellow": "Amarillo"
|
||||
},
|
||||
"contextMenu": {
|
||||
"Add Group": "Agregar Grupo",
|
||||
"Add Group For Selected Nodes": "Agregar Grupo para Nodos Seleccionados",
|
||||
"Add Node": "Agregar Nodo",
|
||||
"Add Group": "Agregar grupo",
|
||||
"Add Group For Selected Nodes": "Agregar grupo para los nodos seleccionados",
|
||||
"Add Node": "Agregar nodo",
|
||||
"Bypass": "Omitir",
|
||||
"Clone": "Clonar",
|
||||
"Collapse": "Colapsar",
|
||||
"Colors": "Colores",
|
||||
"Convert to Group Node": "Convertir en Nodo de Grupo",
|
||||
"Copy (Clipspace)": "Copiar (Espacio de Clip)",
|
||||
"Convert to Group Node": "Convertir en nodo de grupo",
|
||||
"Copy (Clipspace)": "Copiar (Clipspace)",
|
||||
"Expand": "Expandir",
|
||||
"Inputs": "Entradas",
|
||||
"Manage": "Administrar",
|
||||
"Manage Group Nodes": "Administrar Nodos de Grupo",
|
||||
"Manage": "Gestionar",
|
||||
"Manage Group Nodes": "Gestionar nodos de grupo",
|
||||
"Mode": "Modo",
|
||||
"Node Templates": "Plantillas de Nodos",
|
||||
"Node Templates": "Plantillas de nodo",
|
||||
"Outputs": "Salidas",
|
||||
"Pin": "Anclar",
|
||||
"Pin": "Fijar",
|
||||
"Properties": "Propiedades",
|
||||
"Properties Panel": "Panel de Propiedades",
|
||||
"Properties Panel": "Panel de propiedades",
|
||||
"Remove": "Eliminar",
|
||||
"Resize": "Redimensionar",
|
||||
"Save Selected as Template": "Guardar Seleccionado como Plantilla",
|
||||
"Save Selected as Template": "Guardar selección como plantilla",
|
||||
"Search": "Buscar",
|
||||
"Shapes": "Formas",
|
||||
"Title": "Título",
|
||||
"Unpin": "Desanclar"
|
||||
"Unpin": "Desfijar"
|
||||
},
|
||||
"credits": {
|
||||
"accountInitialized": "Cuenta inicializada",
|
||||
"activity": "Actividad",
|
||||
"added": "Añadido",
|
||||
"additionalInfo": "Información adicional",
|
||||
"apiPricing": "Precios de la API",
|
||||
"apiPricing": "Precios de API",
|
||||
"credits": "Créditos",
|
||||
"details": "Detalles",
|
||||
"eventType": "Tipo de evento",
|
||||
"faqs": "Preguntas frecuentes",
|
||||
"invoiceHistory": "Historial de facturas",
|
||||
"lastUpdated": "Última actualización",
|
||||
"messageSupport": "Contactar soporte",
|
||||
"messageSupport": "Soporte por mensaje",
|
||||
"model": "Modelo",
|
||||
"purchaseCredits": "Comprar créditos",
|
||||
"time": "Hora",
|
||||
@@ -214,7 +214,7 @@
|
||||
"UPSCALE_MODEL": "MODELO_DE_ESCALADO",
|
||||
"VAE": "VAE",
|
||||
"VIDEO": "VÍDEO",
|
||||
"VOXEL": "VOXEL",
|
||||
"VOXEL": "VÓXEL",
|
||||
"WEBCAM": "WEBCAM"
|
||||
},
|
||||
"desktopMenu": {
|
||||
@@ -228,7 +228,7 @@
|
||||
"errorCheckingUpdate": "Error al buscar actualizaciones",
|
||||
"errorInstallingUpdate": "Error al instalar la actualización",
|
||||
"noUpdateFound": "No se encontró ninguna actualización",
|
||||
"terminalDefaultMessage": "Cualquier salida de consola de la actualización se mostrará aquí.",
|
||||
"terminalDefaultMessage": "Cualquier salida de la consola de la actualización se mostrará aquí.",
|
||||
"title": "Actualizando ComfyUI Desktop",
|
||||
"updateAvailableMessage": "Hay una actualización disponible. ¿Quieres reiniciar y actualizar ahora?",
|
||||
"updateFoundTitle": "Actualización encontrada (v{version})"
|
||||
@@ -252,8 +252,8 @@
|
||||
"errorDialog": {
|
||||
"defaultTitle": "Ocurrió un error",
|
||||
"extensionFileHint": "Esto puede deberse al siguiente script",
|
||||
"loadWorkflowTitle": "La carga se interrumpió debido a un error al recargar los datos del flujo de trabajo",
|
||||
"noStackTrace": "No hay seguimiento de pila disponible",
|
||||
"loadWorkflowTitle": "Carga abortada debido a un error al recargar los datos del flujo de trabajo",
|
||||
"noStackTrace": "No hay traza de pila disponible",
|
||||
"promptExecutionError": "La ejecución del prompt falló"
|
||||
},
|
||||
"g": {
|
||||
@@ -264,13 +264,14 @@
|
||||
"amount": "Cantidad",
|
||||
"apply": "Aplicar",
|
||||
"architecture": "Arquitectura",
|
||||
"audio": "Audio",
|
||||
"audioFailedToLoad": "No se pudo cargar el audio",
|
||||
"author": "Autor",
|
||||
"back": "Atrás",
|
||||
"cancel": "Cancelar",
|
||||
"capture": "captura",
|
||||
"capture": "capturar",
|
||||
"category": "Categoría",
|
||||
"choose_file_to_upload": "elige archivo para subir",
|
||||
"choose_file_to_upload": "elige un archivo para subir",
|
||||
"clear": "Limpiar",
|
||||
"clearFilters": "Borrar filtros",
|
||||
"close": "Cerrar",
|
||||
@@ -282,8 +283,8 @@
|
||||
"confirm": "Confirmar",
|
||||
"confirmed": "Confirmado",
|
||||
"continue": "Continuar",
|
||||
"control_after_generate": "control después de generar",
|
||||
"control_before_generate": "control antes de generar",
|
||||
"control_after_generate": "controlar después de generar",
|
||||
"control_before_generate": "controlar antes de generar",
|
||||
"copy": "Copiar",
|
||||
"copyToClipboard": "Copiar al portapapeles",
|
||||
"copyURL": "Copiar URL",
|
||||
@@ -313,11 +314,13 @@
|
||||
"filter": "Filtrar",
|
||||
"findIssues": "Encontrar problemas",
|
||||
"firstTimeUIMessage": "Esta es la primera vez que usas la nueva interfaz. Elige \"Menú > Usar nuevo menú > Desactivado\" para restaurar la antigua interfaz.",
|
||||
"folder": "Carpeta",
|
||||
"frontendNewer": "La versión del frontend {frontendVersion} puede no ser compatible con la versión del backend {backendVersion}.",
|
||||
"frontendOutdated": "La versión del frontend {frontendVersion} está desactualizada. El backend requiere la versión {requiredVersion} o superior.",
|
||||
"frontendOutdated": "La versión del frontend {frontendVersion} está desactualizada. El backend requiere {requiredVersion} o superior.",
|
||||
"goToNode": "Ir al nodo",
|
||||
"help": "Ayuda",
|
||||
"icon": "Icono",
|
||||
"image": "Imagen",
|
||||
"imageFailedToLoad": "Falló la carga de la imagen",
|
||||
"imageUrl": "URL de la imagen",
|
||||
"import": "Importar",
|
||||
@@ -327,18 +330,20 @@
|
||||
"installed": "Instalado",
|
||||
"installing": "Instalando",
|
||||
"interrupted": "Interrumpido",
|
||||
"itemsCount": "{0} elementos",
|
||||
"keybinding": "Combinación de teclas",
|
||||
"keybindingAlreadyExists": "La combinación de teclas ya existe en",
|
||||
"learnMore": "Aprende más",
|
||||
"learnMore": "Saber más",
|
||||
"loadAllFolders": "Cargar todas las carpetas",
|
||||
"loadWorkflow": "Cargar flujo de trabajo",
|
||||
"loading": "Cargando",
|
||||
"loadingPanel": "Cargando panel {panel}...",
|
||||
"loadingPanel": "Cargando panel de {panel}...",
|
||||
"login": "Iniciar sesión",
|
||||
"logs": "Registros",
|
||||
"micPermissionDenied": "Permiso de micrófono denegado",
|
||||
"migrate": "Migrar",
|
||||
"missing": "Faltante",
|
||||
"modifyTime": "Hora de modificación",
|
||||
"name": "Nombre",
|
||||
"newFolder": "Nueva carpeta",
|
||||
"next": "Siguiente",
|
||||
@@ -366,13 +371,14 @@
|
||||
"reportSent": "Informe enviado",
|
||||
"reset": "Reiniciar",
|
||||
"resetAll": "Restablecer todo",
|
||||
"resetAllKeybindingsTooltip": "Restablecer todas las teclas de acceso rápido a la configuración predeterminada",
|
||||
"resetAllKeybindingsTooltip": "Restablecer todas las combinaciones de teclas a los valores predeterminados",
|
||||
"restart": "Reiniciar",
|
||||
"resultsCount": "Encontrados {count} resultados",
|
||||
"resultsCount": "{count} resultados encontrados",
|
||||
"save": "Guardar",
|
||||
"saving": "Guardando",
|
||||
"searchExtensions": "Buscar extensiones",
|
||||
"searchFailedMessage": "No pudimos encontrar ninguna configuración que coincida con tu búsqueda. Intenta ajustar tus términos de búsqueda.",
|
||||
"searchIn": "Buscar en {0}",
|
||||
"searchKeybindings": "Buscar combinaciones de teclas",
|
||||
"searchModels": "Buscar modelos",
|
||||
"searchNodes": "Buscar nodos",
|
||||
@@ -381,9 +387,10 @@
|
||||
"setAsBackground": "Establecer como fondo",
|
||||
"settings": "Configuraciones",
|
||||
"showReport": "Mostrar informe",
|
||||
"size": "Tamaño",
|
||||
"sort": "Ordenar",
|
||||
"source": "Fuente",
|
||||
"startRecording": "Iniciar grabación",
|
||||
"startRecording": "Comenzar grabación",
|
||||
"status": "Estado",
|
||||
"stopRecording": "Detener grabación",
|
||||
"success": "Éxito",
|
||||
@@ -391,9 +398,10 @@
|
||||
"terminal": "Terminal",
|
||||
"title": "Título",
|
||||
"triggerPhrase": "Frase de activación",
|
||||
"type": "Tipo",
|
||||
"unknownError": "Error desconocido",
|
||||
"update": "Actualizar",
|
||||
"updateAvailable": "Actualización Disponible",
|
||||
"updateAvailable": "Actualización disponible",
|
||||
"updateFrontend": "Actualizar frontend",
|
||||
"updated": "Actualizado",
|
||||
"updating": "Actualizando",
|
||||
@@ -401,7 +409,8 @@
|
||||
"usageHint": "Sugerencia de uso",
|
||||
"user": "Usuario",
|
||||
"versionMismatchWarning": "Advertencia de compatibilidad de versión",
|
||||
"versionMismatchWarningMessage": "{warning}: {detail} Visita https://docs.comfy.org/installation/update_comfyui#common-update-issues para obtener instrucciones de actualización.",
|
||||
"versionMismatchWarningMessage": "{warning}: {detail} Visita https://docs.comfy.org/installation/update_comfyui#common-update-issues para instrucciones de actualización.",
|
||||
"video": "Video",
|
||||
"videoFailedToLoad": "Falló la carga del video",
|
||||
"workflow": "Flujo de trabajo"
|
||||
},
|
||||
@@ -476,7 +485,7 @@
|
||||
"installLocationDescription": "Selecciona el directorio para los datos de usuario de ComfyUI. Un entorno de python será instalado en la ubicación seleccionada.",
|
||||
"installLocationTooltip": "Directorio de datos de usuario de ComfyUI. Almacena:\n- Entorno Python\n- Modelos\n- Nodos personalizados\n",
|
||||
"insufficientFreeSpace": "Espacio insuficiente - espacio libre mínimo",
|
||||
"isOneDrive": "OneDrive no es compatible. Por favor instala ComfyUI en otra ubicación.",
|
||||
"isOneDrive": "OneDrive no es compatible. Por favor, instala ComfyUI en otra ubicación.",
|
||||
"manualConfiguration": {
|
||||
"createVenv": "Necesitarás crear un entorno virtual en el siguiente directorio",
|
||||
"requirements": "Requisitos",
|
||||
@@ -491,7 +500,7 @@
|
||||
"migrationOptional": "La migración es opcional. Si no tienes una instalación existente, puedes saltarte este paso.",
|
||||
"migrationSourcePathDescription": "Si tienes una instalación existente de ComfyUI, podemos copiar/enlazar tus archivos de usuario existentes y modelos a la nueva instalación. Tu instalación existente de ComfyUI no será afectada.",
|
||||
"moreInfo": "Para más información, por favor lee nuestra",
|
||||
"nonDefaultDrive": "Por favor instala ComfyUI en tu unidad de sistema (ej. C:\\). Las unidades con diferentes sistemas de archivos pueden causar problemas impredecibles. Los modelos y otros archivos pueden ser almacenados en otras unidades después de la instalación.",
|
||||
"nonDefaultDrive": "Por favor, instala ComfyUI en el disco del sistema (por ejemplo, C:\\). Unidades con diferentes sistemas de archivos pueden causar problemas impredecibles. Los modelos y otros archivos pueden almacenarse en otras unidades después de la instalación.",
|
||||
"parentMissing": "La ruta no existe - crea el directorio contenedor primero",
|
||||
"pathExists": "El directorio ya existe - por favor asegúrate de haber respaldado todos los datos",
|
||||
"pathValidationFailed": "Falló la validación de la ruta",
|
||||
@@ -502,7 +511,7 @@
|
||||
"allowMetricsDescription": "Ayuda a mejorar ComfyUI enviando métricas de uso anónimas. No se recogerá ninguna información personal o contenido de flujo de trabajo.",
|
||||
"autoUpdate": "Actualizaciones Automáticas",
|
||||
"autoUpdateDescription": "Descarga automáticamente las actualizaciones cuando estén disponibles. Se te notificará antes de que las actualizaciones sean instaladas.",
|
||||
"checkingMirrors": "Comprobando el acceso a la red a los espejos de python...",
|
||||
"checkingMirrors": "Comprobando el acceso a la red de los mirrors de Python...",
|
||||
"dataCollectionDialog": {
|
||||
"collect": {
|
||||
"errorReports": "Mensaje de error y rastreo de pila",
|
||||
@@ -523,11 +532,11 @@
|
||||
"errorUpdatingConsent": "Error Actualizando Consentimiento",
|
||||
"errorUpdatingConsentDetail": "Falló al actualizar la configuración de consentimiento de métricas",
|
||||
"learnMoreAboutData": "Aprende más sobre la recolección de datos",
|
||||
"mirrorSettings": "Configuraciones de Espejo",
|
||||
"mirrorsReachable": "El acceso a la red a los espejos de python es bueno",
|
||||
"mirrorsUnreachable": "El acceso a la red a algunos espejos de python es malo",
|
||||
"pypiMirrorPlaceholder": "Ingresa la URL del espejo de PyPI",
|
||||
"pythonMirrorPlaceholder": "Ingresa la URL del espejo de Python"
|
||||
"mirrorSettings": "Configuración de mirrors",
|
||||
"mirrorsReachable": "El acceso a la red de los mirrors de Python es bueno",
|
||||
"mirrorsUnreachable": "El acceso a la red de algunos mirrors de Python es deficiente",
|
||||
"pypiMirrorPlaceholder": "Introduce la URL del mirror de PyPI",
|
||||
"pythonMirrorPlaceholder": "Introduce la URL del mirror de Python"
|
||||
},
|
||||
"systemLocations": "Ubicaciones del Sistema",
|
||||
"unhandledError": "Error desconocido",
|
||||
@@ -537,7 +546,7 @@
|
||||
"contactFollowUp": "Contáctame para seguimiento",
|
||||
"contactSupportDescription": "Por favor, complete el siguiente formulario con su reporte",
|
||||
"contactSupportTitle": "Contactar Soporte",
|
||||
"describeTheProblem": "Describa el problema",
|
||||
"describeTheProblem": "Describe el problema",
|
||||
"email": "Correo electrónico",
|
||||
"feedbackTitle": "Ayúdanos a mejorar ComfyUI proporcionando comentarios",
|
||||
"helpFix": "Ayuda a Solucionar Esto",
|
||||
@@ -546,25 +555,25 @@
|
||||
"bugReport": "Reporte de error",
|
||||
"giveFeedback": "Enviar comentarios",
|
||||
"loginAccessIssues": "Problemas de inicio de sesión / acceso",
|
||||
"somethingElse": "Otro"
|
||||
"somethingElse": "Otra cosa"
|
||||
},
|
||||
"notifyResolve": "Notifícame cuando se resuelva",
|
||||
"provideAdditionalDetails": "Proporciona detalles adicionales (opcional)",
|
||||
"provideEmail": "Danos tu correo electrónico (opcional)",
|
||||
"rating": "Calificación",
|
||||
"selectIssue": "Seleccione el problema",
|
||||
"selectIssue": "Selecciona el problema",
|
||||
"stackTrace": "Rastreo de Pila",
|
||||
"submitErrorReport": "Enviar Reporte de Error (Opcional)",
|
||||
"systemStats": "Estadísticas del Sistema",
|
||||
"validation": {
|
||||
"descriptionRequired": "Se requiere una descripción",
|
||||
"helpTypeRequired": "Se requiere el tipo de ayuda",
|
||||
"descriptionRequired": "La descripción es obligatoria",
|
||||
"helpTypeRequired": "El tipo de ayuda es obligatorio",
|
||||
"invalidEmail": "Por favor ingresa una dirección de correo electrónico válida",
|
||||
"maxLength": "Mensaje demasiado largo",
|
||||
"selectIssueType": "Por favor, seleccione un tipo de problema"
|
||||
"selectIssueType": "Por favor, selecciona un tipo de problema"
|
||||
},
|
||||
"whatCanWeInclude": "Especifique qué incluir en el reporte",
|
||||
"whatDoYouNeedHelpWith": "¿Con qué necesita ayuda?"
|
||||
"whatCanWeInclude": "Especifica qué incluir en el reporte",
|
||||
"whatDoYouNeedHelpWith": "¿Con qué necesitas ayuda?"
|
||||
},
|
||||
"load3d": {
|
||||
"applyingTexture": "Aplicando textura...",
|
||||
@@ -582,7 +591,7 @@
|
||||
"exportingModel": "Exportando modelo...",
|
||||
"fov": "FOV",
|
||||
"light": "Luz",
|
||||
"lightIntensity": "Intensidad de luz",
|
||||
"lightIntensity": "Intensidad de la luz",
|
||||
"loadingBackgroundImage": "Cargando imagen de fondo",
|
||||
"loadingModel": "Cargando modelo 3D...",
|
||||
"materialMode": "Modo de material",
|
||||
@@ -591,10 +600,10 @@
|
||||
"lineart": "Dibujo lineal",
|
||||
"normal": "Normal",
|
||||
"original": "Original",
|
||||
"wireframe": "Malla"
|
||||
"wireframe": "Alámbrico"
|
||||
},
|
||||
"model": "Modelo",
|
||||
"openIn3DViewer": "Abrir en el visor 3D",
|
||||
"openIn3DViewer": "Abrir en visor 3D",
|
||||
"previewOutput": "Vista previa de salida",
|
||||
"removeBackgroundImage": "Eliminar imagen de fondo",
|
||||
"resizeNodeMatchOutput": "Redimensionar nodo para coincidir con la salida",
|
||||
@@ -604,7 +613,7 @@
|
||||
"stopRecording": "Detener grabación",
|
||||
"switchCamera": "Cambiar cámara",
|
||||
"switchingMaterialMode": "Cambiando modo de material...",
|
||||
"upDirection": "Dirección hacia arriba",
|
||||
"upDirection": "Dirección superior",
|
||||
"upDirections": {
|
||||
"original": "Original"
|
||||
},
|
||||
@@ -633,13 +642,13 @@
|
||||
"Skipped": "Omitido",
|
||||
"allOk": "No se detectaron problemas.",
|
||||
"confirmTitle": "¿Estás seguro?",
|
||||
"consoleLogs": "Registros de la consola",
|
||||
"consoleLogs": "Registros de consola",
|
||||
"detected": "Detectado",
|
||||
"error": {
|
||||
"cannotContinue": "No se puede continuar - quedan errores",
|
||||
"defaultDescription": "Ocurrió un error mientras se ejecutaba una tarea de mantenimiento.",
|
||||
"taskFailed": "La tarea falló al ejecutarse.",
|
||||
"toastTitle": "Error de tarea"
|
||||
"cannotContinue": "No se puede continuar: quedan errores",
|
||||
"defaultDescription": "Ocurrió un error al ejecutar una tarea de mantenimiento.",
|
||||
"taskFailed": "La tarea no se pudo ejecutar.",
|
||||
"toastTitle": "Error en la tarea"
|
||||
},
|
||||
"refreshing": "Actualizando",
|
||||
"showManual": "Mostrar tareas de mantenimiento",
|
||||
@@ -648,43 +657,43 @@
|
||||
"title": "Mantenimiento"
|
||||
},
|
||||
"manager": {
|
||||
"changingVersion": "Cambiando versión de {from} a {to}",
|
||||
"createdBy": "Creado Por",
|
||||
"changingVersion": "Cambiando la versión de {from} a {to}",
|
||||
"createdBy": "Creado por",
|
||||
"dependencies": "Dependencias",
|
||||
"discoverCommunityContent": "Descubre paquetes de nodos, extensiones y más creados por la comunidad...",
|
||||
"downloads": "Descargas",
|
||||
"errorConnecting": "Error al conectar con el Registro de Nodos Comfy.",
|
||||
"failed": "Falló ({count})",
|
||||
"errorConnecting": "Error al conectar con el Registro de Nodos de Comfy.",
|
||||
"failed": "Fallido ({count})",
|
||||
"filter": {
|
||||
"disabled": "Deshabilitado",
|
||||
"enabled": "Habilitado",
|
||||
"nodePack": "Paquete de Nodos"
|
||||
},
|
||||
"inWorkflow": "En Flujo de Trabajo",
|
||||
"inWorkflow": "En el flujo de trabajo",
|
||||
"infoPanelEmpty": "Haz clic en un elemento para ver la información",
|
||||
"installAllMissingNodes": "Instalar todos los nodos faltantes",
|
||||
"installSelected": "Instalar Seleccionado",
|
||||
"installSelected": "Instalar seleccionados",
|
||||
"installationQueue": "Cola de Instalación",
|
||||
"lastUpdated": "Última Actualización",
|
||||
"lastUpdated": "Última actualización",
|
||||
"latestVersion": "Última",
|
||||
"license": "Licencia",
|
||||
"loadingVersions": "Cargando versiones...",
|
||||
"nightlyVersion": "Nocturna",
|
||||
"noDescription": "No hay descripción disponible",
|
||||
"noNodesFound": "No se encontraron nodos",
|
||||
"noNodesFoundDescription": "Los nodos del paquete no se pudieron analizar, o el paquete es solo una extensión de frontend y no tiene ningún nodo.",
|
||||
"noNodesFoundDescription": "Los nodos del paquete no se pudieron analizar, o el paquete es solo una extensión de frontend y no tiene nodos.",
|
||||
"noResultsFound": "No se encontraron resultados que coincidan con tu búsqueda.",
|
||||
"nodePack": "Paquete de Nodos",
|
||||
"packsSelected": "Paquetes Seleccionados",
|
||||
"packsSelected": "Paquetes seleccionados",
|
||||
"repository": "Repositorio",
|
||||
"restartToApplyChanges": "Para aplicar los cambios, por favor reinicia ComfyUI",
|
||||
"restartToApplyChanges": "Para aplicar los cambios, reinicia ComfyUI",
|
||||
"searchPlaceholder": "Buscar",
|
||||
"selectVersion": "Seleccionar Versión",
|
||||
"selectVersion": "Seleccionar versión",
|
||||
"sort": {
|
||||
"created": "Más reciente",
|
||||
"downloads": "Más Popular",
|
||||
"created": "Más nuevos",
|
||||
"downloads": "Más populares",
|
||||
"publisher": "Editor",
|
||||
"updated": "Actualizado recientemente"
|
||||
"updated": "Actualizados recientemente"
|
||||
},
|
||||
"status": {
|
||||
"active": "Activo",
|
||||
@@ -695,11 +704,11 @@
|
||||
"unknown": "Desconocido"
|
||||
},
|
||||
"title": "Administrador de Nodos Personalizados",
|
||||
"totalNodes": "Total de Nodos",
|
||||
"tryAgainLater": "Por favor intenta de nuevo más tarde.",
|
||||
"tryDifferentSearch": "Por favor intenta con una consulta de búsqueda diferente.",
|
||||
"totalNodes": "Nodos totales",
|
||||
"tryAgainLater": "Por favor, inténtalo de nuevo más tarde.",
|
||||
"tryDifferentSearch": "Por favor, prueba con otra consulta de búsqueda.",
|
||||
"uninstall": "Desinstalar",
|
||||
"uninstallSelected": "Desinstalar Seleccionado",
|
||||
"uninstallSelected": "Desinstalar seleccionados",
|
||||
"uninstalling": "Desinstalando",
|
||||
"update": "Actualizar",
|
||||
"updatingAllPacks": "Actualizando todos los paquetes",
|
||||
@@ -707,9 +716,9 @@
|
||||
},
|
||||
"maskEditor": {
|
||||
"Apply to Whole Image": "Aplicar a toda la imagen",
|
||||
"Brush Settings": "Configuración de pincel",
|
||||
"Brush Shape": "Forma de pincel",
|
||||
"Clear": "Borrar",
|
||||
"Brush Settings": "Configuración del pincel",
|
||||
"Brush Shape": "Forma del pincel",
|
||||
"Clear": "Limpiar",
|
||||
"Color Select Settings": "Configuración de selección de color",
|
||||
"Fill Opacity": "Opacidad de relleno",
|
||||
"Hardness": "Dureza",
|
||||
@@ -722,11 +731,11 @@
|
||||
"Mask Tolerance": "Tolerancia de máscara",
|
||||
"Method": "Método",
|
||||
"Opacity": "Opacidad",
|
||||
"Paint Bucket Settings": "Configuración de cubo de pintura",
|
||||
"Paint Bucket Settings": "Configuración del bote de pintura",
|
||||
"Reset to Default": "Restablecer a predeterminado",
|
||||
"Selection Opacity": "Opacidad de selección",
|
||||
"Smoothing Precision": "Precisión de suavizado",
|
||||
"Stop at mask": "Detener en máscara",
|
||||
"Stop at mask": "Detener en la máscara",
|
||||
"Thickness": "Grosor",
|
||||
"Tolerance": "Tolerancia"
|
||||
},
|
||||
@@ -753,8 +762,8 @@
|
||||
"refresh": "Actualizar definiciones de nodos",
|
||||
"resetView": "Restablecer vista del lienzo",
|
||||
"run": "Ejecutar",
|
||||
"runWorkflow": "Ejecutar flujo de trabajo (Shift para encolar al frente)",
|
||||
"runWorkflowFront": "Ejecutar flujo de trabajo (Encolar al frente)",
|
||||
"runWorkflow": "Ejecutar flujo de trabajo (Shift para poner al frente de la cola)",
|
||||
"runWorkflowFront": "Ejecutar flujo de trabajo (Poner al frente de la cola)",
|
||||
"settings": "Configuración",
|
||||
"showMenu": "Mostrar menú",
|
||||
"theme": "Tema",
|
||||
@@ -823,6 +832,7 @@
|
||||
"Open Outputs Folder": "Abrir carpeta de salidas",
|
||||
"Open Sign In Dialog": "Abrir diálogo de inicio de sesión",
|
||||
"Open extra_model_paths_yaml": "Abrir extra_model_paths.yaml",
|
||||
"Output Explorer": "Explorador de salidas",
|
||||
"Pin/Unpin Selected Items": "Anclar/Desanclar elementos seleccionados",
|
||||
"Pin/Unpin Selected Nodes": "Anclar/Desanclar nodos seleccionados",
|
||||
"Previous Opened Workflow": "Flujo de trabajo abierto anterior",
|
||||
@@ -902,7 +912,7 @@
|
||||
"controlnet": "controlnet",
|
||||
"create": "crear",
|
||||
"custom_sampling": "muestreo_personalizado",
|
||||
"debug": "depurar",
|
||||
"debug": "depuración",
|
||||
"deprecated": "obsoleto",
|
||||
"flux": "flux",
|
||||
"gligen": "gligen",
|
||||
@@ -1188,7 +1198,7 @@
|
||||
"essentials": "Esenciales",
|
||||
"keyboardShortcuts": "Atajos de teclado",
|
||||
"manageShortcuts": "Gestionar atajos",
|
||||
"noKeybinding": "Sin asignación de tecla",
|
||||
"noKeybinding": "Sin combinación de teclas",
|
||||
"subcategories": {
|
||||
"node": "Nodo",
|
||||
"panelControls": "Controles del panel",
|
||||
@@ -1221,9 +1231,9 @@
|
||||
"module": "Módulo",
|
||||
"moduleDesc": "Agrupar por fuente del módulo",
|
||||
"source": "Fuente",
|
||||
"sourceDesc": "Agrupar por tipo de fuente (Core, Custom, API)"
|
||||
"sourceDesc": "Agrupar por tipo de fuente (Core, Personalizado, API)"
|
||||
},
|
||||
"resetView": "Restablecer vista a la predeterminada",
|
||||
"resetView": "Restablecer vista por defecto",
|
||||
"sortBy": {
|
||||
"alphabetical": "Alfabético",
|
||||
"alphabeticalDesc": "Ordenar alfabéticamente dentro de los grupos",
|
||||
@@ -1233,6 +1243,7 @@
|
||||
"sortMode": "Modo de ordenación"
|
||||
},
|
||||
"openWorkflow": "Abrir flujo de trabajo en el sistema de archivos local",
|
||||
"outputExplorer": "Explorador de salidas",
|
||||
"queue": "Cola",
|
||||
"queueTab": {
|
||||
"backToAllTasks": "Volver a todas las tareas",
|
||||
@@ -1256,7 +1267,7 @@
|
||||
"deleteFailedTitle": "Eliminación fallida",
|
||||
"deleted": "Flujo de trabajo eliminado",
|
||||
"dirtyClose": "Los archivos a continuación han sido modificados. ¿Te gustaría guardarlos antes de cerrar?",
|
||||
"dirtyCloseHint": "Mantén presionada la tecla Shift para cerrar sin preguntar",
|
||||
"dirtyCloseHint": "Mantén presionada la tecla Shift para cerrar sin aviso",
|
||||
"dirtyCloseTitle": "¿Guardar cambios?",
|
||||
"workflowTreeType": {
|
||||
"bookmarks": "Marcadores",
|
||||
@@ -1278,7 +1289,7 @@
|
||||
"templateWorkflows": {
|
||||
"category": {
|
||||
"3D": "3D",
|
||||
"All": "Todas las plantillas",
|
||||
"All": "Todas las Plantillas",
|
||||
"Area Composition": "Composición de Área",
|
||||
"Audio": "Audio",
|
||||
"Basics": "Básicos",
|
||||
@@ -1289,7 +1300,7 @@
|
||||
"Image": "Imagen",
|
||||
"Image API": "API de Imagen",
|
||||
"LLM API": "API LLM",
|
||||
"Upscaling": "Ampliación",
|
||||
"Upscaling": "Escalado",
|
||||
"Video": "Video",
|
||||
"Video API": "API de Video"
|
||||
},
|
||||
@@ -1300,7 +1311,7 @@
|
||||
"3d_hunyuan3d_image_to_model": "Hunyuan3D 2.0",
|
||||
"3d_hunyuan3d_multiview_to_model": "Hunyuan3D 2.0 MV",
|
||||
"3d_hunyuan3d_multiview_to_model_turbo": "Hunyuan3D 2.0 MV Turbo",
|
||||
"stable_zero123_example": "Estable Zero123"
|
||||
"stable_zero123_example": "Stable Zero123"
|
||||
},
|
||||
"3D API": {
|
||||
"api_rodin_image_to_model": "Rodin: Imagen a Modelo",
|
||||
@@ -1314,15 +1325,15 @@
|
||||
"area_composition_square_area_for_subject": "Composición de Área Cuadrada para el Sujeto"
|
||||
},
|
||||
"Audio": {
|
||||
"audio_ace_step_1_m2m_editing": "ACE Step v1 Edición M2M",
|
||||
"audio_ace_step_1_m2m_editing": "ACE Step v1 M2M Edición",
|
||||
"audio_ace_step_1_t2a_instrumentals": "ACE-Step v1 Texto a Música Instrumental",
|
||||
"audio_ace_step_1_t2a_song": "ACE Step v1 Texto a Canción",
|
||||
"audio_stable_audio_example": "Stable Audio"
|
||||
},
|
||||
"Basics": {
|
||||
"default": "Generación de Imagen",
|
||||
"embedding_example": "Incrustación",
|
||||
"gligen_textbox_example": "Caja de Texto Gligen",
|
||||
"default": "Generación de Imágenes",
|
||||
"embedding_example": "Embedding",
|
||||
"gligen_textbox_example": "Gligen Textbox",
|
||||
"image2image": "Imagen a Imagen",
|
||||
"inpaint_example": "Inpaint",
|
||||
"inpaint_model_outpainting": "Outpaint",
|
||||
@@ -1330,42 +1341,42 @@
|
||||
"lora_multiple": "LoRA Múltiple"
|
||||
},
|
||||
"ControlNet": {
|
||||
"2_pass_pose_worship": "ControlNet de Pose 2 Pasadas",
|
||||
"controlnet_example": "ControlNet de Garabato",
|
||||
"depth_controlnet": "ControlNet de Profundidad",
|
||||
"depth_t2i_adapter": "Adaptador de Profundidad T2I",
|
||||
"mixing_controlnets": "Mezcla de ControlNets"
|
||||
"2_pass_pose_worship": "Pose ControlNet 2 Pasos",
|
||||
"controlnet_example": "Scribble ControlNet",
|
||||
"depth_controlnet": "Depth ControlNet",
|
||||
"depth_t2i_adapter": "Depth T2I Adapter",
|
||||
"mixing_controlnets": "Mixing ControlNets"
|
||||
},
|
||||
"Flux": {
|
||||
"flux_canny_model_example": "Flux Canny Model",
|
||||
"flux_depth_lora_example": "Flux Depth LoRA",
|
||||
"flux_dev_checkpoint_example": "Flux Dev fp8",
|
||||
"flux_dev_full_text_to_image": "Flux Dev texto a imagen completo",
|
||||
"flux_dev_full_text_to_image": "Flux Dev full text to image",
|
||||
"flux_fill_inpaint_example": "Flux Inpaint",
|
||||
"flux_fill_outpaint_example": "Flux Outpaint",
|
||||
"flux_kontext_dev_basic": "Flux Kontext Dev (Básico)",
|
||||
"flux_kontext_dev_grouped": "Flux Kontext Dev (Agrupado)",
|
||||
"flux_redux_model_example": "Flux Redux Model",
|
||||
"flux_schnell": "Flux Schnell fp8",
|
||||
"flux_schnell_full_text_to_image": "Flux Schnell texto a imagen completo"
|
||||
"flux_schnell_full_text_to_image": "Flux Schnell full text to image"
|
||||
},
|
||||
"Image": {
|
||||
"hidream_e1_full": "HiDream E1 Completo",
|
||||
"hidream_e1_full": "HiDream E1 Full",
|
||||
"hidream_i1_dev": "HiDream I1 Dev",
|
||||
"hidream_i1_fast": "HiDream I1 Rápido",
|
||||
"hidream_i1_full": "HiDream I1 Completo",
|
||||
"hidream_i1_fast": "HiDream I1 Fast",
|
||||
"hidream_i1_full": "HiDream I1 Full",
|
||||
"image_chroma_text_to_image": "Chroma texto a imagen",
|
||||
"image_cosmos_predict2_2B_t2i": "Cosmos Predict2 2B T2I",
|
||||
"image_lotus_depth_v1_1": "Lotus Depth",
|
||||
"image_omnigen2_image_edit": "OmniGen2 Edición de Imagen",
|
||||
"image_omnigen2_t2i": "OmniGen2 Texto a Imagen",
|
||||
"sd3_5_large_blur": "SD3.5 Grande Desenfoque",
|
||||
"sd3_5_large_canny_controlnet_example": "SD3.5 Grande Canny ControlNet",
|
||||
"sd3_5_large_depth": "SD3.5 Grande Profundidad",
|
||||
"sd3_5_large_blur": "SD3.5 Large Blur",
|
||||
"sd3_5_large_canny_controlnet_example": "SD3.5 Large Canny ControlNet",
|
||||
"sd3_5_large_depth": "SD3.5 Large Depth",
|
||||
"sd3_5_simple_example": "SD3.5 Simple",
|
||||
"sdxl_refiner_prompt_example": "SDXL Refinador de Solicitud",
|
||||
"sdxl_revision_text_prompts": "SDXL Revisión de Solicitud de Texto",
|
||||
"sdxl_revision_zero_positive": "SDXL Revisión Cero Positivo",
|
||||
"sdxl_refiner_prompt_example": "SDXL Refiner Prompt",
|
||||
"sdxl_revision_text_prompts": "SDXL Revision Text Prompts",
|
||||
"sdxl_revision_zero_positive": "SDXL Revision Zero Positive",
|
||||
"sdxl_simple_example": "SDXL Simple",
|
||||
"sdxlturbo_example": "SDXL Turbo"
|
||||
},
|
||||
@@ -1377,16 +1388,16 @@
|
||||
"api_ideogram_v3_t2i": "Ideogram V3: Texto a Imagen",
|
||||
"api_luma_photon_i2i": "Luma Photon: Imagen a Imagen",
|
||||
"api_luma_photon_style_ref": "Luma Photon: Referencia de Estilo",
|
||||
"api_openai_dall_e_2_inpaint": "OpenAI: Dall-E 2 Rellenar",
|
||||
"api_openai_dall_e_2_inpaint": "OpenAI: Dall-E 2 Inpaint",
|
||||
"api_openai_dall_e_2_t2i": "OpenAI: Dall-E 2 Texto a Imagen",
|
||||
"api_openai_dall_e_3_t2i": "OpenAI: Dall-E 3 Texto a Imagen",
|
||||
"api_openai_image_1_i2i": "OpenAI: GPT-Image-1 Imagen a Imagen",
|
||||
"api_openai_image_1_inpaint": "OpenAI: GPT-Image-1 Rellenar",
|
||||
"api_openai_image_1_inpaint": "OpenAI: GPT-Image-1 Inpaint",
|
||||
"api_openai_image_1_multi_inputs": "OpenAI: GPT-Image-1 Múltiples Entradas",
|
||||
"api_openai_image_1_t2i": "OpenAI: GPT-Image-1 Texto a Imagen",
|
||||
"api_recraft_image_gen_with_color_control": "Recraft: Generación de Imagen con Control de Color",
|
||||
"api_recraft_image_gen_with_style_control": "Recraft: Generación de Imagen con Control de Estilo",
|
||||
"api_recraft_vector_gen": "Recraft: Generación de Vectores",
|
||||
"api_recraft_vector_gen": "Recraft: Generación Vectorial",
|
||||
"api_runway_reference_to_image": "Runway: Referencia a Imagen",
|
||||
"api_runway_text_to_image": "Runway: Texto a Imagen",
|
||||
"api_stability_ai_i2i": "Stability AI: Imagen a Imagen",
|
||||
@@ -1400,9 +1411,9 @@
|
||||
},
|
||||
"Upscaling": {
|
||||
"esrgan_example": "ESRGAN",
|
||||
"hiresfix_esrgan_workflow": "Flujo de Trabajo HiresFix ESRGAN",
|
||||
"hiresfix_latent_workflow": "Ampliación",
|
||||
"latent_upscale_different_prompt_model": "Ampliación Latente Modelo de Solicitud Diferente"
|
||||
"hiresfix_esrgan_workflow": "HiresFix ESRGAN Workflow",
|
||||
"hiresfix_latent_workflow": "Escalado",
|
||||
"latent_upscale_different_prompt_model": "Latent Upscale Different Prompt Model"
|
||||
},
|
||||
"Video": {
|
||||
"hunyuan_video_text_to_video": "Hunyuan Video Texto a Video",
|
||||
@@ -1419,7 +1430,7 @@
|
||||
"video_wan_vace_14B_ref2v": "Wan VACE Referencia a Video",
|
||||
"video_wan_vace_14B_t2v": "Wan VACE Texto a Video",
|
||||
"video_wan_vace_14B_v2v": "Wan VACE Control Video",
|
||||
"video_wan_vace_flf2v": "Wan VACE Primer-Ultimo Fotograma",
|
||||
"video_wan_vace_flf2v": "Wan VACE First-Last Frame",
|
||||
"video_wan_vace_inpainting": "Wan VACE Inpainting",
|
||||
"video_wan_vace_outpainting": "Wan VACE Outpainting",
|
||||
"wan2_1_flf2v_720_f16": "Wan 2.1 FLF2V 720p F16",
|
||||
@@ -1437,11 +1448,11 @@
|
||||
"api_moonvalley_image_to_video": "Moonvalley: Imagen a Video",
|
||||
"api_moonvalley_text_to_video": "Moonvalley: Texto a Video",
|
||||
"api_pika_i2v": "Pika: Imagen a Video",
|
||||
"api_pika_scene": "Pika Escenas: Imágenes a Video",
|
||||
"api_pika_scene": "Pika Scenes: Imágenes a Video",
|
||||
"api_pixverse_i2v": "PixVerse: Imagen a Video",
|
||||
"api_pixverse_t2v": "PixVerse: Texto a Video",
|
||||
"api_pixverse_template_i2v": "PixVerse Plantillas: Imagen a Video",
|
||||
"api_runway_first_last_frame": "Runway: Primer Último Fotograma a Video",
|
||||
"api_runway_first_last_frame": "Runway: Primer Último Cuadro a Video",
|
||||
"api_runway_gen3a_turbo_image_to_video": "Runway: Gen3a Turbo Imagen a Video",
|
||||
"api_runway_gen4_turo_image_to_video": "Runway: Gen4 Turbo Imagen a Video",
|
||||
"api_veo2_i2v": "Veo2: Imagen a Video"
|
||||
@@ -1456,34 +1467,34 @@
|
||||
},
|
||||
"3D API": {
|
||||
"api_rodin_image_to_model": "Genera modelos 3D detallados a partir de una sola foto usando Rodin AI.",
|
||||
"api_rodin_multiview_to_model": "Esculpe modelos 3D completos usando reconstrucción multivista de Rodin.",
|
||||
"api_rodin_multiview_to_model": "Esculpe modelos 3D completos usando la reconstrucción multiángulo de Rodin.",
|
||||
"api_tripo_image_to_model": "Genera activos 3D profesionales a partir de imágenes 2D usando el motor Tripo.",
|
||||
"api_tripo_multiview_to_model": "Construye modelos 3D a partir de múltiples ángulos con el escáner avanzado de Tripo.",
|
||||
"api_tripo_text_to_model": "Crea objetos 3D a partir de descripciones con modelado basado en texto de Tripo."
|
||||
"api_tripo_multiview_to_model": "Construye modelos 3D desde múltiples ángulos con el escáner avanzado de Tripo.",
|
||||
"api_tripo_text_to_model": "Crea objetos 3D a partir de descripciones con el modelado basado en texto de Tripo."
|
||||
},
|
||||
"Area Composition": {
|
||||
"area_composition": "Genera imágenes controlando la composición con áreas definidas.",
|
||||
"area_composition_square_area_for_subject": "Genera imágenes con colocación consistente del sujeto usando composición de áreas."
|
||||
"area_composition_square_area_for_subject": "Genera imágenes con colocación consistente del sujeto usando composición de área."
|
||||
},
|
||||
"Audio": {
|
||||
"audio_ace_step_1_m2m_editing": "Edita canciones existentes para cambiar el estilo y la letra usando ACE-Step v1 M2M.",
|
||||
"audio_ace_step_1_m2m_editing": "Edita canciones existentes para cambiar estilo y letra usando ACE-Step v1 M2M.",
|
||||
"audio_ace_step_1_t2a_instrumentals": "Genera música instrumental a partir de texto usando ACE-Step v1.",
|
||||
"audio_ace_step_1_t2a_song": "Genera canciones con voz a partir de texto usando ACE-Step v1, soportando múltiples idiomas y personalización de estilo.",
|
||||
"audio_stable_audio_example": "Genera audio a partir de descripciones de texto usando Stable Audio."
|
||||
"audio_ace_step_1_t2a_song": "Genera canciones con voz a partir de texto usando ACE-Step v1, soportando multilingüe y personalización de estilo.",
|
||||
"audio_stable_audio_example": "Genera audio a partir de texto usando Stable Audio."
|
||||
},
|
||||
"Basics": {
|
||||
"default": "Genera imágenes a partir de descripciones de texto.",
|
||||
"default": "Genera imágenes a partir de indicaciones de texto.",
|
||||
"embedding_example": "Genera imágenes usando inversión textual para estilos consistentes.",
|
||||
"gligen_textbox_example": "Genera imágenes con colocación precisa de objetos usando cajas de texto.",
|
||||
"gligen_textbox_example": "Genera imágenes con colocación precisa de objetos usando cuadros de texto.",
|
||||
"image2image": "Transforma imágenes existentes usando indicaciones de texto.",
|
||||
"inpaint_example": "Edita partes específicas de imágenes de manera fluida.",
|
||||
"inpaint_example": "Edita partes específicas de imágenes de forma fluida.",
|
||||
"inpaint_model_outpainting": "Extiende imágenes más allá de sus límites originales.",
|
||||
"lora": "Genera imágenes con modelos LoRA para estilos o temas especializados.",
|
||||
"lora_multiple": "Genera imágenes combinando múltiples modelos LoRA."
|
||||
},
|
||||
"ControlNet": {
|
||||
"2_pass_pose_worship": "Genera imágenes guiadas por referencias de pose usando ControlNet.",
|
||||
"controlnet_example": "Genera imágenes guiadas por imágenes de garabato usando ControlNet.",
|
||||
"controlnet_example": "Genera imágenes guiadas por imágenes de referencia de garabatos usando ControlNet.",
|
||||
"depth_controlnet": "Genera imágenes guiadas por información de profundidad usando ControlNet.",
|
||||
"depth_t2i_adapter": "Genera imágenes guiadas por información de profundidad usando el adaptador T2I.",
|
||||
"mixing_controlnets": "Genera imágenes combinando múltiples modelos ControlNet."
|
||||
@@ -1491,31 +1502,31 @@
|
||||
"Flux": {
|
||||
"flux_canny_model_example": "Genera imágenes guiadas por detección de bordes usando Flux Canny.",
|
||||
"flux_depth_lora_example": "Genera imágenes guiadas por información de profundidad usando Flux LoRA.",
|
||||
"flux_dev_checkpoint_example": "Genera imágenes usando la versión cuantizada fp8 de Flux Dev. Ideal para dispositivos con poca VRAM, solo requiere un archivo de modelo, pero la calidad es ligeramente inferior a la versión completa.",
|
||||
"flux_dev_full_text_to_image": "Genera imágenes de alta calidad con la versión completa de Flux Dev. Requiere más VRAM y múltiples archivos de modelo, pero ofrece la mejor adherencia a la indicación y calidad de imagen.",
|
||||
"flux_fill_inpaint_example": "Rellena partes faltantes de imágenes usando inpainting de Flux.",
|
||||
"flux_fill_outpaint_example": "Extiende imágenes más allá de los límites usando outpainting de Flux.",
|
||||
"flux_kontext_dev_basic": "Edita imágenes usando Flux Kontext con visibilidad total de nodos, ideal para aprender el flujo de trabajo.",
|
||||
"flux_dev_checkpoint_example": "Genera imágenes usando Flux Dev versión fp8 cuantizada. Adecuado para dispositivos con VRAM limitada, solo requiere un archivo de modelo, pero la calidad de imagen es ligeramente inferior a la versión completa.",
|
||||
"flux_dev_full_text_to_image": "Genera imágenes de alta calidad con Flux Dev versión completa. Requiere mayor VRAM y múltiples archivos de modelo, pero ofrece la mejor capacidad de seguimiento de indicaciones y calidad de imagen.",
|
||||
"flux_fill_inpaint_example": "Rellena partes faltantes de imágenes usando Flux inpainting.",
|
||||
"flux_fill_outpaint_example": "Extiende imágenes más allá de los límites usando Flux outpainting.",
|
||||
"flux_kontext_dev_basic": "Edita imágenes usando Flux Kontext con visibilidad total de nodos, perfecto para aprender el flujo de trabajo.",
|
||||
"flux_kontext_dev_grouped": "Versión simplificada de Flux Kontext con nodos agrupados para un espacio de trabajo más limpio.",
|
||||
"flux_redux_model_example": "Genera imágenes transfiriendo el estilo de imágenes de referencia usando Flux Redux.",
|
||||
"flux_schnell": "Genera imágenes rápidamente con la versión cuantizada fp8 de Flux Schnell. Perfecto para hardware de gama baja, solo requiere 4 pasos.",
|
||||
"flux_schnell_full_text_to_image": "Genera imágenes rápidamente con la versión completa de Flux Schnell. Licencia Apache2.0, solo requiere 4 pasos manteniendo buena calidad."
|
||||
"flux_redux_model_example": "Genera imágenes transfiriendo estilo de imágenes de referencia usando Flux Redux.",
|
||||
"flux_schnell": "Genera imágenes rápidamente con Flux Schnell versión fp8 cuantizada. Ideal para hardware de gama baja, solo requiere 4 pasos para generar imágenes.",
|
||||
"flux_schnell_full_text_to_image": "Genera imágenes rápidamente con Flux Schnell versión completa. Usa licencia Apache2.0, solo requiere 4 pasos para generar imágenes manteniendo buena calidad."
|
||||
},
|
||||
"Image": {
|
||||
"hidream_e1_full": "Edita imágenes con HiDream E1 - Modelo profesional de edición de imágenes por lenguaje natural.",
|
||||
"hidream_i1_dev": "Genera imágenes con HiDream I1 Dev - Versión equilibrada con 28 pasos de inferencia, adecuada para hardware medio.",
|
||||
"hidream_i1_fast": "Genera imágenes rápidamente con HiDream I1 Fast - Versión ligera con 16 pasos, ideal para previsualizaciones rápidas.",
|
||||
"hidream_i1_full": "Genera imágenes con HiDream I1 Full - Versión completa con 50 pasos para la máxima calidad.",
|
||||
"image_chroma_text_to_image": "Chroma está modificado de Flux y tiene algunos cambios en la arquitectura.",
|
||||
"image_cosmos_predict2_2B_t2i": "Genera imágenes con Cosmos-Predict2 2B T2I, logrando generación física precisa, alta fidelidad y gran detalle.",
|
||||
"image_lotus_depth_v1_1": "Ejecuta Lotus Depth en ComfyUI para estimación de profundidad monocular eficiente y detallada.",
|
||||
"hidream_i1_dev": "Genera imágenes con HiDream I1 Dev - Versión equilibrada con 28 pasos de inferencia, adecuada para hardware de gama media.",
|
||||
"hidream_i1_fast": "Genera imágenes rápidamente con HiDream I1 Fast - Versión ligera con 16 pasos de inferencia, ideal para previsualizaciones rápidas en hardware de gama baja.",
|
||||
"hidream_i1_full": "Genera imágenes con HiDream I1 Full - Versión completa con 50 pasos de inferencia para la máxima calidad.",
|
||||
"image_chroma_text_to_image": "Chroma está modificado de flux y tiene algunos cambios en la arquitectura.",
|
||||
"image_cosmos_predict2_2B_t2i": "Genera imágenes con Cosmos-Predict2 2B T2I, logrando generación físicamente precisa, de alta fidelidad y con gran nivel de detalle.",
|
||||
"image_lotus_depth_v1_1": "Ejecuta Lotus Depth en ComfyUI para estimación monocular de profundidad eficiente y de alta retención de detalles.",
|
||||
"image_omnigen2_image_edit": "Edita imágenes con instrucciones en lenguaje natural usando las avanzadas capacidades de edición de imagen y soporte de texto de OmniGen2.",
|
||||
"image_omnigen2_t2i": "Genera imágenes de alta calidad a partir de texto usando el modelo multimodal unificado 7B de OmniGen2 con arquitectura de doble vía.",
|
||||
"sd3_5_large_blur": "Genera imágenes guiadas por imágenes de referencia borrosas usando SD 3.5.",
|
||||
"sd3_5_large_blur": "Genera imágenes guiadas por imágenes de referencia desenfocadas usando SD 3.5.",
|
||||
"sd3_5_large_canny_controlnet_example": "Genera imágenes guiadas por detección de bordes usando SD 3.5 Canny ControlNet.",
|
||||
"sd3_5_large_depth": "Genera imágenes guiadas por información de profundidad usando SD 3.5.",
|
||||
"sd3_5_simple_example": "Genera imágenes usando SD 3.5.",
|
||||
"sdxl_refiner_prompt_example": "Mejora imágenes SDXL usando modelos refinadores.",
|
||||
"sdxl_refiner_prompt_example": "Mejora imágenes SDXL usando modelos refiner.",
|
||||
"sdxl_revision_text_prompts": "Genera imágenes transfiriendo conceptos de imágenes de referencia usando SDXL Revision.",
|
||||
"sdxl_revision_zero_positive": "Genera imágenes usando tanto indicaciones de texto como imágenes de referencia con SDXL Revision.",
|
||||
"sdxl_simple_example": "Genera imágenes de alta calidad usando SDXL.",
|
||||
@@ -1528,23 +1539,23 @@
|
||||
"api_bfl_flux_pro_t2i": "Genera imágenes con excelente seguimiento de indicaciones y calidad visual usando FLUX.1 Pro.",
|
||||
"api_ideogram_v3_t2i": "Genera imágenes de calidad profesional con excelente alineación de indicaciones, fotorrealismo y renderizado de texto usando Ideogram V3.",
|
||||
"api_luma_photon_i2i": "Guía la generación de imágenes usando una combinación de imágenes e indicaciones.",
|
||||
"api_luma_photon_style_ref": "Genera imágenes combinando referencias de estilo con control preciso usando Luma Photon.",
|
||||
"api_luma_photon_style_ref": "Genera imágenes mezclando referencias de estilo con control preciso usando Luma Photon.",
|
||||
"api_openai_dall_e_2_inpaint": "Edita imágenes usando inpainting con la API OpenAI Dall-E 2.",
|
||||
"api_openai_dall_e_2_t2i": "Genera imágenes a partir de texto usando la API OpenAI Dall-E 2.",
|
||||
"api_openai_dall_e_3_t2i": "Genera imágenes a partir de texto usando la API OpenAI Dall-E 3.",
|
||||
"api_openai_image_1_i2i": "Genera imágenes a partir de imágenes usando la API OpenAI GPT Image 1.",
|
||||
"api_openai_image_1_i2i": "Genera imágenes a partir de imágenes de entrada usando la API OpenAI GPT Image 1.",
|
||||
"api_openai_image_1_inpaint": "Edita imágenes usando inpainting con la API OpenAI GPT Image 1.",
|
||||
"api_openai_image_1_multi_inputs": "Genera imágenes a partir de múltiples entradas usando la API OpenAI GPT Image 1.",
|
||||
"api_openai_image_1_t2i": "Genera imágenes a partir de texto usando la API OpenAI GPT Image 1.",
|
||||
"api_recraft_image_gen_with_color_control": "Genera imágenes con paletas de color personalizadas y visuales de marca usando Recraft.",
|
||||
"api_recraft_image_gen_with_style_control": "Controla el estilo con ejemplos visuales, alinea la posición y ajusta objetos. Guarda y comparte estilos para consistencia de marca.",
|
||||
"api_recraft_image_gen_with_color_control": "Genera imágenes con paletas de colores personalizadas y visuales específicos de marca usando Recraft.",
|
||||
"api_recraft_image_gen_with_style_control": "Controla el estilo con ejemplos visuales, alinea la posición y ajusta objetos. Guarda y comparte estilos para coherencia de marca perfecta.",
|
||||
"api_recraft_vector_gen": "Genera imágenes vectoriales de alta calidad a partir de texto usando el generador de vectores IA de Recraft.",
|
||||
"api_runway_reference_to_image": "Genera nuevas imágenes basadas en estilos y composiciones de referencia con Runway.",
|
||||
"api_runway_reference_to_image": "Genera nuevas imágenes basadas en estilos y composiciones de referencia con la IA de Runway.",
|
||||
"api_runway_text_to_image": "Genera imágenes de alta calidad a partir de texto usando el modelo IA de Runway.",
|
||||
"api_stability_ai_i2i": "Transforma imágenes con generación de alta calidad usando Stability AI, ideal para edición profesional y transferencia de estilo.",
|
||||
"api_stability_ai_sd3_5_i2i": "Genera imágenes de alta calidad con excelente adherencia a la indicación. Perfecto para uso profesional a 1 megapíxel.",
|
||||
"api_stability_ai_sd3_5_t2i": "Genera imágenes de alta calidad con excelente adherencia a la indicación. Perfecto para uso profesional a 1 megapíxel.",
|
||||
"api_stability_ai_stable_image_ultra_t2i": "Genera imágenes de alta calidad con excelente adherencia a la indicación. Perfecto para uso profesional a 1 megapíxel."
|
||||
"api_stability_ai_i2i": "Transforma imágenes con generación de alta calidad usando Stability AI, perfecto para edición profesional y transferencia de estilo.",
|
||||
"api_stability_ai_sd3_5_i2i": "Genera imágenes de alta calidad con excelente adherencia a la indicación. Perfecto para casos profesionales a 1 megapíxel de resolución.",
|
||||
"api_stability_ai_sd3_5_t2i": "Genera imágenes de alta calidad con excelente adherencia a la indicación. Perfecto para casos profesionales a 1 megapíxel de resolución.",
|
||||
"api_stability_ai_stable_image_ultra_t2i": "Genera imágenes de alta calidad con excelente adherencia a la indicación. Perfecto para casos profesionales a 1 megapíxel de resolución."
|
||||
},
|
||||
"LLM API": {
|
||||
"api_google_gemini": "Experimenta la IA multimodal de Google con las capacidades de razonamiento de Gemini.",
|
||||
@@ -1552,48 +1563,48 @@
|
||||
},
|
||||
"Upscaling": {
|
||||
"esrgan_example": "Escala imágenes usando modelos ESRGAN para mejorar la calidad.",
|
||||
"hiresfix_esrgan_workflow": "Escala imágenes usando modelos ESRGAN durante pasos intermedios.",
|
||||
"hiresfix_esrgan_workflow": "Escala imágenes usando modelos ESRGAN durante pasos intermedios de generación.",
|
||||
"hiresfix_latent_workflow": "Escala imágenes mejorando la calidad en el espacio latente.",
|
||||
"latent_upscale_different_prompt_model": "Escala imágenes cambiando las indicaciones entre pasadas."
|
||||
"latent_upscale_different_prompt_model": "Escala imágenes cambiando las indicaciones entre pasadas de generación."
|
||||
},
|
||||
"Video": {
|
||||
"hunyuan_video_text_to_video": "Genera videos a partir de texto usando el modelo Hunyuan.",
|
||||
"image_to_video": "Genera videos a partir de imágenes fijas.",
|
||||
"image_to_video_wan": "Genera videos a partir de imágenes usando Wan 2.1.",
|
||||
"ltxv_image_to_video": "Genera videos a partir de imágenes fijas.",
|
||||
"ltxv_text_to_video": "Genera videos a partir de texto.",
|
||||
"ltxv_text_to_video": "Genera videos a partir de indicaciones de texto.",
|
||||
"mochi_text_to_video_example": "Genera videos a partir de texto usando el modelo Mochi.",
|
||||
"text_to_video_wan": "Genera videos a partir de texto usando Wan 2.1.",
|
||||
"txt_to_image_to_video": "Genera videos creando primero imágenes a partir de texto.",
|
||||
"video_cosmos_predict2_2B_video2world_480p_16fps": "Genera videos con Cosmos-Predict2 2B Video2World, logrando simulaciones físicas precisas, alta fidelidad y consistencia.",
|
||||
"video_cosmos_predict2_2B_video2world_480p_16fps": "Genera videos con Cosmos-Predict2 2B Video2World, logrando simulaciones de video físicamente precisas, de alta fidelidad y consistentes.",
|
||||
"video_wan2_1_fun_camera_v1_1_14B": "Genera videos de alta calidad con control avanzado de cámara usando el modelo completo de 14B.",
|
||||
"video_wan2_1_fun_camera_v1_1_1_3B": "Genera videos dinámicos con movimientos de cámara cinematográficos usando Wan 2.1 Fun Camera 1.3B.",
|
||||
"video_wan_vace_14B_ref2v": "Crea videos que coinciden con el estilo y contenido de una imagen de referencia.",
|
||||
"video_wan2_1_fun_camera_v1_1_1_3B": "Genera videos dinámicos con movimientos de cámara cinematográficos usando el modelo Wan 2.1 Fun Camera 1.3B.",
|
||||
"video_wan_vace_14B_ref2v": "Crea videos que coinciden con el estilo y contenido de una imagen de referencia. Perfecto para generación de video consistente en estilo.",
|
||||
"video_wan_vace_14B_t2v": "Transforma descripciones de texto en videos de alta calidad. Soporta 480p y 720p con el modelo VACE-14B.",
|
||||
"video_wan_vace_14B_v2v": "Genera videos controlando videos de entrada e imágenes de referencia usando Wan VACE.",
|
||||
"video_wan_vace_flf2v": "Genera transiciones suaves definiendo fotogramas iniciales y finales. Soporta secuencias de fotogramas personalizadas.",
|
||||
"video_wan_vace_inpainting": "Edita regiones específicas en videos preservando el contenido circundante.",
|
||||
"video_wan_vace_outpainting": "Genera videos extendidos expandiendo el tamaño usando Wan VACE outpainting.",
|
||||
"wan2_1_flf2v_720_f16": "Genera videos controlando primer y último fotograma usando Wan 2.1 FLF2V.",
|
||||
"video_wan_vace_flf2v": "Genera transiciones de video suaves definiendo cuadros iniciales y finales. Soporta secuencias de cuadros personalizadas.",
|
||||
"video_wan_vace_inpainting": "Edita regiones específicas en videos preservando el contenido circundante. Ideal para eliminar o reemplazar objetos.",
|
||||
"video_wan_vace_outpainting": "Genera videos extendidos ampliando el tamaño del video usando Wan VACE outpainting.",
|
||||
"wan2_1_flf2v_720_f16": "Genera videos controlando los primeros y últimos cuadros usando Wan 2.1 FLF2V.",
|
||||
"wan2_1_fun_control": "Genera videos guiados por pose, profundidad y bordes usando Wan 2.1 ControlNet.",
|
||||
"wan2_1_fun_inp": "Genera videos a partir de fotogramas iniciales y finales usando Wan 2.1 inpainting."
|
||||
"wan2_1_fun_inp": "Genera videos a partir de cuadros iniciales y finales usando Wan 2.1 inpainting."
|
||||
},
|
||||
"Video API": {
|
||||
"api_hailuo_minimax_i2v": "Genera videos refinados a partir de imágenes y texto con integración CGI usando MiniMax.",
|
||||
"api_hailuo_minimax_t2v": "Genera videos de alta calidad directamente desde texto. Explora las capacidades avanzadas de IA de MiniMax para crear narrativas visuales diversas con efectos CGI profesionales.",
|
||||
"api_hailuo_minimax_t2v": "Genera videos de alta calidad directamente desde texto. Explora las capacidades avanzadas de IA de MiniMax para crear narrativas visuales diversas con efectos CGI profesionales y elementos estilísticos.",
|
||||
"api_kling_effects": "Genera videos dinámicos aplicando efectos visuales a imágenes usando Kling.",
|
||||
"api_kling_flf": "Genera videos controlando los primeros y últimos fotogramas.",
|
||||
"api_kling_flf": "Genera videos controlando el primer y último cuadro.",
|
||||
"api_kling_i2v": "Genera videos con excelente adherencia a la indicación para acciones, expresiones y movimientos de cámara usando Kling.",
|
||||
"api_luma_i2v": "Convierte imágenes estáticas en animaciones mágicas de alta calidad al instante.",
|
||||
"api_luma_t2v": "Genera videos de alta calidad usando indicaciones simples.",
|
||||
"api_moonvalley_image_to_video": "Genera videos cinematográficos 1080p a partir de una imagen usando un modelo entrenado solo con datos licenciados.",
|
||||
"api_moonvalley_text_to_video": "Genera videos cinematográficos 1080p a partir de texto usando un modelo entrenado solo con datos licenciados.",
|
||||
"api_pika_i2v": "Genera videos animados suaves a partir de imágenes estáticas usando Pika AI.",
|
||||
"api_luma_t2v": "Se pueden generar videos de alta calidad usando indicaciones simples.",
|
||||
"api_moonvalley_image_to_video": "Genera videos cinematográficos en 1080p a partir de una imagen mediante un modelo entrenado exclusivamente con datos licenciados.",
|
||||
"api_moonvalley_text_to_video": "Genera videos cinematográficos en 1080p a partir de texto mediante un modelo entrenado exclusivamente con datos licenciados.",
|
||||
"api_pika_i2v": "Genera videos animados suaves a partir de una sola imagen estática usando Pika AI.",
|
||||
"api_pika_scene": "Genera videos que incorporan múltiples imágenes de entrada usando Pika Scenes.",
|
||||
"api_pixverse_i2v": "Genera videos dinámicos a partir de imágenes estáticas con movimiento y efectos usando PixVerse.",
|
||||
"api_pixverse_t2v": "Genera videos con interpretación precisa de indicaciones y dinámica visual impresionante.",
|
||||
"api_pixverse_t2v": "Genera videos con interpretación precisa de indicaciones y dinámicas visuales impresionantes.",
|
||||
"api_pixverse_template_i2v": "Genera videos dinámicos a partir de imágenes estáticas con movimiento y efectos usando PixVerse.",
|
||||
"api_runway_first_last_frame": "Genera transiciones de video suaves entre dos fotogramas clave con precisión de Runway.",
|
||||
"api_runway_first_last_frame": "Genera transiciones de video suaves entre dos cuadros clave con la precisión de Runway.",
|
||||
"api_runway_gen3a_turbo_image_to_video": "Genera videos cinematográficos a partir de imágenes estáticas usando Runway Gen3a Turbo.",
|
||||
"api_runway_gen4_turo_image_to_video": "Genera videos dinámicos a partir de imágenes usando Runway Gen4 Turbo.",
|
||||
"api_veo2_i2v": "Genera videos a partir de imágenes usando la API Google Veo2."
|
||||
@@ -1602,29 +1613,29 @@
|
||||
"title": "Comienza con una Plantilla"
|
||||
},
|
||||
"toastMessages": {
|
||||
"cannotCreateSubgraph": "No se puede crear el subgrafo",
|
||||
"cannotCreateSubgraph": "No se puede crear subgrafo",
|
||||
"couldNotDetermineFileType": "No se pudo determinar el tipo de archivo",
|
||||
"dropFileError": "No se puede procesar el elemento soltado: {error}",
|
||||
"dropFileError": "No se pudo procesar el elemento soltado: {error}",
|
||||
"emptyCanvas": "Lienzo vacío",
|
||||
"errorCopyImage": "Error al copiar la imagen: {error}",
|
||||
"errorLoadingModel": "Error al cargar el modelo",
|
||||
"errorSaveSetting": "Error al guardar la configuración {id}: {err}",
|
||||
"failedToAccessBillingPortal": "No se pudo acceder al portal de facturación: {error}",
|
||||
"failedToApplyTexture": "Error al aplicar textura",
|
||||
"failedToConvertToSubgraph": "No se pudo convertir los elementos en subgrafo",
|
||||
"failedToApplyTexture": "No se pudo aplicar la textura",
|
||||
"failedToConvertToSubgraph": "No se pudo convertir los elementos a subgrafo",
|
||||
"failedToCreateCustomer": "No se pudo crear el cliente: {error}",
|
||||
"failedToDownloadFile": "Error al descargar el archivo",
|
||||
"failedToExportModel": "Error al exportar modelo como {format}",
|
||||
"failedToDownloadFile": "No se pudo descargar el archivo",
|
||||
"failedToExportModel": "No se pudo exportar el modelo como {format}",
|
||||
"failedToFetchBalance": "No se pudo obtener el saldo: {error}",
|
||||
"failedToFetchLogs": "Error al obtener los registros del servidor",
|
||||
"failedToFetchLogs": "No se pudieron obtener los registros del servidor",
|
||||
"failedToInitializeLoad3dViewer": "No se pudo inicializar el visor 3D",
|
||||
"failedToInitiateCreditPurchase": "No se pudo iniciar la compra de créditos: {error}",
|
||||
"failedToPurchaseCredits": "No se pudo comprar créditos: {error}",
|
||||
"fileLoadError": "No se puede encontrar el flujo de trabajo en {fileName}",
|
||||
"fileLoadError": "No se pudo encontrar el flujo de trabajo en {fileName}",
|
||||
"fileUploadFailed": "Error al subir el archivo",
|
||||
"interrupted": "La ejecución ha sido interrumpida",
|
||||
"migrateToLitegraphReroute": "Los nodos de reroute se eliminarán en futuras versiones. Haz clic para migrar a reroute nativo de litegraph.",
|
||||
"no3dScene": "No hay escena 3D para aplicar textura",
|
||||
"migrateToLitegraphReroute": "Los nodos de redirección serán eliminados en futuras versiones. Haz clic para migrar a la redirección nativa de litegraph.",
|
||||
"no3dScene": "No hay escena 3D para aplicar la textura",
|
||||
"no3dSceneToExport": "No hay escena 3D para exportar",
|
||||
"noTemplatesToExport": "No hay plantillas para exportar",
|
||||
"nodeDefinitionsUpdated": "Definiciones de nodos actualizadas",
|
||||
@@ -1632,12 +1643,12 @@
|
||||
"nothingToGroup": "Nada para agrupar",
|
||||
"nothingToQueue": "Nada para poner en cola",
|
||||
"pendingTasksDeleted": "Tareas pendientes eliminadas",
|
||||
"pleaseSelectNodesToGroup": "Por favor, seleccione los nodos (u otros grupos) para crear un grupo para",
|
||||
"pleaseSelectNodesToGroup": "Por favor, selecciona los nodos (u otros grupos) para crear un grupo",
|
||||
"pleaseSelectOutputNodes": "Por favor, selecciona los nodos de salida",
|
||||
"unableToGetModelFilePath": "No se puede obtener la ruta del archivo del modelo",
|
||||
"unableToGetModelFilePath": "No se pudo obtener la ruta del archivo del modelo",
|
||||
"unauthorizedDomain": "Tu dominio {domain} no está autorizado para usar este servicio. Por favor, contacta a {email} para agregar tu dominio a la lista blanca.",
|
||||
"updateRequested": "Actualización solicitada",
|
||||
"useApiKeyTip": "Consejo: ¿No puedes acceder al inicio de sesión normal? Usa la opción de clave API de Comfy.",
|
||||
"useApiKeyTip": "Consejo: ¿No puedes acceder al inicio de sesión normal? Usa la opción de Comfy API Key.",
|
||||
"userNotAuthenticated": "Usuario no autenticado"
|
||||
},
|
||||
"userSelect": {
|
||||
@@ -1651,12 +1662,12 @@
|
||||
"email": "Correo electrónico",
|
||||
"name": "Nombre",
|
||||
"notSet": "No establecido",
|
||||
"provider": "Método de inicio de sesión",
|
||||
"provider": "Proveedor de inicio de sesión",
|
||||
"title": "Configuración de usuario",
|
||||
"updatePassword": "Actualizar contraseña"
|
||||
},
|
||||
"validation": {
|
||||
"invalidEmail": "Dirección de correo electrónico inválida",
|
||||
"invalidEmail": "Dirección de correo electrónico no válida",
|
||||
"length": "Debe tener {length} caracteres",
|
||||
"maxLength": "No debe tener más de {length} caracteres",
|
||||
"minLength": "Debe tener al menos {length} caracteres",
|
||||
@@ -1671,7 +1682,7 @@
|
||||
},
|
||||
"personalDataConsentRequired": "Debes aceptar el procesamiento de tus datos personales.",
|
||||
"prefix": "Debe comenzar con {prefix}",
|
||||
"required": "Requerido"
|
||||
"required": "Obligatorio"
|
||||
},
|
||||
"versionMismatchWarning": {
|
||||
"dismiss": "Descartar",
|
||||
@@ -1685,7 +1696,7 @@
|
||||
"title": "Bienvenido a ComfyUI"
|
||||
},
|
||||
"whatsNewPopup": {
|
||||
"learnMore": "Aprende más",
|
||||
"learnMore": "Más información",
|
||||
"noReleaseNotes": "No hay notas de la versión disponibles."
|
||||
},
|
||||
"workflowService": {
|
||||
|
||||
@@ -277,6 +277,10 @@
|
||||
"label": "Basculer la barre latérale de la bibliothèque de nœuds",
|
||||
"tooltip": "Bibliothèque de nœuds"
|
||||
},
|
||||
"Workspace_ToggleSidebarTab_output-explorer": {
|
||||
"label": "Basculer la barre latérale de l’Explorateur de sortie",
|
||||
"tooltip": "Explorateur de sortie"
|
||||
},
|
||||
"Workspace_ToggleSidebarTab_queue": {
|
||||
"label": "Basculer la barre latérale de la file d'attente",
|
||||
"tooltip": "File d'attente"
|
||||
|
||||
File diff suppressed because it is too large
Load Diff
@@ -277,6 +277,10 @@
|
||||
"label": "ノードライブラリサイドバーの切り替え",
|
||||
"tooltip": "ノードライブラリ"
|
||||
},
|
||||
"Workspace_ToggleSidebarTab_output-explorer": {
|
||||
"label": "出力エクスプローラーサイドバーを切り替え",
|
||||
"tooltip": "出力エクスプローラー"
|
||||
},
|
||||
"Workspace_ToggleSidebarTab_queue": {
|
||||
"label": "キューサイドバーの切り替え",
|
||||
"tooltip": "キュー"
|
||||
|
||||
File diff suppressed because it is too large
Load Diff
@@ -277,6 +277,10 @@
|
||||
"label": "노드 라이브러리 사이드바 토글",
|
||||
"tooltip": "노드 라이브러리"
|
||||
},
|
||||
"Workspace_ToggleSidebarTab_output-explorer": {
|
||||
"label": "출력 탐색기 사이드바 전환",
|
||||
"tooltip": "출력 탐색기"
|
||||
},
|
||||
"Workspace_ToggleSidebarTab_queue": {
|
||||
"label": "실행 큐 사이드바 토글",
|
||||
"tooltip": "실행 큐"
|
||||
|
||||
File diff suppressed because it is too large
Load Diff
@@ -277,6 +277,10 @@
|
||||
"label": "Переключить боковую панель библиотеки нод",
|
||||
"tooltip": "Библиотека нод"
|
||||
},
|
||||
"Workspace_ToggleSidebarTab_output-explorer": {
|
||||
"label": "Переключить боковую панель проводника вывода",
|
||||
"tooltip": "Проводник вывода"
|
||||
},
|
||||
"Workspace_ToggleSidebarTab_queue": {
|
||||
"label": "Переключить боковую панель очереди",
|
||||
"tooltip": "Очередь"
|
||||
|
||||
File diff suppressed because it is too large
Load Diff
@@ -277,6 +277,10 @@
|
||||
"label": "切換節點庫側邊欄",
|
||||
"tooltip": "節點庫"
|
||||
},
|
||||
"Workspace_ToggleSidebarTab_output-explorer": {
|
||||
"label": "切換輸出總覽側邊欄",
|
||||
"tooltip": "輸出總覽"
|
||||
},
|
||||
"Workspace_ToggleSidebarTab_queue": {
|
||||
"label": "切換佇列側邊欄",
|
||||
"tooltip": "佇列"
|
||||
|
||||
@@ -119,12 +119,12 @@
|
||||
"Add Group": "新增群組",
|
||||
"Add Group For Selected Nodes": "為選取的節點新增群組",
|
||||
"Add Node": "新增節點",
|
||||
"Bypass": "略過",
|
||||
"Bypass": "繞過",
|
||||
"Clone": "複製",
|
||||
"Collapse": "收合",
|
||||
"Colors": "顏色",
|
||||
"Convert to Group Node": "轉換為群組節點",
|
||||
"Copy (Clipspace)": "複製(剪貼空間)",
|
||||
"Copy (Clipspace)": "複製(Clipspace)",
|
||||
"Expand": "展開",
|
||||
"Inputs": "輸入",
|
||||
"Manage": "管理",
|
||||
@@ -163,7 +163,7 @@
|
||||
"buyNow": "立即購買",
|
||||
"insufficientMessage": "您的點數不足,無法執行此工作流程。",
|
||||
"insufficientTitle": "點數不足",
|
||||
"maxAmount": "(最高 $1,000 美元)",
|
||||
"maxAmount": "(最高 $1,000 USD)",
|
||||
"quickPurchase": "快速購買",
|
||||
"seeDetails": "查看詳情",
|
||||
"topUp": "儲值"
|
||||
@@ -174,7 +174,7 @@
|
||||
"*": "*",
|
||||
"AUDIO": "音訊",
|
||||
"BOOLEAN": "布林值",
|
||||
"CAMERA_CONTROL": "攝影機控制",
|
||||
"CAMERA_CONTROL": "相機控制",
|
||||
"CLIP": "CLIP",
|
||||
"CLIP_VISION": "CLIP 視覺",
|
||||
"CLIP_VISION_OUTPUT": "CLIP 視覺輸出",
|
||||
@@ -191,7 +191,7 @@
|
||||
"INT": "整數",
|
||||
"LATENT": "latent (潛空間)",
|
||||
"LATENT_OPERATION": "latent 操作",
|
||||
"LOAD3D_CAMERA": "載入 3D 攝影機",
|
||||
"LOAD3D_CAMERA": "載入3D相機",
|
||||
"LOAD_3D": "載入 3D",
|
||||
"LOAD_3D_ANIMATION": "載入 3D 動畫",
|
||||
"LUMA_CONCEPTS": "LUMA 概念",
|
||||
@@ -224,13 +224,13 @@
|
||||
"reinstall": "重新安裝"
|
||||
},
|
||||
"desktopUpdate": {
|
||||
"description": "ComfyUI Desktop 正在安裝新相依套件,這可能需要幾分鐘。",
|
||||
"description": "ComfyUI Desktop 正在安裝新依賴項。這可能需要幾分鐘。",
|
||||
"errorCheckingUpdate": "檢查更新時發生錯誤",
|
||||
"errorInstallingUpdate": "安裝更新時發生錯誤",
|
||||
"noUpdateFound": "未發現更新",
|
||||
"terminalDefaultMessage": "任何來自更新的主控台輸出都會顯示在這裡。",
|
||||
"title": "正在更新 ComfyUI Desktop",
|
||||
"updateAvailableMessage": "有可用的更新。您要立即重新啟動並更新嗎?",
|
||||
"updateAvailableMessage": "有可用的更新。你要立即重新啟動並更新嗎?",
|
||||
"updateFoundTitle": "發現更新(v{version})"
|
||||
},
|
||||
"downloadGit": {
|
||||
@@ -264,7 +264,8 @@
|
||||
"amount": "數量",
|
||||
"apply": "套用",
|
||||
"architecture": "架構",
|
||||
"audioFailedToLoad": "無法載入音訊",
|
||||
"audio": "音訊",
|
||||
"audioFailedToLoad": "音訊載入失敗",
|
||||
"author": "作者",
|
||||
"back": "返回",
|
||||
"cancel": "取消",
|
||||
@@ -272,7 +273,7 @@
|
||||
"category": "分類",
|
||||
"choose_file_to_upload": "選擇要上傳的檔案",
|
||||
"clear": "清除",
|
||||
"clearFilters": "清除篩選",
|
||||
"clearFilters": "清除篩選條件",
|
||||
"close": "關閉",
|
||||
"color": "顏色",
|
||||
"comingSoon": "即將推出",
|
||||
@@ -313,11 +314,13 @@
|
||||
"filter": "篩選",
|
||||
"findIssues": "尋找問題",
|
||||
"firstTimeUIMessage": "這是您第一次使用新介面。若要返回舊介面,請前往「選單」>「使用新介面」>「關閉」。",
|
||||
"folder": "資料夾",
|
||||
"frontendNewer": "前端版本 {frontendVersion} 可能與後端版本 {backendVersion} 不相容。",
|
||||
"frontendOutdated": "前端版本 {frontendVersion} 已過時。後端需要 {requiredVersion} 或更高版本。",
|
||||
"goToNode": "前往節點",
|
||||
"help": "說明",
|
||||
"icon": "圖示",
|
||||
"image": "影像",
|
||||
"imageFailedToLoad": "無法載入圖片",
|
||||
"imageUrl": "圖片網址",
|
||||
"import": "匯入",
|
||||
@@ -327,23 +330,25 @@
|
||||
"installed": "已安裝",
|
||||
"installing": "安裝中",
|
||||
"interrupted": "已中斷",
|
||||
"itemsCount": "{0} 項",
|
||||
"keybinding": "快捷鍵",
|
||||
"keybindingAlreadyExists": "快捷鍵已存在於",
|
||||
"learnMore": "了解更多",
|
||||
"loadAllFolders": "載入所有資料夾",
|
||||
"loadWorkflow": "載入工作流程",
|
||||
"loading": "載入中",
|
||||
"loadingPanel": "正在載入{panel}面板...",
|
||||
"loadingPanel": "正在載入 {panel} 面板...",
|
||||
"login": "登入",
|
||||
"logs": "日誌",
|
||||
"micPermissionDenied": "麥克風權限被拒絕",
|
||||
"migrate": "遷移",
|
||||
"missing": "缺少",
|
||||
"modifyTime": "修改時間",
|
||||
"name": "名稱",
|
||||
"newFolder": "新資料夾",
|
||||
"next": "下一步",
|
||||
"no": "否",
|
||||
"noAudioRecorded": "沒有錄製到音訊",
|
||||
"noAudioRecorded": "未錄製音訊",
|
||||
"noResultsFound": "找不到結果",
|
||||
"noTasksFound": "找不到任務",
|
||||
"noTasksFoundMessage": "佇列中沒有任務。",
|
||||
@@ -358,7 +363,7 @@
|
||||
"reconnected": "已重新連線",
|
||||
"reconnecting": "重新連線中",
|
||||
"refresh": "重新整理",
|
||||
"releaseTitle": "{package} {version} 版本發佈",
|
||||
"releaseTitle": "{package} {version} 發布",
|
||||
"reloadToApplyChanges": "重新載入以套用變更",
|
||||
"rename": "重新命名",
|
||||
"reportIssue": "送出回報",
|
||||
@@ -373,6 +378,7 @@
|
||||
"saving": "儲存中",
|
||||
"searchExtensions": "搜尋擴充套件",
|
||||
"searchFailedMessage": "找不到符合您搜尋的設定。請嘗試調整搜尋條件。",
|
||||
"searchIn": "在 {0} 中搜尋",
|
||||
"searchKeybindings": "搜尋快捷鍵",
|
||||
"searchModels": "搜尋模型",
|
||||
"searchNodes": "搜尋節點",
|
||||
@@ -381,6 +387,7 @@
|
||||
"setAsBackground": "設為背景",
|
||||
"settings": "設定",
|
||||
"showReport": "顯示報告",
|
||||
"size": "大小",
|
||||
"sort": "排序",
|
||||
"source": "來源",
|
||||
"startRecording": "開始錄音",
|
||||
@@ -391,6 +398,7 @@
|
||||
"terminal": "終端機",
|
||||
"title": "標題",
|
||||
"triggerPhrase": "觸發詞",
|
||||
"type": "類型",
|
||||
"unknownError": "未知錯誤",
|
||||
"update": "更新",
|
||||
"updateAvailable": "有可用更新",
|
||||
@@ -402,6 +410,7 @@
|
||||
"user": "使用者",
|
||||
"versionMismatchWarning": "版本相容性警告",
|
||||
"versionMismatchWarningMessage": "{warning}:{detail} 請參閱 https://docs.comfy.org/installation/update_comfyui#common-update-issues 以取得更新說明。",
|
||||
"video": "影片",
|
||||
"videoFailedToLoad": "無法載入影片",
|
||||
"workflow": "工作流程"
|
||||
},
|
||||
@@ -425,13 +434,13 @@
|
||||
"docs": "文件",
|
||||
"github": "Github",
|
||||
"helpFeedback": "幫助與回饋",
|
||||
"loadingReleases": "正在載入版本資訊…",
|
||||
"more": "更多…",
|
||||
"noRecentReleases": "近期沒有新版本",
|
||||
"loadingReleases": "正在載入版本...",
|
||||
"more": "更多...",
|
||||
"noRecentReleases": "近期無版本更新",
|
||||
"openDevTools": "開啟開發者工具",
|
||||
"reinstall": "重新安裝",
|
||||
"updateAvailable": "有更新",
|
||||
"whatsNew": "有什麼新功能?"
|
||||
"whatsNew": "最新消息?"
|
||||
},
|
||||
"icon": {
|
||||
"bookmark": "書籤",
|
||||
@@ -476,7 +485,7 @@
|
||||
"installLocationDescription": "選擇 ComfyUI 使用者資料的目錄。Python 環境將安裝在所選位置。",
|
||||
"installLocationTooltip": "ComfyUI 的使用者資料目錄。儲存:\n- Python 環境\n- 模型\n- 自訂節點\n",
|
||||
"insufficientFreeSpace": "空間不足 - 最低可用空間",
|
||||
"isOneDrive": "不支援 OneDrive。請將 ComfyUI 安裝在其他位置。",
|
||||
"isOneDrive": "不支援 OneDrive。請在其他位置安裝 ComfyUI。",
|
||||
"manualConfiguration": {
|
||||
"createVenv": "您需要在下列目錄建立虛擬環境",
|
||||
"requirements": "需求",
|
||||
@@ -491,7 +500,7 @@
|
||||
"migrationOptional": "遷移為選擇性步驟。如果您沒有現有安裝,可以略過此步驟。",
|
||||
"migrationSourcePathDescription": "如果您已有 ComfyUI 安裝,我們可以將您現有的使用者檔案與模型複製/連結到新安裝。您現有的 ComfyUI 安裝不會受到影響。",
|
||||
"moreInfo": "更多資訊請參閱",
|
||||
"nonDefaultDrive": "請將 ComfyUI 安裝在您的系統磁碟(例如 C:\\)。不同檔案系統的磁碟可能會導致不可預期的問題。安裝後,模型和其他檔案可以儲存在其他磁碟。",
|
||||
"nonDefaultDrive": "請將 ComfyUI 安裝在系統磁碟機(例如 C:\\)。不同檔案系統的磁碟機可能會導致不可預期的問題。模型和其他檔案可於安裝後儲存在其他磁碟機。",
|
||||
"parentMissing": "路徑不存在 - 請先建立上層目錄",
|
||||
"pathExists": "目錄已存在 - 請確保您已備份所有資料",
|
||||
"pathValidationFailed": "路徑驗證失敗",
|
||||
@@ -502,7 +511,7 @@
|
||||
"allowMetricsDescription": "協助改進 ComfyUI,傳送匿名使用統計資料。不會收集個人資訊或工作流程內容。",
|
||||
"autoUpdate": "自動更新",
|
||||
"autoUpdateDescription": "自動下載可用更新。安裝前會通知您。",
|
||||
"checkingMirrors": "正在檢查 Python 鏡像的網路連線...",
|
||||
"checkingMirrors": "正在檢查對 Python 鏡像的網路連線...",
|
||||
"dataCollectionDialog": {
|
||||
"collect": {
|
||||
"errorReports": "錯誤訊息與堆疊追蹤",
|
||||
@@ -524,10 +533,10 @@
|
||||
"errorUpdatingConsentDetail": "無法更新統計同意設定",
|
||||
"learnMoreAboutData": "了解更多資料收集資訊",
|
||||
"mirrorSettings": "鏡像設定",
|
||||
"mirrorsReachable": "Python 鏡像網路連線正常",
|
||||
"mirrorsUnreachable": "部分 Python 鏡像網路連線異常",
|
||||
"pypiMirrorPlaceholder": "請輸入 PyPI 鏡像網址",
|
||||
"pythonMirrorPlaceholder": "請輸入 Python 鏡像網址"
|
||||
"mirrorsReachable": "對 Python 鏡像的網路連線良好",
|
||||
"mirrorsUnreachable": "部分 Python 鏡像的網路連線不佳",
|
||||
"pypiMirrorPlaceholder": "輸入 PyPI 鏡像網址",
|
||||
"pythonMirrorPlaceholder": "輸入 Python 鏡像網址"
|
||||
},
|
||||
"systemLocations": "系統位置",
|
||||
"unhandledError": "未知錯誤",
|
||||
@@ -535,14 +544,14 @@
|
||||
},
|
||||
"issueReport": {
|
||||
"contactFollowUp": "需要聯絡我以便後續追蹤",
|
||||
"contactSupportDescription": "請填寫下列表單並提交您的報告",
|
||||
"contactSupportTitle": "聯絡客服支援",
|
||||
"contactSupportDescription": "請在下方表單填寫您的回報內容",
|
||||
"contactSupportTitle": "聯絡支援",
|
||||
"describeTheProblem": "請描述問題",
|
||||
"email": "電子郵件",
|
||||
"feedbackTitle": "協助我們改進 ComfyUI,請提供您的回饋",
|
||||
"helpFix": "協助修復此問題",
|
||||
"helpTypes": {
|
||||
"billingPayments": "帳單/付款問題",
|
||||
"billingPayments": "帳單/付款",
|
||||
"bugReport": "錯誤回報",
|
||||
"giveFeedback": "提供回饋",
|
||||
"loginAccessIssues": "登入/存取問題",
|
||||
@@ -552,12 +561,12 @@
|
||||
"provideAdditionalDetails": "提供更多細節",
|
||||
"provideEmail": "請提供您的電子郵件(選填)",
|
||||
"rating": "評分",
|
||||
"selectIssue": "請選擇問題",
|
||||
"selectIssue": "選擇問題",
|
||||
"stackTrace": "堆疊追蹤",
|
||||
"submitErrorReport": "提交錯誤報告(選填)",
|
||||
"systemStats": "系統狀態",
|
||||
"validation": {
|
||||
"descriptionRequired": "請填寫問題描述",
|
||||
"descriptionRequired": "請填寫描述",
|
||||
"helpTypeRequired": "請選擇協助類型",
|
||||
"invalidEmail": "請輸入有效的電子郵件地址",
|
||||
"maxLength": "訊息過長",
|
||||
@@ -588,7 +597,7 @@
|
||||
"materialMode": "材質模式",
|
||||
"materialModes": {
|
||||
"depth": "深度",
|
||||
"lineart": "線條藝術",
|
||||
"lineart": "線稿",
|
||||
"normal": "一般",
|
||||
"original": "原始",
|
||||
"wireframe": "線框"
|
||||
@@ -616,10 +625,10 @@
|
||||
"cameraType": "相機類型",
|
||||
"cancel": "取消",
|
||||
"exportSettings": "匯出設定",
|
||||
"lightSettings": "燈光設定",
|
||||
"lightSettings": "光源設定",
|
||||
"modelSettings": "模型設定",
|
||||
"sceneSettings": "場景設定",
|
||||
"title": "3D 檢視器(測試版)"
|
||||
"title": "3D 檢視器(Beta)"
|
||||
}
|
||||
},
|
||||
"loadWorkflowWarning": {
|
||||
@@ -631,10 +640,10 @@
|
||||
"None": "無",
|
||||
"OK": "正常",
|
||||
"Skipped": "已略過",
|
||||
"allOk": "未偵測到任何問題。",
|
||||
"confirmTitle": "確定要繼續嗎?",
|
||||
"consoleLogs": "控制台日誌",
|
||||
"detected": "已偵測",
|
||||
"allOk": "未檢測到任何問題。",
|
||||
"confirmTitle": "您確定嗎?",
|
||||
"consoleLogs": "主控台日誌",
|
||||
"detected": "已檢測",
|
||||
"error": {
|
||||
"cannotContinue": "無法繼續 - 仍有錯誤存在",
|
||||
"defaultDescription": "執行維護任務時發生錯誤。",
|
||||
@@ -669,10 +678,10 @@
|
||||
"latestVersion": "最新版本",
|
||||
"license": "授權條款",
|
||||
"loadingVersions": "正在載入版本...",
|
||||
"nightlyVersion": "每夜建置版",
|
||||
"noDescription": "沒有可用的說明",
|
||||
"nightlyVersion": "夜間版",
|
||||
"noDescription": "沒有可用的描述",
|
||||
"noNodesFound": "找不到任何節點",
|
||||
"noNodesFoundDescription": "此套件的節點無法解析,或此套件僅為前端擴充功能,沒有任何節點。",
|
||||
"noNodesFoundDescription": "此套件的節點無法解析,或此套件僅為前端擴充且沒有任何節點。",
|
||||
"noResultsFound": "找不到符合搜尋條件的結果。",
|
||||
"nodePack": "節點包",
|
||||
"packsSelected": "已選擇套件",
|
||||
@@ -706,7 +715,7 @@
|
||||
"version": "版本"
|
||||
},
|
||||
"maskEditor": {
|
||||
"Apply to Whole Image": "套用至整張圖片",
|
||||
"Apply to Whole Image": "套用至整張圖像",
|
||||
"Brush Settings": "筆刷設定",
|
||||
"Brush Shape": "筆刷形狀",
|
||||
"Clear": "清除",
|
||||
@@ -753,8 +762,8 @@
|
||||
"refresh": "重新整理節點定義",
|
||||
"resetView": "重設畫布視圖",
|
||||
"run": "執行",
|
||||
"runWorkflow": "執行工作流程(Shift 於前方排隊)",
|
||||
"runWorkflowFront": "執行工作流程(前方排隊)",
|
||||
"runWorkflow": "執行工作流程(Shift 以排到最前面)",
|
||||
"runWorkflowFront": "執行工作流程(排到最前面)",
|
||||
"settings": "設定",
|
||||
"showMenu": "顯示選單",
|
||||
"theme": "主題",
|
||||
@@ -823,6 +832,7 @@
|
||||
"Open Outputs Folder": "開啟輸出資料夾",
|
||||
"Open Sign In Dialog": "開啟登入對話框",
|
||||
"Open extra_model_paths_yaml": "開啟 extra_model_paths.yaml",
|
||||
"Output Explorer": "輸出總管",
|
||||
"Pin/Unpin Selected Items": "釘選/取消釘選選取項目",
|
||||
"Pin/Unpin Selected Nodes": "釘選/取消釘選選取節點",
|
||||
"Previous Opened Workflow": "上一個已開啟的工作流程",
|
||||
@@ -843,12 +853,12 @@
|
||||
"Show Model Selector (Dev)": "顯示模型選擇器(開發用)",
|
||||
"Show Settings Dialog": "顯示設定對話框",
|
||||
"Sign Out": "登出",
|
||||
"Toggle Essential Bottom Panel": "切換基本下方面板",
|
||||
"Toggle Essential Bottom Panel": "切換基本底部面板",
|
||||
"Toggle Logs Bottom Panel": "切換日誌下方面板",
|
||||
"Toggle Search Box": "切換搜尋框",
|
||||
"Toggle Terminal Bottom Panel": "切換終端機底部面板",
|
||||
"Toggle Theme (Dark/Light)": "切換主題(深色/淺色)",
|
||||
"Toggle View Controls Bottom Panel": "切換檢視控制下方面板",
|
||||
"Toggle View Controls Bottom Panel": "切換檢視控制底部面板",
|
||||
"Toggle the Custom Nodes Manager": "切換自訂節點管理器",
|
||||
"Toggle the Custom Nodes Manager Progress Bar": "切換自訂節點管理器進度條",
|
||||
"Undo": "復原",
|
||||
@@ -889,7 +899,7 @@
|
||||
"advanced": "進階",
|
||||
"animation": "動畫",
|
||||
"api": "API",
|
||||
"api node": "API 節點",
|
||||
"api node": "api 節點",
|
||||
"attention_experiments": "注意力實驗",
|
||||
"audio": "音訊",
|
||||
"batch": "批次",
|
||||
@@ -926,12 +936,12 @@
|
||||
"photomaker": "photomaker",
|
||||
"postprocessing": "後處理",
|
||||
"preprocessors": "前處理器",
|
||||
"primitive": "基礎元件",
|
||||
"primitive": "基本元件",
|
||||
"samplers": "取樣器",
|
||||
"sampling": "取樣",
|
||||
"schedulers": "排程器",
|
||||
"scheduling": "排程",
|
||||
"sd": "SD",
|
||||
"sd": "sd",
|
||||
"sd3": "sd3",
|
||||
"sigmas": "西格瑪值",
|
||||
"stable_cascade": "stable_cascade",
|
||||
@@ -980,7 +990,7 @@
|
||||
"selectionToolbox": {
|
||||
"executeButton": {
|
||||
"disabledTooltip": "未選取任何輸出節點",
|
||||
"tooltip": "執行至選取的輸出節點(以橙色邊框標示)"
|
||||
"tooltip": "執行至選取的輸出節點(以橘色邊框標示)"
|
||||
}
|
||||
},
|
||||
"serverConfig": {
|
||||
@@ -1143,7 +1153,7 @@
|
||||
"Comfy": "Comfy",
|
||||
"Comfy-Desktop": "Comfy-Desktop",
|
||||
"ContextMenu": "右鍵選單",
|
||||
"Credits": "點數",
|
||||
"Credits": "製作團隊",
|
||||
"CustomColorPalettes": "自訂色彩調色盤",
|
||||
"DevMode": "開發者模式",
|
||||
"EditTokenWeight": "編輯權重",
|
||||
@@ -1185,7 +1195,7 @@
|
||||
"Workflow": "工作流程"
|
||||
},
|
||||
"shortcuts": {
|
||||
"essentials": "基本",
|
||||
"essentials": "基本功能",
|
||||
"keyboardShortcuts": "鍵盤快捷鍵",
|
||||
"manageShortcuts": "管理快捷鍵",
|
||||
"noKeybinding": "無快捷鍵",
|
||||
@@ -1233,6 +1243,7 @@
|
||||
"sortMode": "排序模式"
|
||||
},
|
||||
"openWorkflow": "在本機檔案系統中開啟工作流程",
|
||||
"outputExplorer": "輸出總覽",
|
||||
"queue": "佇列",
|
||||
"queueTab": {
|
||||
"backToAllTasks": "返回所有任務",
|
||||
@@ -1256,7 +1267,7 @@
|
||||
"deleteFailedTitle": "刪除失敗",
|
||||
"deleted": "工作流程已刪除",
|
||||
"dirtyClose": "下列檔案已被修改。您要在關閉前儲存它們嗎?",
|
||||
"dirtyCloseHint": "按住 Shift 可直接關閉不提示",
|
||||
"dirtyCloseHint": "按住 Shift 鍵可直接關閉而不提示",
|
||||
"dirtyCloseTitle": "儲存變更?",
|
||||
"workflowTreeType": {
|
||||
"bookmarks": "書籤",
|
||||
@@ -1279,15 +1290,15 @@
|
||||
"category": {
|
||||
"3D": "3D",
|
||||
"All": "所有範本",
|
||||
"Area Composition": "區域合成",
|
||||
"Area Composition": "區域構圖",
|
||||
"Audio": "音訊",
|
||||
"Basics": "基礎",
|
||||
"ComfyUI Examples": "ComfyUI 範例",
|
||||
"ControlNet": "ControlNet",
|
||||
"Custom Nodes": "自訂節點",
|
||||
"Flux": "Flux",
|
||||
"Image": "圖片",
|
||||
"Image API": "圖片 API",
|
||||
"Image": "影像",
|
||||
"Image API": "影像 API",
|
||||
"LLM API": "LLM API",
|
||||
"Upscaling": "放大",
|
||||
"Video": "影片",
|
||||
@@ -1303,96 +1314,96 @@
|
||||
"stable_zero123_example": "Stable Zero123"
|
||||
},
|
||||
"3D API": {
|
||||
"api_rodin_image_to_model": "Rodin:圖片轉模型",
|
||||
"api_rodin_image_to_model": "Rodin:影像轉模型",
|
||||
"api_rodin_multiview_to_model": "Rodin:多視角轉模型",
|
||||
"api_tripo_image_to_model": "Tripo:圖片轉模型",
|
||||
"api_tripo_image_to_model": "Tripo:影像轉模型",
|
||||
"api_tripo_multiview_to_model": "Tripo:多視角轉模型",
|
||||
"api_tripo_text_to_model": "Tripo:文字轉模型"
|
||||
},
|
||||
"Area Composition": {
|
||||
"area_composition": "區域合成",
|
||||
"area_composition_square_area_for_subject": "主體區域一致合成"
|
||||
"area_composition": "區域構圖",
|
||||
"area_composition_square_area_for_subject": "區域構圖主體方格"
|
||||
},
|
||||
"Audio": {
|
||||
"audio_ace_step_1_m2m_editing": "ACE Step v1 M2M 編輯",
|
||||
"audio_ace_step_1_t2a_instrumentals": "ACE-Step v1 文字轉純樂器音樂",
|
||||
"audio_ace_step_1_t2a_instrumentals": "ACE-Step v1 文字轉純樂器",
|
||||
"audio_ace_step_1_t2a_song": "ACE Step v1 文字轉歌曲",
|
||||
"audio_stable_audio_example": "Stable Audio"
|
||||
},
|
||||
"Basics": {
|
||||
"default": "圖片生成",
|
||||
"default": "影像生成",
|
||||
"embedding_example": "Embedding",
|
||||
"gligen_textbox_example": "Gligen Textbox",
|
||||
"image2image": "圖片轉圖片",
|
||||
"inpaint_example": "Inpaint",
|
||||
"gligen_textbox_example": "Gligen 文字框",
|
||||
"image2image": "影像轉影像",
|
||||
"inpaint_example": "修補",
|
||||
"inpaint_model_outpainting": "外延",
|
||||
"lora": "LoRA",
|
||||
"lora_multiple": "多重LoRA"
|
||||
"lora_multiple": "多重 LoRA"
|
||||
},
|
||||
"ControlNet": {
|
||||
"2_pass_pose_worship": "Pose ControlNet 2 Pass",
|
||||
"controlnet_example": "Scribble ControlNet",
|
||||
"depth_controlnet": "Depth ControlNet",
|
||||
"depth_t2i_adapter": "Depth T2I Adapter",
|
||||
"mixing_controlnets": "Mixing ControlNets"
|
||||
"2_pass_pose_worship": "姿勢 ControlNet 兩階段",
|
||||
"controlnet_example": "塗鴉 ControlNet",
|
||||
"depth_controlnet": "深度 ControlNet",
|
||||
"depth_t2i_adapter": "深度 T2I Adapter",
|
||||
"mixing_controlnets": "混合 ControlNets"
|
||||
},
|
||||
"Flux": {
|
||||
"flux_canny_model_example": "Flux Canny Model",
|
||||
"flux_depth_lora_example": "Flux Depth LoRA",
|
||||
"flux_canny_model_example": "Flux Canny 模型",
|
||||
"flux_depth_lora_example": "Flux 深度 LoRA",
|
||||
"flux_dev_checkpoint_example": "Flux Dev fp8",
|
||||
"flux_dev_full_text_to_image": "Flux Dev 完整文字轉圖",
|
||||
"flux_fill_inpaint_example": "Flux Inpaint",
|
||||
"flux_fill_outpaint_example": "Flux Outpaint",
|
||||
"flux_dev_full_text_to_image": "Flux Dev 完整文字轉影像",
|
||||
"flux_fill_inpaint_example": "Flux 修補",
|
||||
"flux_fill_outpaint_example": "Flux 外延",
|
||||
"flux_kontext_dev_basic": "Flux Kontext Dev(基礎)",
|
||||
"flux_kontext_dev_grouped": "Flux Kontext Dev(組合版)",
|
||||
"flux_redux_model_example": "Flux Redux Model",
|
||||
"flux_kontext_dev_grouped": "Flux Kontext Dev(分組)",
|
||||
"flux_redux_model_example": "Flux Redux 模型",
|
||||
"flux_schnell": "Flux Schnell fp8",
|
||||
"flux_schnell_full_text_to_image": "Flux Schnell 完整文字轉圖"
|
||||
"flux_schnell_full_text_to_image": "Flux Schnell 完整文字轉影像"
|
||||
},
|
||||
"Image": {
|
||||
"hidream_e1_full": "HiDream E1 完整版",
|
||||
"hidream_e1_full": "HiDream E1 Full",
|
||||
"hidream_i1_dev": "HiDream I1 Dev",
|
||||
"hidream_i1_fast": "HiDream I1 Fast",
|
||||
"hidream_i1_full": "HiDream I1 Full",
|
||||
"image_chroma_text_to_image": "Chroma 文字轉圖",
|
||||
"image_cosmos_predict2_2B_t2i": "Cosmos Predict2 2B 文字轉圖",
|
||||
"image_chroma_text_to_image": "Chroma 文字轉影像",
|
||||
"image_cosmos_predict2_2B_t2i": "Cosmos Predict2 2B T2I",
|
||||
"image_lotus_depth_v1_1": "Lotus Depth",
|
||||
"image_omnigen2_image_edit": "OmniGen2 圖片編輯",
|
||||
"image_omnigen2_t2i": "OmniGen2 文字轉圖",
|
||||
"sd3_5_large_blur": "SD3.5 Large Blur",
|
||||
"sd3_5_large_canny_controlnet_example": "SD3.5 Large Canny ControlNet",
|
||||
"sd3_5_large_depth": "SD3.5 Large Depth",
|
||||
"sd3_5_simple_example": "SD3.5 Simple",
|
||||
"sdxl_refiner_prompt_example": "SDXL Refiner Prompt",
|
||||
"sdxl_revision_text_prompts": "SDXL Revision Text Prompts",
|
||||
"image_omnigen2_image_edit": "OmniGen2 影像編輯",
|
||||
"image_omnigen2_t2i": "OmniGen2 文字轉影像",
|
||||
"sd3_5_large_blur": "SD3.5 大型模糊",
|
||||
"sd3_5_large_canny_controlnet_example": "SD3.5 大型 Canny ControlNet",
|
||||
"sd3_5_large_depth": "SD3.5 大型深度",
|
||||
"sd3_5_simple_example": "SD3.5 簡易",
|
||||
"sdxl_refiner_prompt_example": "SDXL 精煉提示",
|
||||
"sdxl_revision_text_prompts": "SDXL Revision 文字提示",
|
||||
"sdxl_revision_zero_positive": "SDXL Revision Zero Positive",
|
||||
"sdxl_simple_example": "SDXL Simple",
|
||||
"sdxl_simple_example": "SDXL 簡易",
|
||||
"sdxlturbo_example": "SDXL Turbo"
|
||||
},
|
||||
"Image API": {
|
||||
"api_bfl_flux_1_kontext_max_image": "BFL Flux.1 Kontext Max",
|
||||
"api_bfl_flux_1_kontext_multiple_images_input": "BFL Flux.1 Kontext 多圖輸入",
|
||||
"api_bfl_flux_1_kontext_multiple_images_input": "BFL Flux.1 Kontext 多影像輸入",
|
||||
"api_bfl_flux_1_kontext_pro_image": "BFL Flux.1 Kontext Pro",
|
||||
"api_bfl_flux_pro_t2i": "BFL Flux 1.1[pro] Ultra Text to Image",
|
||||
"api_ideogram_v3_t2i": "Ideogram V3 Text to Image",
|
||||
"api_luma_photon_i2i": "Luma Photon Image to Image",
|
||||
"api_luma_photon_style_ref": "Luma Photon Style Reference",
|
||||
"api_bfl_flux_pro_t2i": "BFL Flux[Pro]:文字轉影像",
|
||||
"api_ideogram_v3_t2i": "Ideogram V3:文字轉影像",
|
||||
"api_luma_photon_i2i": "Luma Photon:影像轉影像",
|
||||
"api_luma_photon_style_ref": "Luma Photon:風格參考",
|
||||
"api_openai_dall_e_2_inpaint": "OpenAI:Dall-E 2 修補",
|
||||
"api_openai_dall_e_2_t2i": "OpenAI:Dall-E 2 文字轉圖",
|
||||
"api_openai_dall_e_3_t2i": "OpenAI:Dall-E 3 文字轉圖",
|
||||
"api_openai_image_1_i2i": "OpenAI Image-1 Image to Image",
|
||||
"api_openai_image_1_inpaint": "OpenAI Image-1 Inpaint",
|
||||
"api_openai_image_1_multi_inputs": "OpenAI Image-1 Multi Inputs",
|
||||
"api_openai_image_1_t2i": "OpenAI Image-1 Text to Image",
|
||||
"api_recraft_image_gen_with_color_control": "Recraft Color Control Image Generation",
|
||||
"api_recraft_image_gen_with_style_control": "Recraft Style Control Image Generation",
|
||||
"api_recraft_vector_gen": "Recraft Vector Generation",
|
||||
"api_runway_reference_to_image": "Runway:參考圖轉圖",
|
||||
"api_runway_text_to_image": "Runway:文字轉圖",
|
||||
"api_stability_ai_i2i": "Stability AI:圖轉圖",
|
||||
"api_stability_ai_sd3_5_i2i": "Stability AI:SD3.5 圖轉圖",
|
||||
"api_stability_ai_sd3_5_t2i": "Stability AI:SD3.5 文字轉圖",
|
||||
"api_stability_ai_stable_image_ultra_t2i": "Stability AI:Stable Image Ultra 文字轉圖"
|
||||
"api_openai_dall_e_2_t2i": "OpenAI:Dall-E 2 文字轉影像",
|
||||
"api_openai_dall_e_3_t2i": "OpenAI:Dall-E 3 文字轉影像",
|
||||
"api_openai_image_1_i2i": "OpenAI:GPT-Image-1 影像轉影像",
|
||||
"api_openai_image_1_inpaint": "OpenAI:GPT-Image-1 修補",
|
||||
"api_openai_image_1_multi_inputs": "OpenAI:GPT-Image-1 多重輸入",
|
||||
"api_openai_image_1_t2i": "OpenAI:GPT-Image-1 文字轉影像",
|
||||
"api_recraft_image_gen_with_color_control": "Recraft:色彩控制影像生成",
|
||||
"api_recraft_image_gen_with_style_control": "Recraft:風格控制影像生成",
|
||||
"api_recraft_vector_gen": "Recraft:向量生成",
|
||||
"api_runway_reference_to_image": "Runway:參考轉影像",
|
||||
"api_runway_text_to_image": "Runway:文字轉影像",
|
||||
"api_stability_ai_i2i": "Stability AI:影像轉影像",
|
||||
"api_stability_ai_sd3_5_i2i": "Stability AI:SD3.5 影像轉影像",
|
||||
"api_stability_ai_sd3_5_t2i": "Stability AI:SD3.5 文字轉影像",
|
||||
"api_stability_ai_stable_image_ultra_t2i": "Stability AI:Stable Image Ultra 文字轉影像"
|
||||
},
|
||||
"LLM API": {
|
||||
"api_google_gemini": "Google Gemini:聊天",
|
||||
@@ -1400,23 +1411,23 @@
|
||||
},
|
||||
"Upscaling": {
|
||||
"esrgan_example": "ESRGAN",
|
||||
"hiresfix_esrgan_workflow": "HiresFix ESRGAN Workflow",
|
||||
"hiresfix_latent_workflow": "Upscale",
|
||||
"latent_upscale_different_prompt_model": "Latent Upscale Different Prompt Model"
|
||||
"hiresfix_esrgan_workflow": "HiresFix ESRGAN 工作流",
|
||||
"hiresfix_latent_workflow": "放大",
|
||||
"latent_upscale_different_prompt_model": "Latent 放大不同提示模型"
|
||||
},
|
||||
"Video": {
|
||||
"hunyuan_video_text_to_video": "Hunyuan Video Text to Video",
|
||||
"image_to_video": "SVD Image to Video",
|
||||
"image_to_video_wan": "Wan 2.1 Image to Video",
|
||||
"ltxv_image_to_video": "LTXV Image to Video",
|
||||
"ltxv_text_to_video": "LTXV Text to Video",
|
||||
"mochi_text_to_video_example": "Mochi Text to Video",
|
||||
"text_to_video_wan": "Wan 2.1 Text to Video",
|
||||
"txt_to_image_to_video": "SVD Text to Image to Video",
|
||||
"hunyuan_video_text_to_video": "Hunyuan 影片文字轉影片",
|
||||
"image_to_video": "SVD 影像轉影片",
|
||||
"image_to_video_wan": "Wan 2.1 影像轉影片",
|
||||
"ltxv_image_to_video": "LTXV 影像轉影片",
|
||||
"ltxv_text_to_video": "LTXV 文字轉影片",
|
||||
"mochi_text_to_video_example": "Mochi 文字轉影片",
|
||||
"text_to_video_wan": "Wan 2.1 文字轉影片",
|
||||
"txt_to_image_to_video": "SVD 文字轉影像再轉影片",
|
||||
"video_cosmos_predict2_2B_video2world_480p_16fps": "Cosmos Predict2 2B Video2World 480p 16fps",
|
||||
"video_wan2_1_fun_camera_v1_1_14B": "Wan 2.1 Fun Camera 14B",
|
||||
"video_wan2_1_fun_camera_v1_1_1_3B": "Wan 2.1 Fun Camera 1.3B",
|
||||
"video_wan_vace_14B_ref2v": "Wan VACE 參考圖轉影片",
|
||||
"video_wan_vace_14B_ref2v": "Wan VACE 參考轉影片",
|
||||
"video_wan_vace_14B_t2v": "Wan VACE 文字轉影片",
|
||||
"video_wan_vace_14B_v2v": "Wan VACE 控制影片",
|
||||
"video_wan_vace_flf2v": "Wan VACE 首尾影格",
|
||||
@@ -1424,179 +1435,179 @@
|
||||
"video_wan_vace_outpainting": "Wan VACE 外延",
|
||||
"wan2_1_flf2v_720_f16": "Wan 2.1 FLF2V 720p F16",
|
||||
"wan2_1_fun_control": "Wan 2.1 ControlNet",
|
||||
"wan2_1_fun_inp": "Wan 2.1 Inpainting"
|
||||
"wan2_1_fun_inp": "Wan 2.1 修補"
|
||||
},
|
||||
"Video API": {
|
||||
"api_hailuo_minimax_i2v": "MiniMax Image to Video",
|
||||
"api_hailuo_minimax_i2v": "MiniMax:影像轉影片",
|
||||
"api_hailuo_minimax_t2v": "MiniMax:文字轉影片",
|
||||
"api_kling_effects": "Kling:影片特效",
|
||||
"api_kling_flf": "Kling:首尾影格",
|
||||
"api_kling_i2v": "Kling Image to Video",
|
||||
"api_luma_i2v": "Luma Image to Video",
|
||||
"api_kling_flf": "Kling:FLF2V",
|
||||
"api_kling_i2v": "Kling:影像轉影片",
|
||||
"api_luma_i2v": "Luma:影像轉影片",
|
||||
"api_luma_t2v": "Luma:文字轉影片",
|
||||
"api_moonvalley_image_to_video": "Moonvalley:圖片轉影片",
|
||||
"api_moonvalley_image_to_video": "Moonvalley:影像轉影片",
|
||||
"api_moonvalley_text_to_video": "Moonvalley:文字轉影片",
|
||||
"api_pika_i2v": "Pika:圖片轉影片",
|
||||
"api_pika_scene": "Pika Scenes: Images to Video",
|
||||
"api_pixverse_i2v": "PixVerse:圖片轉影片",
|
||||
"api_pixverse_t2v": "PixVerse Text to Video",
|
||||
"api_pixverse_template_i2v": "PixVerse Template Effects: Image to Video",
|
||||
"api_pika_i2v": "Pika:影像轉影片",
|
||||
"api_pika_scene": "Pika Scenes:多影像轉影片",
|
||||
"api_pixverse_i2v": "PixVerse:影像轉影片",
|
||||
"api_pixverse_t2v": "PixVerse:文字轉影片",
|
||||
"api_pixverse_template_i2v": "PixVerse 範本:影像轉影片",
|
||||
"api_runway_first_last_frame": "Runway:首尾影格轉影片",
|
||||
"api_runway_gen3a_turbo_image_to_video": "Runway:Gen3a Turbo 圖片轉影片",
|
||||
"api_runway_gen4_turo_image_to_video": "Runway:Gen4 Turbo 圖片轉影片",
|
||||
"api_veo2_i2v": "Veo2 Image to Video"
|
||||
"api_runway_gen3a_turbo_image_to_video": "Runway:Gen3a Turbo 影像轉影片",
|
||||
"api_runway_gen4_turo_image_to_video": "Runway:Gen4 Turbo 影像轉影片",
|
||||
"api_veo2_i2v": "Veo2:影像轉影片"
|
||||
}
|
||||
},
|
||||
"templateDescription": {
|
||||
"3D": {
|
||||
"3d_hunyuan3d_image_to_model": "使用 Hunyuan3D 2.0,單張圖片生成 3D 模型。",
|
||||
"3d_hunyuan3d_multiview_to_model": "使用 Hunyuan3D 2.0 MV,多視角生成 3D 模型。",
|
||||
"3d_hunyuan3d_multiview_to_model_turbo": "使用 Hunyuan3D 2.0 MV Turbo,多視角快速生成 3D 模型。",
|
||||
"stable_zero123_example": "由單張圖片產生 3D 視角。"
|
||||
"3d_hunyuan3d_image_to_model": "使用 Hunyuan3D 2.0 由單張影像生成 3D 模型。",
|
||||
"3d_hunyuan3d_multiview_to_model": "使用 Hunyuan3D 2.0 MV 由多視角生成 3D 模型。",
|
||||
"3d_hunyuan3d_multiview_to_model_turbo": "使用 Hunyuan3D 2.0 MV Turbo 由多視角生成 3D 模型。",
|
||||
"stable_zero123_example": "使用 Stable Zero123 由單張影像生成 3D 視角。"
|
||||
},
|
||||
"3D API": {
|
||||
"api_rodin_image_to_model": "使用 Rodin AI,單張照片生成細緻 3D 模型。",
|
||||
"api_rodin_multiview_to_model": "利用 Rodin 多角度重建,雕塑完整 3D 模型。",
|
||||
"api_tripo_image_to_model": "使用 Tripo 引擎,將 2D 圖片生成專業 3D 素材。",
|
||||
"api_tripo_multiview_to_model": "利用 Tripo 進階掃描,從多角度建立 3D 模型。",
|
||||
"api_tripo_text_to_model": "用 Tripo 文字驅動建模,創作 3D 物件。"
|
||||
"api_rodin_image_to_model": "使用 Rodin AI 由單張照片生成細緻 3D 模型。",
|
||||
"api_rodin_multiview_to_model": "使用 Rodin 多角度重建雕塑完整 3D 模型。",
|
||||
"api_tripo_image_to_model": "使用 Tripo 引擎由 2D 影像生成專業 3D 素材。",
|
||||
"api_tripo_multiview_to_model": "使用 Tripo 進階掃描器由多角度生成 3D 模型。",
|
||||
"api_tripo_text_to_model": "使用 Tripo 文字驅動建模,創作 3D 物件。"
|
||||
},
|
||||
"Area Composition": {
|
||||
"area_composition": "以區域控制圖片構圖。",
|
||||
"area_composition_square_area_for_subject": "建立主體一致擺放。"
|
||||
"area_composition": "以區域控制構圖生成影像。",
|
||||
"area_composition_square_area_for_subject": "以區域構圖確保主體位置一致生成影像。"
|
||||
},
|
||||
"Audio": {
|
||||
"audio_ace_step_1_m2m_editing": "使用 ACE-Step v1 M2M,編輯現有歌曲,變更風格與歌詞。",
|
||||
"audio_ace_step_1_t2a_instrumentals": "使用 ACE-Step v1,根據文字提示產生純樂器音樂。",
|
||||
"audio_ace_step_1_t2a_song": "使用 ACE-Step v1,根據文字提示產生含人聲歌曲,支援多語言與風格自訂。",
|
||||
"audio_stable_audio_example": "使用 Stable Audio,根據文字提示產生音訊。"
|
||||
"audio_ace_step_1_m2m_editing": "使用 ACE-Step v1 M2M 編輯現有歌曲,變更風格與歌詞。",
|
||||
"audio_ace_step_1_t2a_instrumentals": "使用 ACE-Step v1 由文字提示生成純樂器音樂。",
|
||||
"audio_ace_step_1_t2a_song": "使用 ACE-Step v1 由文字提示生成歌曲,支援多語言與風格自訂。",
|
||||
"audio_stable_audio_example": "使用 Stable Audio 由文字提示生成音訊。"
|
||||
},
|
||||
"Basics": {
|
||||
"default": "根據文字描述產生圖片。",
|
||||
"embedding_example": "使用文字反轉技術以保持風格一致。",
|
||||
"gligen_textbox_example": "指定物件的位置與大小。",
|
||||
"image2image": "使用文字提示轉換現有圖片。",
|
||||
"inpaint_example": "無縫編輯圖片的特定區域。",
|
||||
"default": "從文字提示生成影像。",
|
||||
"embedding_example": "利用文本反轉生成一致風格的影像。",
|
||||
"gligen_textbox_example": "使用文字框精確放置物件生成影像。",
|
||||
"image2image": "使用文字提示轉換現有影像。",
|
||||
"inpaint_example": "無縫編輯影像的特定區域。",
|
||||
"inpaint_model_outpainting": "將影像延伸至原始邊界之外。",
|
||||
"lora": "套用 LoRA 模型以獲得特殊風格或主題。",
|
||||
"lora_multiple": "結合多個 LoRA 模型創造獨特效果。"
|
||||
"lora": "使用 LoRA 模型生成特定風格或主題的影像。",
|
||||
"lora_multiple": "結合多個 LoRA 模型生成影像。"
|
||||
},
|
||||
"ControlNet": {
|
||||
"2_pass_pose_worship": "由姿勢參考產生圖片。",
|
||||
"controlnet_example": "以參考圖控制圖片生成。",
|
||||
"depth_controlnet": "產生深度感知圖片。",
|
||||
"depth_t2i_adapter": "使用 T2I adapter 快速產生深度感知圖片。",
|
||||
"mixing_controlnets": "結合多個 ControlNet 模型。"
|
||||
"2_pass_pose_worship": "使用 ControlNet 以姿勢參考引導生成影像。",
|
||||
"controlnet_example": "使用 ControlNet 以塗鴉參考影像引導生成影像。",
|
||||
"depth_controlnet": "使用 ControlNet 以深度資訊引導生成影像。",
|
||||
"depth_t2i_adapter": "使用 T2I adapter 以深度資訊引導生成影像。",
|
||||
"mixing_controlnets": "結合多個 ControlNet 模型生成影像。"
|
||||
},
|
||||
"Flux": {
|
||||
"flux_canny_model_example": "從邊緣偵測產生圖片。",
|
||||
"flux_depth_lora_example": "結合深度感知 LoRA 產生圖片。",
|
||||
"flux_dev_checkpoint_example": "使用 Flux 開發模型產生圖片。",
|
||||
"flux_dev_full_text_to_image": "使用 Flux Dev 完整版本產生高品質影像。需較大 VRAM 與多個模型檔案,但能提供最佳提示遵循能力與影像品質。",
|
||||
"flux_fill_inpaint_example": "填補圖片缺失區域。",
|
||||
"flux_fill_outpaint_example": "使用 Flux 外延技術延伸圖片。",
|
||||
"flux_canny_model_example": "使用 Flux Canny 邊緣偵測引導生成影像。",
|
||||
"flux_depth_lora_example": "使用 Flux LoRA 深度資訊引導生成影像。",
|
||||
"flux_dev_checkpoint_example": "使用 Flux Dev fp8 量化版生成影像。適合顯存有限的裝置,只需一個模型檔案,但畫質略低於完整版。",
|
||||
"flux_dev_full_text_to_image": "使用 Flux Dev 完整版生成高品質影像。需較大顯存及多個模型檔案,但提示遵循度與畫質最佳。",
|
||||
"flux_fill_inpaint_example": "使用 Flux 修補影像缺失區域。",
|
||||
"flux_fill_outpaint_example": "使用 Flux 將影像延伸至邊界之外。",
|
||||
"flux_kontext_dev_basic": "使用 Flux Kontext 編輯影像,完整節點可見,適合學習工作流程。",
|
||||
"flux_kontext_dev_grouped": "Flux Kontext 精簡版,節點分組,工作區更整潔。",
|
||||
"flux_redux_model_example": "從參考圖片轉移風格,指引 Flux 生成圖片。",
|
||||
"flux_schnell": "使用 Flux Schnell 快速產生圖片。",
|
||||
"flux_schnell_full_text_to_image": "使用 Flux Schnell 完整版快速產生影像。採用 Apache2.0 授權,僅需 4 步驟即可生成並維持良好畫質。"
|
||||
"flux_redux_model_example": "使用 Flux Redux 參考影像風格轉換生成影像。",
|
||||
"flux_schnell": "使用 Flux Schnell fp8 量化版快速生成影像。適合低階硬體,只需 4 步即可生成影像。",
|
||||
"flux_schnell_full_text_to_image": "使用 Flux Schnell 完整版快速生成影像。採用 Apache2.0 授權,只需 4 步即可維持良好畫質。"
|
||||
},
|
||||
"Image": {
|
||||
"hidream_e1_full": "使用 HiDream E1 編輯圖片。",
|
||||
"hidream_i1_dev": "使用 HiDream I1 Dev 產生圖片。",
|
||||
"hidream_i1_fast": "使用 HiDream I1 快速產生圖片。",
|
||||
"hidream_i1_full": "使用 HiDream I1 產生圖片。",
|
||||
"image_chroma_text_to_image": "Chroma 由 flux 修改而來,架構上有部分變動。",
|
||||
"image_cosmos_predict2_2B_t2i": "使用 Cosmos-Predict2 2B T2I 產生物理精確、高保真且細節豐富的影像。",
|
||||
"image_lotus_depth_v1_1": "在 ComfyUI 執行 Lotus Depth,進行零樣本、高效率的單眼深度估測,保留高細節。",
|
||||
"image_omnigen2_image_edit": "利用 OmniGen2 進階影像編輯能力與文字渲染支援,透過自然語言指令編輯影像。",
|
||||
"image_omnigen2_t2i": "使用 OmniGen2 的統一 7B 多模態模型與雙路架構,根據文字提示產生高品質影像。",
|
||||
"sd3_5_large_blur": "使用 SD 3.5 由模糊參考圖產生圖片。",
|
||||
"sd3_5_large_canny_controlnet_example": "使用邊緣偵測搭配 SD 3.5 指引圖片生成。",
|
||||
"sd3_5_large_depth": "使用 SD 3.5 產生深度感知圖片。",
|
||||
"sd3_5_simple_example": "使用 SD 3.5 產生圖片。",
|
||||
"sdxl_refiner_prompt_example": "使用精煉器增強 SDXL 輸出。",
|
||||
"sdxl_revision_text_prompts": "將參考圖概念轉移至 SDXL 生成流程。",
|
||||
"sdxl_revision_zero_positive": "結合文字提示與參考圖指引 SDXL 生成圖片。",
|
||||
"sdxl_simple_example": "使用 SDXL 產生高品質圖片。",
|
||||
"sdxlturbo_example": "使用 SDXL Turbo 一步產生圖片。"
|
||||
"hidream_e1_full": "使用 HiDream E1 - 專業自然語言影像編輯模型進行影像編輯。",
|
||||
"hidream_i1_dev": "使用 HiDream I1 Dev - 平衡版,28 步推理,適合中階硬體生成影像。",
|
||||
"hidream_i1_fast": "使用 HiDream I1 Fast - 輕量版,16 步推理,適合低階硬體快速預覽。",
|
||||
"hidream_i1_full": "使用 HiDream I1 Full - 完整版,50 步推理,產出最高品質影像。",
|
||||
"image_chroma_text_to_image": "Chroma 由 flux 修改,架構有所變動。",
|
||||
"image_cosmos_predict2_2B_t2i": "使用 Cosmos-Predict2 2B T2I,生成物理精確、高保真、細節豐富的影像。",
|
||||
"image_lotus_depth_v1_1": "在 ComfyUI 執行 Lotus Depth,零樣本高效單目深度估測,細節保留佳。",
|
||||
"image_omnigen2_image_edit": "利用 OmniGen2 進階影像編輯與文字渲染,透過自然語言指令編輯影像。",
|
||||
"image_omnigen2_t2i": "使用 OmniGen2 統一 7B 多模態雙路架構,從文字提示生成高品質影像。",
|
||||
"sd3_5_large_blur": "使用 SD 3.5 模糊參考影像引導生成影像。",
|
||||
"sd3_5_large_canny_controlnet_example": "使用 SD 3.5 Canny ControlNet 邊緣偵測引導生成影像。",
|
||||
"sd3_5_large_depth": "使用 SD 3.5 深度資訊引導生成影像。",
|
||||
"sd3_5_simple_example": "使用 SD 3.5 生成影像。",
|
||||
"sdxl_refiner_prompt_example": "使用精煉模型提升 SDXL 影像品質。",
|
||||
"sdxl_revision_text_prompts": "使用 SDXL Revision 參考影像概念生成影像。",
|
||||
"sdxl_revision_zero_positive": "使用 SDXL Revision 結合文字提示與參考影像生成影像。",
|
||||
"sdxl_simple_example": "使用 SDXL 生成高品質影像。",
|
||||
"sdxlturbo_example": "使用 SDXL Turbo 一步生成影像。"
|
||||
},
|
||||
"Image API": {
|
||||
"api_bfl_flux_1_kontext_max_image": "使用 Flux.1 Kontext max 編輯圖片。",
|
||||
"api_bfl_flux_1_kontext_multiple_images_input": "輸入多張圖片並用 Flux.1 Kontext 編輯。",
|
||||
"api_bfl_flux_1_kontext_pro_image": "使用 Flux.1 Kontext pro 編輯圖片。",
|
||||
"api_bfl_flux_pro_t2i": "使用 FLUX.1 [pro] 產生優異提示遵循、視覺品質、細節與多樣化圖片。",
|
||||
"api_ideogram_v3_t2i": "產生高品質圖片與提示對齊、寫實感與文字渲染。可製作專業標誌、宣傳海報、登陸頁概念、產品攝影等。輕鬆打造複雜背景、精確光影與真實環境細節的空間構圖。",
|
||||
"api_luma_photon_i2i": "結合圖片與提示指引圖片生成。",
|
||||
"api_luma_photon_style_ref": "精確控制套用與混合風格參考。Luma Photon 捕捉每張參考圖的精髓,讓你結合不同視覺元素並維持專業品質。",
|
||||
"api_openai_dall_e_2_inpaint": "使用 OpenAI Dall-E 2 API 進行圖片修補編輯。",
|
||||
"api_openai_dall_e_2_t2i": "使用 OpenAI Dall-E 2 API,根據文字提示產生圖片。",
|
||||
"api_openai_dall_e_3_t2i": "使用 OpenAI Dall-E 3 API,根據文字提示產生圖片。",
|
||||
"api_openai_image_1_i2i": "使用 GPT Image 1 API 由圖片產生圖片。",
|
||||
"api_openai_image_1_inpaint": "使用 GPT Image 1 API 修補圖片。",
|
||||
"api_openai_image_1_multi_inputs": "使用 GPT Image 1 API 多重輸入產生圖片。",
|
||||
"api_openai_image_1_t2i": "使用 GPT Image 1 API 根據文字描述產生圖片。",
|
||||
"api_recraft_image_gen_with_color_control": "建立自訂調色盤以多圖共用,或為每張照片手動挑選顏色。配合品牌色彩,打造專屬視覺風格。",
|
||||
"api_recraft_image_gen_with_style_control": "以視覺範例控制風格、對齊位置並微調物件。儲存並分享風格,確保品牌一致性。",
|
||||
"api_recraft_vector_gen": "從文字提示生成向量圖,Recraft AI 向量生成器可產出最佳品質的標誌、海報、圖示、廣告、橫幅與模型。以高品質 SVG 完善設計,數秒內為你的應用或網站創建品牌向量插圖。",
|
||||
"api_runway_reference_to_image": "利用 Runway AI,根據參考風格與構圖產生新圖片。",
|
||||
"api_runway_text_to_image": "使用 Runway AI 模型,根據文字提示產生高品質圖片。",
|
||||
"api_stability_ai_i2i": "使用 Stability AI 進行高品質圖片生成,適合專業編輯與風格轉換。",
|
||||
"api_stability_ai_sd3_5_i2i": "產生高品質、極佳提示遵循度的圖片。1 百萬像素解析度,專業用途首選。",
|
||||
"api_stability_ai_sd3_5_t2i": "產生高品質、極佳提示遵循度的圖片。1 百萬像素解析度,專業用途首選。",
|
||||
"api_stability_ai_stable_image_ultra_t2i": "產生高品質、極佳提示遵循度的圖片。1 百萬像素解析度,專業用途首選。"
|
||||
"api_bfl_flux_1_kontext_max_image": "使用 Flux.1 Kontext max 編輯影像。",
|
||||
"api_bfl_flux_1_kontext_multiple_images_input": "輸入多張影像並用 Flux.1 Kontext 編輯。",
|
||||
"api_bfl_flux_1_kontext_pro_image": "使用 Flux.1 Kontext pro 編輯影像。",
|
||||
"api_bfl_flux_pro_t2i": "使用 FLUX.1 Pro 生成提示遵循度與視覺品質極佳的影像。",
|
||||
"api_ideogram_v3_t2i": "使用 Ideogram V3 生成專業品質、提示對齊、寫實與文字渲染影像。",
|
||||
"api_luma_photon_i2i": "結合影像與提示詞引導影像生成。",
|
||||
"api_luma_photon_style_ref": "結合風格參考與精確控制生成影像。",
|
||||
"api_openai_dall_e_2_inpaint": "使用 OpenAI Dall-E 2 API 進行影像修補編輯。",
|
||||
"api_openai_dall_e_2_t2i": "使用 OpenAI Dall-E 2 API 從文字提示生成影像。",
|
||||
"api_openai_dall_e_3_t2i": "使用 OpenAI Dall-E 3 API 從文字提示生成影像。",
|
||||
"api_openai_image_1_i2i": "使用 OpenAI GPT Image 1 API 從輸入影像生成新影像。",
|
||||
"api_openai_image_1_inpaint": "使用 OpenAI GPT Image 1 API 進行影像修補編輯。",
|
||||
"api_openai_image_1_multi_inputs": "使用 OpenAI GPT Image 1 API 從多重輸入生成影像。",
|
||||
"api_openai_image_1_t2i": "使用 OpenAI GPT Image 1 API 從文字提示生成影像。",
|
||||
"api_recraft_image_gen_with_color_control": "自訂色板與品牌視覺生成影像,使用 Recraft。",
|
||||
"api_recraft_image_gen_with_style_control": "以視覺範例控制風格、對齊位置、微調物件。儲存並分享風格,確保品牌一致性。",
|
||||
"api_recraft_vector_gen": "使用 Recraft AI 向量生成器,從文字提示生成高品質向量影像。",
|
||||
"api_runway_reference_to_image": "使用 Runway AI 根據參考風格與構圖生成新影像。",
|
||||
"api_runway_text_to_image": "使用 Runway AI 模型從文字提示生成高品質影像。",
|
||||
"api_stability_ai_i2i": "使用 Stability AI 進行高品質影像生成,適合專業編輯與風格轉換。",
|
||||
"api_stability_ai_sd3_5_i2i": "生成高品質、提示遵循度佳的影像。1 百萬像素,專業用途首選。",
|
||||
"api_stability_ai_sd3_5_t2i": "生成高品質、提示遵循度佳的影像。1 百萬像素,專業用途首選。",
|
||||
"api_stability_ai_stable_image_ultra_t2i": "生成高品質、提示遵循度佳的影像。1 百萬像素,專業用途首選。"
|
||||
},
|
||||
"LLM API": {
|
||||
"api_google_gemini": "體驗 Google Gemini 多模態 AI 與推理能力。",
|
||||
"api_openai_chat": "與 OpenAI 進階語言模型互動,展開智慧對話。"
|
||||
"api_google_gemini": "體驗 Google Gemini 多模態 AI 推理能力。",
|
||||
"api_openai_chat": "與 OpenAI 進階語言模型互動對話。"
|
||||
},
|
||||
"Upscaling": {
|
||||
"esrgan_example": "使用放大模型提升圖片品質。",
|
||||
"hiresfix_esrgan_workflow": "在中間步驟使用放大模型。",
|
||||
"hiresfix_latent_workflow": "在 latent 空間提升圖片品質。",
|
||||
"latent_upscale_different_prompt_model": "跨多次處理放大並更換提示。"
|
||||
"esrgan_example": "使用 ESRGAN 模型放大影像並提升品質。",
|
||||
"hiresfix_esrgan_workflow": "在中間生成步驟中結合 ESRGAN 模型放大影像。",
|
||||
"hiresfix_latent_workflow": "在 latent 空間提升影像品質進行放大。",
|
||||
"latent_upscale_different_prompt_model": "跨生成階段變更提示詞同時放大影像。"
|
||||
},
|
||||
"Video": {
|
||||
"hunyuan_video_text_to_video": "使用 Hunyuan 模型產生影片。",
|
||||
"image_to_video": "將圖片轉換為動畫影片。",
|
||||
"image_to_video_wan": "快速將圖片轉換為影片。",
|
||||
"ltxv_image_to_video": "將靜態圖片轉換為影片。",
|
||||
"ltxv_text_to_video": "根據文字描述產生影片。",
|
||||
"mochi_text_to_video_example": "使用 Mochi 模型產生影片。",
|
||||
"text_to_video_wan": "快速將文字描述轉換為影片。",
|
||||
"txt_to_image_to_video": "先由文字產生圖片,再轉換為影片。",
|
||||
"video_cosmos_predict2_2B_video2world_480p_16fps": "使用 Cosmos-Predict2 2B Video2World 產生物理精確、高保真且一致的影片模擬。",
|
||||
"video_wan2_1_fun_camera_v1_1_14B": "使用完整 14B 模型,進階鏡頭控制產生高品質影片。",
|
||||
"video_wan2_1_fun_camera_v1_1_1_3B": "使用 Wan 2.1 Fun Camera 1.3B 模型,產生具電影感鏡頭運動的動態影片。",
|
||||
"video_wan_vace_14B_ref2v": "根據參考圖片產生風格與內容一致的影片。適合風格一致的影片生成。",
|
||||
"video_wan_vace_14B_t2v": "將文字描述轉換為高品質影片。支援 480p 與 720p,採用 VACE-14B 模型。",
|
||||
"video_wan_vace_14B_v2v": "透過控制輸入影片與參考圖片,使用 Wan VACE 產生影片。",
|
||||
"video_wan_vace_flf2v": "自訂起始與結束畫面,產生平滑影片過渡。支援自定義關鍵影格序列。",
|
||||
"video_wan_vace_inpainting": "編輯影片中特定區域,同時保留周圍內容。適合物件移除或替換。",
|
||||
"video_wan_vace_outpainting": "使用 Wan VACE 外延功能,擴展影片尺寸產生延伸影片。",
|
||||
"wan2_1_flf2v_720_f16": "透過控制首尾影格產生影片。",
|
||||
"wan2_1_fun_control": "以姿勢、深度、邊緣等控制影片生成。",
|
||||
"wan2_1_fun_inp": "從起始與結束影格產生影片。"
|
||||
"hunyuan_video_text_to_video": "使用 Hunyuan 模型由文字提示生成影片。",
|
||||
"image_to_video": "由靜態影像生成影片。",
|
||||
"image_to_video_wan": "使用 Wan 2.1 由影像生成影片。",
|
||||
"ltxv_image_to_video": "由靜態影像生成影片。",
|
||||
"ltxv_text_to_video": "由文字提示生成影片。",
|
||||
"mochi_text_to_video_example": "使用 Mochi 模型由文字提示生成影片。",
|
||||
"text_to_video_wan": "使用 Wan 2.1 由文字提示生成影片。",
|
||||
"txt_to_image_to_video": "先由文字生成影像,再生成影片。",
|
||||
"video_cosmos_predict2_2B_video2world_480p_16fps": "使用 Cosmos-Predict2 2B Video2World 生成物理精確、高保真且一致的影片模擬。",
|
||||
"video_wan2_1_fun_camera_v1_1_14B": "使用 14B 完整版進階鏡頭控制生成高品質影片。",
|
||||
"video_wan2_1_fun_camera_v1_1_1_3B": "使用 Wan 2.1 Fun Camera 1.3B 生成具電影感鏡頭運動的動態影片。",
|
||||
"video_wan_vace_14B_ref2v": "根據參考影像生成風格一致的影片,適合風格一致性需求。",
|
||||
"video_wan_vace_14B_t2v": "將文字描述轉換為高品質影片。VACE-14B 支援 480p 與 720p。",
|
||||
"video_wan_vace_14B_v2v": "使用 Wan VACE 控制輸入影片與參考影像生成影片。",
|
||||
"video_wan_vace_flf2v": "自訂起始與結束影格,生成平滑影片過渡,支援自訂關鍵影格序列。",
|
||||
"video_wan_vace_inpainting": "編輯影片特定區域,同時保留周圍內容,適合物件移除或替換。",
|
||||
"video_wan_vace_outpainting": "使用 Wan VACE 外延生成擴展尺寸的影片。",
|
||||
"wan2_1_flf2v_720_f16": "使用 Wan 2.1 FLF2V 控制首尾影格生成影片。",
|
||||
"wan2_1_fun_control": "使用 Wan 2.1 ControlNet 以姿勢、深度、邊緣引導生成影片。",
|
||||
"wan2_1_fun_inp": "使用 Wan 2.1 由起始與結束影格生成影片(修補)。"
|
||||
},
|
||||
"Video API": {
|
||||
"api_hailuo_minimax_i2v": "結合圖片與文字產生精緻影片,支援 CGI 整合與流行 AI 擁抱等特效。多種影片風格與主題任你選擇,滿足創意需求。",
|
||||
"api_hailuo_minimax_t2v": "直接從文字提示產生高品質影片。探索 MiniMax 進階 AI,打造多元視覺敘事,專業 CGI 效果與風格元素,讓描述栩栩如生。",
|
||||
"api_kling_effects": "使用 Kling 將視覺特效套用於圖片,產生動態影片。",
|
||||
"api_kling_flf": "透過控制首尾畫面產生影片。",
|
||||
"api_kling_i2v": "產生動作、表情、鏡頭移動等提示遵循度高的影片。支援複雜連續動作提示,讓你成為導演。",
|
||||
"api_luma_i2v": "將靜態圖片即時轉換為高品質動畫。",
|
||||
"api_luma_t2v": "只需簡單提示,即可產生高品質影片。",
|
||||
"api_moonvalley_image_to_video": "透過專為授權資料訓練的模型,使用圖片產生電影級 1080p 影片。",
|
||||
"api_moonvalley_text_to_video": "透過專為授權資料訓練的模型,根據文字提示產生電影級 1080p 影片。",
|
||||
"api_pika_i2v": "使用 Pika AI,將單張靜態圖片轉為流暢動畫影片。",
|
||||
"api_pika_scene": "將多張圖片作為素材,產生融合所有圖片的影片。",
|
||||
"api_pixverse_i2v": "使用 PixVerse,將靜態圖片轉為具動態與特效的影片。",
|
||||
"api_pixverse_t2v": "根據提示精確解讀並產生動態出色的影片。",
|
||||
"api_pixverse_template_i2v": "將靜態圖片轉換為具動態與特效的影片。",
|
||||
"api_runway_first_last_frame": "利用 Runway 精準控制,於兩個關鍵影格間產生平滑影片過渡。",
|
||||
"api_runway_gen3a_turbo_image_to_video": "使用 Runway Gen3a Turbo,將靜態圖片轉為電影感影片。",
|
||||
"api_runway_gen4_turo_image_to_video": "使用 Runway Gen4 Turbo,將圖片轉為動態影片。",
|
||||
"api_veo2_i2v": "使用 Google Veo2 API 由圖片產生影片。"
|
||||
"api_hailuo_minimax_i2v": "MiniMax 由影像與文字生成精緻影片,整合 CGI 效果。",
|
||||
"api_hailuo_minimax_t2v": "MiniMax 由文字提示直接生成高品質影片,支援專業 CGI 與多樣風格敘事。",
|
||||
"api_kling_effects": "使用 Kling 將視覺特效套用於影像生成動態影片。",
|
||||
"api_kling_flf": "控制首尾影格生成影片。",
|
||||
"api_kling_i2v": "使用 Kling 生成動作、表情、鏡頭運動提示遵循度極佳的影片。",
|
||||
"api_luma_i2v": "將靜態影像即時轉換為高品質動畫。",
|
||||
"api_luma_t2v": "只需簡單提示即可生成高品質影片。",
|
||||
"api_moonvalley_image_to_video": "由影像生成電影級 1080p 影片,模型僅訓練於授權資料。",
|
||||
"api_moonvalley_text_to_video": "由文字提示生成電影級 1080p 影片,模型僅訓練於授權資料。",
|
||||
"api_pika_i2v": "使用 Pika AI 將單張靜態影像生成平滑動畫影片。",
|
||||
"api_pika_scene": "使用 Pika Scenes 結合多張輸入影像生成影片。",
|
||||
"api_pixverse_i2v": "使用 PixVerse 將靜態影像生成具動態與特效的影片。",
|
||||
"api_pixverse_t2v": "使用 PixVerse 生成提示解讀精準、動態效果出色的影片。",
|
||||
"api_pixverse_template_i2v": "使用 PixVerse 範本將靜態影像生成具動態與特效的影片。",
|
||||
"api_runway_first_last_frame": "使用 Runway 精準控制兩個關鍵影格間的平滑影片過渡。",
|
||||
"api_runway_gen3a_turbo_image_to_video": "使用 Runway Gen3a Turbo 將靜態影像生成電影級影片。",
|
||||
"api_runway_gen4_turo_image_to_video": "使用 Runway Gen4 Turbo 由影像生成動態影片。",
|
||||
"api_veo2_i2v": "使用 Google Veo2 API 由影像生成影片。"
|
||||
}
|
||||
},
|
||||
"title": "從範本開始"
|
||||
@@ -1605,24 +1616,24 @@
|
||||
"cannotCreateSubgraph": "無法建立子圖",
|
||||
"couldNotDetermineFileType": "無法判斷檔案類型",
|
||||
"dropFileError": "無法處理拖放項目:{error}",
|
||||
"emptyCanvas": "畫布為空",
|
||||
"emptyCanvas": "空白畫布",
|
||||
"errorCopyImage": "複製圖片時發生錯誤:{error}",
|
||||
"errorLoadingModel": "載入模型時發生錯誤",
|
||||
"errorSaveSetting": "儲存設定 {id} 時發生錯誤:{err}",
|
||||
"failedToAccessBillingPortal": "無法存取帳單入口",
|
||||
"failedToAccessBillingPortal": "存取帳單入口失敗:{error}",
|
||||
"failedToApplyTexture": "套用材質失敗",
|
||||
"failedToConvertToSubgraph": "轉換項目為子圖失敗",
|
||||
"failedToCreateCustomer": "建立客戶失敗:{error}",
|
||||
"failedToDownloadFile": "檔案下載失敗",
|
||||
"failedToExportModel": "無法將模型匯出為 {format}",
|
||||
"failedToExportModel": "模型匯出為 {format} 失敗",
|
||||
"failedToFetchBalance": "取得餘額失敗:{error}",
|
||||
"failedToFetchLogs": "無法取得伺服器日誌",
|
||||
"failedToFetchLogs": "取得伺服器日誌失敗",
|
||||
"failedToInitializeLoad3dViewer": "初始化 3D 檢視器失敗",
|
||||
"failedToInitiateCreditPurchase": "啟動點數購買失敗:{error}",
|
||||
"failedToPurchaseCredits": "購買點數失敗:{error}",
|
||||
"fileLoadError": "無法在 {fileName} 中找到工作流程",
|
||||
"fileUploadFailed": "檔案上傳失敗",
|
||||
"interrupted": "執行已被中斷",
|
||||
"interrupted": "執行已中斷",
|
||||
"migrateToLitegraphReroute": "重導節點將於未來版本移除。點擊以遷移至 litegraph 原生重導。",
|
||||
"no3dScene": "沒有 3D 場景可套用材質",
|
||||
"no3dSceneToExport": "沒有 3D 場景可匯出",
|
||||
@@ -1659,11 +1670,11 @@
|
||||
"invalidEmail": "無效的電子郵件地址",
|
||||
"length": "必須為 {length} 個字元",
|
||||
"maxLength": "不得超過 {length} 個字元",
|
||||
"minLength": "至少需有 {length} 個字元",
|
||||
"minLength": "至少需要 {length} 個字元",
|
||||
"password": {
|
||||
"lowercase": "必須包含至少一個小寫字母",
|
||||
"match": "密碼必須相符",
|
||||
"minLength": "必須介於 8 到 32 個字元之間",
|
||||
"minLength": "必須為 8 至 32 個字元",
|
||||
"number": "必須包含至少一個數字",
|
||||
"requirements": "密碼要求",
|
||||
"special": "必須包含至少一個特殊字元",
|
||||
@@ -1676,7 +1687,7 @@
|
||||
"versionMismatchWarning": {
|
||||
"dismiss": "關閉",
|
||||
"frontendNewer": "前端版本 {frontendVersion} 可能與後端版本 {backendVersion} 不相容。",
|
||||
"frontendOutdated": "前端版本 {frontendVersion} 已過時。後端需要版本 {requiredVersion} 或更高版本。",
|
||||
"frontendOutdated": "前端版本 {frontendVersion} 已過時。後端需要 {requiredVersion} 或更高版本。",
|
||||
"title": "版本相容性警告",
|
||||
"updateFrontend": "更新前端"
|
||||
},
|
||||
|
||||
@@ -277,6 +277,10 @@
|
||||
"label": "切换节点库侧边栏",
|
||||
"tooltip": "节点库"
|
||||
},
|
||||
"Workspace_ToggleSidebarTab_output-explorer": {
|
||||
"label": "切换输出资源管理器侧边栏",
|
||||
"tooltip": "输出资源管理器"
|
||||
},
|
||||
"Workspace_ToggleSidebarTab_queue": {
|
||||
"label": "切换执行队列侧边栏",
|
||||
"tooltip": "执行队列"
|
||||
|
||||
File diff suppressed because it is too large
Load Diff
@@ -699,6 +699,19 @@ export class ComfyApi extends EventTarget {
|
||||
return await res.json()
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets a list of output folder items (eg ['output', 'output/images', 'output/videos', ...])
|
||||
* @param {string} folder The folder to list items from, such as 'output'
|
||||
* @returns The list of output folder items within the specified folder
|
||||
*/
|
||||
async getOutputFolderItems(folder: string) {
|
||||
const res = await this.fetchApi(`/output${folder}`)
|
||||
if (res.status === 404) {
|
||||
return []
|
||||
}
|
||||
return await res.json()
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets the metadata for a model
|
||||
* @param {string} folder The folder containing the model
|
||||
|
||||
@@ -1,6 +1,7 @@
|
||||
import { defineStore } from 'pinia'
|
||||
import { computed, ref } from 'vue'
|
||||
|
||||
import { useOutputExplorerSidebarTab } from '@/composables/sidebarTabs/outputExplorerSidebarTab'
|
||||
import { useModelLibrarySidebarTab } from '@/composables/sidebarTabs/useModelLibrarySidebarTab'
|
||||
import { useNodeLibrarySidebarTab } from '@/composables/sidebarTabs/useNodeLibrarySidebarTab'
|
||||
import { useQueueSidebarTab } from '@/composables/sidebarTabs/useQueueSidebarTab'
|
||||
@@ -92,6 +93,7 @@ export const useSidebarTabStore = defineStore('sidebarTab', () => {
|
||||
registerSidebarTab(useNodeLibrarySidebarTab())
|
||||
registerSidebarTab(useModelLibrarySidebarTab())
|
||||
registerSidebarTab(useWorkflowsSidebarTab())
|
||||
registerSidebarTab(useOutputExplorerSidebarTab())
|
||||
|
||||
const menuStore = useMenuItemStore()
|
||||
|
||||
|
||||
Reference in New Issue
Block a user