Spaces:
Running
Running
Commit
·
ae65ad2
1
Parent(s):
250440d
add support for reference images
Browse files
src/app/api/parsers/parseTurbo.ts
CHANGED
@@ -7,7 +7,8 @@ export function parseTurbo(
|
|
7 |
try {
|
8 |
let maybeTurbo = decodeURIComponent(`${input || value}`).trim().toLowerCase()
|
9 |
|
10 |
-
|
|
|
11 |
|
12 |
if (maybeTurbo === "false") { return false }
|
13 |
|
|
|
7 |
try {
|
8 |
let maybeTurbo = decodeURIComponent(`${input || value}`).trim().toLowerCase()
|
9 |
|
10 |
+
|
11 |
+
if (maybeTurbo === "true" || maybeTurbo === "1") { return true }
|
12 |
|
13 |
if (maybeTurbo === "false") { return false }
|
14 |
|
src/app/api/providers/videochain/renderWithVideoChain.ts
CHANGED
@@ -10,6 +10,7 @@ const apiKey = `${process.env.VIDEOCHAIN_API_KEY || ""}`
|
|
10 |
export async function newRender({
|
11 |
prompt,
|
12 |
negativePrompt,
|
|
|
13 |
nbFrames,
|
14 |
nbFPS,
|
15 |
nbSteps,
|
@@ -21,6 +22,7 @@ export async function newRender({
|
|
21 |
}: {
|
22 |
prompt: string
|
23 |
negativePrompt: string
|
|
|
24 |
nbFrames: number
|
25 |
nbFPS: number
|
26 |
nbSteps: number
|
@@ -64,6 +66,7 @@ export async function newRender({
|
|
64 |
body: JSON.stringify({
|
65 |
prompt,
|
66 |
negativePrompt,
|
|
|
67 |
// nbFrames: 8 and nbSteps: 15 --> ~10 sec generation
|
68 |
nbFrames, // when nbFrames is 1, we will only generate static images
|
69 |
nbFPS,
|
|
|
10 |
export async function newRender({
|
11 |
prompt,
|
12 |
negativePrompt,
|
13 |
+
identityImage,
|
14 |
nbFrames,
|
15 |
nbFPS,
|
16 |
nbSteps,
|
|
|
22 |
}: {
|
23 |
prompt: string
|
24 |
negativePrompt: string
|
25 |
+
identityImage?: string
|
26 |
nbFrames: number
|
27 |
nbFPS: number
|
28 |
nbSteps: number
|
|
|
66 |
body: JSON.stringify({
|
67 |
prompt,
|
68 |
negativePrompt,
|
69 |
+
identityImage,
|
70 |
// nbFrames: 8 and nbSteps: 15 --> ~10 sec generation
|
71 |
nbFrames, // when nbFrames is 1, we will only generate static images
|
72 |
nbFPS,
|
src/app/api/v1/edit/storyboards/generateStoryboard.ts
CHANGED
@@ -7,6 +7,7 @@ import { getNegativePrompt, getPositivePrompt } from "@/app/api/utils/imagePromp
|
|
7 |
export async function generateStoryboard({
|
8 |
prompt,
|
9 |
// negativePrompt,
|
|
|
10 |
width,
|
11 |
height,
|
12 |
seed,
|
@@ -14,6 +15,7 @@ export async function generateStoryboard({
|
|
14 |
}: {
|
15 |
prompt: string
|
16 |
// negativePrompt?: string
|
|
|
17 |
width?: number
|
18 |
height?: number
|
19 |
seed?: number
|
@@ -23,13 +25,14 @@ export async function generateStoryboard({
|
|
23 |
width = getValidNumber(width, 256, 8192, 512)
|
24 |
height = getValidNumber(height, 256, 8192, 288)
|
25 |
|
26 |
-
|
27 |
prompt = getPositivePrompt(prompt)
|
28 |
const negativePrompt = getNegativePrompt()
|
29 |
|
30 |
let render = await newRender({
|
31 |
prompt,
|
32 |
negativePrompt,
|
|
|
33 |
nbFrames: 1,
|
34 |
nbFPS: 1,
|
35 |
nbSteps: turbo ? 8 : 25,
|
|
|
7 |
export async function generateStoryboard({
|
8 |
prompt,
|
9 |
// negativePrompt,
|
10 |
+
identityImage,
|
11 |
width,
|
12 |
height,
|
13 |
seed,
|
|
|
15 |
}: {
|
16 |
prompt: string
|
17 |
// negativePrompt?: string
|
18 |
+
identityImage?: string
|
19 |
width?: number
|
20 |
height?: number
|
21 |
seed?: number
|
|
|
25 |
width = getValidNumber(width, 256, 8192, 512)
|
26 |
height = getValidNumber(height, 256, 8192, 288)
|
27 |
|
28 |
+
|
29 |
prompt = getPositivePrompt(prompt)
|
30 |
const negativePrompt = getNegativePrompt()
|
31 |
|
32 |
let render = await newRender({
|
33 |
prompt,
|
34 |
negativePrompt,
|
35 |
+
identityImage,
|
36 |
nbFrames: 1,
|
37 |
nbFPS: 1,
|
38 |
nbSteps: turbo ? 8 : 25,
|
src/app/api/v1/edit/storyboards/processShot.ts
CHANGED
@@ -79,12 +79,22 @@ export async function processShot({
|
|
79 |
if (!shotStoryboardSegment.assetUrl) {
|
80 |
// console.log(`[api/v1/edit/storyboards] generating image..`)
|
81 |
|
|
|
|
|
|
|
|
|
|
|
|
|
82 |
try {
|
83 |
shotStoryboardSegment.assetUrl = await generateStoryboard({
|
84 |
prompt: getPositivePrompt(shotStoryboardSegment.prompt),
|
|
|
85 |
width: existingClap.meta.width,
|
86 |
height: existingClap.meta.height,
|
87 |
-
|
|
|
|
|
|
|
88 |
})
|
89 |
shotStoryboardSegment.assetSourceType = getClapAssetSourceType(shotStoryboardSegment.assetUrl)
|
90 |
shotStoryboardSegment.status = "completed"
|
|
|
79 |
if (!shotStoryboardSegment.assetUrl) {
|
80 |
// console.log(`[api/v1/edit/storyboards] generating image..`)
|
81 |
|
82 |
+
// console.log(`we have ${existingClap.entities.length} entities`)
|
83 |
+
// check if we have an entity image we can use
|
84 |
+
const identityImage = existingClap.entities.find(e => e.id === shotStoryboardSegment.entityId)?.imageId
|
85 |
+
if (identityImage) {
|
86 |
+
// console.log(`[api/v1/edit/storyboards] processShot: using an entity to generate the storyboard..`)
|
87 |
+
}
|
88 |
try {
|
89 |
shotStoryboardSegment.assetUrl = await generateStoryboard({
|
90 |
prompt: getPositivePrompt(shotStoryboardSegment.prompt),
|
91 |
+
identityImage,
|
92 |
width: existingClap.meta.width,
|
93 |
height: existingClap.meta.height,
|
94 |
+
|
95 |
+
// turbo mode is mandatory if we have an identity image
|
96 |
+
// that's because it will use PuLID instead of SDXL
|
97 |
+
turbo: !!identityImage,
|
98 |
})
|
99 |
shotStoryboardSegment.assetSourceType = getClapAssetSourceType(shotStoryboardSegment.assetUrl)
|
100 |
shotStoryboardSegment.status = "completed"
|
src/app/api/v1/edit/storyboards/route.ts
CHANGED
@@ -24,7 +24,7 @@ export async function POST(req: NextRequest) {
|
|
24 |
|
25 |
const mode = parseCompletionMode(query?.c)
|
26 |
const turbo = parseTurbo(query?.t)
|
27 |
-
|
28 |
const blob = await req.blob()
|
29 |
|
30 |
const existingClap: ClapProject = await parseClap(blob)
|
|
|
24 |
|
25 |
const mode = parseCompletionMode(query?.c)
|
26 |
const turbo = parseTurbo(query?.t)
|
27 |
+
|
28 |
const blob = await req.blob()
|
29 |
|
30 |
const existingClap: ClapProject = await parseClap(blob)
|