File size: 1,741 Bytes
710844b
 
 
 
c9d9c2a
710844b
c9d9c2a
 
 
 
 
 
 
 
 
 
710844b
c9d9c2a
 
 
 
 
710844b
 
c9d9c2a
 
 
 
710844b
c9d9c2a
710844b
 
 
 
c9d9c2a
710844b
c9d9c2a
710844b
 
c9d9c2a
710844b
 
 
 
 
 
 
 
 
 
 
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
import gradio as gr
from pydub import AudioSegment
import tempfile
import os
from math import log10

def change_volume(audio_path, mode, value):
    if audio_path is None:
        return "エラー: 音声ファイルがありません"

    # 音声読み込み
    audio = AudioSegment.from_file(audio_path)

    # 音量調整
    try:
        if mode == "パーセンテージ(%)":
            multiplier = 1 + float(value) / 100
            if multiplier <= 0:
                return "エラー: 0%以下にはできません"
            db_gain = 10 * log10(multiplier)
            audio = audio.apply_gain(db_gain)
        elif mode == "デシベル(dB)":
            db_value = float(value)
            audio = audio + db_value
        else:
            return "エラー: モードが不正です"
    except Exception as e:
        return f"エラー: 数値が不正です ({e})"

    # 出力
    out_path = tempfile.NamedTemporaryFile(delete=False, suffix=".wav").name
    audio.export(out_path, format="wav")
    return out_path

# Gradio UI
with gr.Blocks() as app:
    gr.Markdown("## 🎚️ 音量調整アプリ(% または dB)")

    with gr.Row():
        audio_input = gr.Audio(type="filepath", label="音声ファイルをアップロード")
        audio_output = gr.Audio(label="出力音声", interactive=False)

    with gr.Row():
        mode = gr.Radio(["パーセンテージ(%)", "デシベル(dB)"], value="パーセンテージ(%)", label="調整モード")
        value = gr.Textbox(label="調整値(例:50, -10 など)")

    run_btn = gr.Button("音量を変更")

    run_btn.click(fn=change_volume, inputs=[audio_input, mode, value], outputs=audio_output)

app.launch()