File size: 4,949 Bytes
4bb640e
998beeb
9acefe3
 
 
8651489
4bb640e
 
 
8651489
19c8b69
 
4bb640e
 
 
19c8b69
 
1f7c7c0
4bb640e
19c8b69
 
4bb640e
19c8b69
4bb640e
 
19c8b69
4bb640e
 
19c8b69
4bb640e
19c8b69
9acefe3
 
 
c850802
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
d30b841
7bec308
4bb640e
9203d26
 
 
 
d56b541
 
9203d26
 
 
 
 
 
 
 
d56b541
9203d26
 
 
 
 
d56b541
9203d26
 
 
 
 
 
d56b541
 
 
 
 
 
 
 
9203d26
d56b541
cbad5f5
c518f1d
1c95558
6a9394a
9acefe3
f2728c5
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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
import os
import secrets
import gradio as gr
from AudioFusion import Fusion

def process_audio(input_file,
    effect_8d, pan_boundary, jump_percentage, time_l_to_r, volume_multiplier,
    effect_slowed, speed_multiplier,
    effect_reverb, room_size, damping, width, wet_level, dry_level
):
    # Load the sound file
    sound = Fusion.loadSound(input_file)
    os.remove(os.path.abspath(input_file))
    effect_str = []
    
    # Apply effects based on user choices
    if effect_8d:
        sound = Fusion.effect8D(sound, pan_boundary, jump_percentage, time_l_to_r*1000, volume_multiplier)
        effect_str.append("8d")
    if effect_slowed:
        sound = Fusion.effectSlowed(sound, speed_multiplier)
        effect_str.append("Slowed")
    if effect_reverb:
        sound = Fusion.effectReverb(sound, room_size, damping, width, wet_level, dry_level, "temp"+input_file+".wav")
        effect_str.append("Reverb")

    output_file = f"{input_file} {' + '.join(effects_str)} - {'By AudioFusion'}"
    
    # Save the processed sound and return the output file
    output = Fusion.saveSound(sound, output_file, effect_reverb, "temp"+input_file+".wav")
    return output



# iface = gr.Interface(
#     fn=process_audio,
#     inputs=[
#         gr.Audio(label="Upload your music file", type="filepath"),

#         # 8d Effect and its arguments
#         gr.Checkbox(label="Apply 8D effect"),
#         gr.Slider(label="8D - Pan Boundary", minimum=0, maximum=100, value=100),
#         gr.Slider(label="8D - Jump Percentage", minimum=1, maximum=100, value=5),
#         gr.Slider(label="8D - Time L to R (s)", minimum=1, maximum=30, value=10),
#         gr.Slider(label="8D - Volume Multiplier", minimum=1, maximum=20, value=6),
        
#         # SLowed Effect and its arguments
#         gr.Checkbox(label="Apply slowed effect"),
#         gr.Slider(label="Slowed - Speed Multiplier", minimum=0.1, maximum=4, step=0.01, value=0.92),
        
#         # Reverb Effect and its arguments
#         gr.Checkbox(label="Apply reverb effect"),
#         gr.Slider(label="Reverb - Room Size", minimum=0, maximum=2, step=0.01, value=0.8),
#         gr.Slider(label="Reverb - Damping", minimum=0, maximum=2, value=1),
#         gr.Slider(label="Reverb - Width", minimum=0, maximum=2, step=0.1, value=0.5),
#         gr.Slider(label="Reverb - Wet Level", minimum=0, maximum=2, step=0.1, value=0.3),
#         gr.Slider(label="Reverb - Dry Level", minimum=0, maximum=2, step=0.1, value=0.8),
#     ],
#     outputs=gr.Audio(label="Download processed music", type="filepath"),
#     title="Audio Fusion"
# )


with gr.Blocks(title="Audio Fusion") as iface:
    gr.Markdown("<p align='center'><h1>Audio Fusion</h1></p>")

    input_audio = gr.Audio(label="Upload your music file", type="filepath")
    
    # 8d Effect and its arguments
    with gr.Tab("8d Effect"):
        dimension_check = gr.Checkbox(label="Apply 8D effect")
        with gr.Column(visible=False) as di_col:
            pan = gr.Slider(label="8D - Pan Boundary", minimum=0, maximum=100, value=100)
            jump = gr.Slider(label="8D - Jump Percentage", minimum=1, maximum=100, value=5)
            time = gr.Slider(label="8D - Time L to R (s)", minimum=1, maximum=30, value=10)
            volx = gr.Slider(label="8D - Volume Multiplier", minimum=1, maximum=20, value=6)
    
    # SLowed Effect and its arguments
    with gr.Tab("Slowed Effect"):
        speed_check = gr.Checkbox(label="Apply slowed effect")
        with gr.Column(visible=True) as se_col:
            speed = gr.Slider(label="Slowed - Speed Multiplier", minimum=0.1, maximum=4, step=0.01, value=0.92)
    
    # Reverb Effect and its arguments
    with gr.Tab("Reverb Effect"):
        reverb_check = gr.Checkbox(label="Apply reverb effect")
        with gr.Column(visible=True) as re_col:
            room = gr.Slider(label="Reverb - Room Size", minimum=0, maximum=2, step=0.01, value=0.8)
            damp = gr.Slider(label="Reverb - Damping", minimum=0, maximum=2, value=1)
            width = gr.Slider(label="Reverb - Width", minimum=0, maximum=2, step=0.1, value=0.5)
            wet = gr.Slider(label="Reverb - Wet Level", minimum=0, maximum=2, step=0.1, value=0.3)
            dry = gr.Slider(label="Reverb - Dry Level", minimum=0, maximum=2, step=0.1, value=0.8)

    def visiblity(check, col):
        if check:
            return {col: gr.Column(visiblity=True)}
        else:
            return {col: gr.Column(visiblity=False)}
        

    dimension_check.change(visiblity, inputs=[dimension_check, di_col], outputs=[di_col])
    
    inputs = [input_audio, dimension_check, pan, jump, time, volx, speed_check, speed, reverb_check, room, damp, width, wet, dry]
    output = [gr.Audio(label="Download processed music", type="filepath")]
    
    btn = gr.Button("Run", size="sm")
    btn.click(fn=process_audio, inputs=inputs, outputs=output, api_name="AudioFusion")

iface.launch(share=False)