File size: 2,354 Bytes
372395e
f694503
04d2706
 
372395e
 
 
 
 
 
f694503
 
 
 
372395e
79b4496
 
 
 
 
 
 
 
 
 
 
 
 
 
 
755cfd7
79b4496
 
 
 
 
 
 
 
 
 
 
 
 
 
372395e
 
 
79b4496
372395e
 
ee7056c
f694503
372395e
570b690
79b4496
53f5458
 
 
 
 
79b4496
fdef21e
ee7056c
bc6b39c
372395e
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
import gradio as gr
from moviepy.editor import *
from share_btn import community_icon_html, loading_icon_html, share_js

caption = gr.Blocks.load(name="spaces/SRDdev/Image-Caption")
audio_gen = gr.Blocks.load(name="spaces/haoheliu/audioldm-text-to-audio-generation")

def infer(image_input):
    cap = caption(image_input, fn_index=0)
    sound = audio_gen(cap, 5, 2.5, 45, 3, fn_index=0)
    FILETOCONVERT = AudioFileClip(sound)
    FILETOCONVERT.write_audiofile("audio.wav")
    FILETOCONVERT.close()
    return gr.Textbox.update(value=cap, visible=True), "audio.wav", gr.Group.update(visible=True)

title = """
    <div style="text-align: center; max-width: 700px; margin: 0 auto;">
        <div
        style="
            display: inline-flex;
            align-items: center;
            gap: 0.8rem;
            font-size: 1.75rem;
        "
        >
        <h1 style="font-weight: 900; margin-bottom: 7px; margin-top: 5px;">
            Image to Sound Effect
        </h1>
        </div>
        <p style="margin-bottom: 10px; font-size: 94%">
        Convert an image to corresponding sound effect through gpt2 image captioning & AudioLDM
        </p>
    </div>
"""

article = """
    
    <div class="footer">
        <p>
         
        Follow <a href="https://twitter.com/fffiloni" target="_blank">Sylvain Filoni</a> for future updates πŸ€—
        </p>
    </div>    
"""

with gr.Blocks(css="style.css") as demo:
    with gr.Column(elem_id="col-container"):
        
        gr.HTML(title)
    
        input_img = gr.Image(type="filepath", elem_id="input-img")
        caption_output = gr.Textbox(label="Caption", lines=1, visible=False, elem_id="text-caption")
        sound_output = gr.Audio(label="Result", elem_id="sound-output")
        
        generate = gr.Button("Generate SFX from Image")

        with gr.Group(elem_id="share-btn-container", visible=False) as share_group:
            community_icon = gr.HTML(community_icon_html)
            loading_icon = gr.HTML(loading_icon_html)
            share_button = gr.Button("Share to community", elem_id="share-btn")

        gr.HTML(article)
        
    generate.click(infer, inputs=[input_img], outputs=[caption_output, sound_output, share_group], api_name="i2fx")
    share_button.click(None, [], [], _js=share_js)

demo.queue(max_size=32, concurrency_count=20).launch()