File size: 5,535 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
9203d26
 
 
 
d56b541
 
9203d26
 
 
 
 
 
 
 
71488aa
9203d26
 
 
 
 
71488aa
9203d26
 
 
 
 
 
a2a9034
6df37b5
d56b541
71488aa
d56b541
71488aa
6df37b5
 
 
71488aa
6df37b5
71488aa
6df37b5
 
 
71488aa
6df37b5
71488aa
d56b541
 
a2a9034
 
 
 
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
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
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=False) 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=False) 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 di_v(check):
        if check:
            return {di_col: gr.Column(visible=True)}
        else:
            return {di_col: gr.Column(visible=False)}
            
    def se_v(check):
        if check:
            return {se_col: gr.Column(visible=True)}
        else:
            return {se_col: gr.Column(visible=False)}
            
    def re_v(check):
        if check:
            return {re_col: gr.Column(visible=True)}
        else:
            return {re_col: gr.Column(visible=False)}
        

    dimension_check.change(di_v, inputs=[dimension_check], outputs=[di_col])
    speed_check.change(se_v, inputs=[speed_check], outputs=[se_col])
    reverb_check.change(re_v, inputs=[reverb_check], outputs=[re_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)