立即切换声音

问题描述 投票:0回答:1

我创建了一个切换按钮来关闭/打开音乐。这个问题是我必须关闭应用程序才能使其生效。

这就是我用来开始音乐的地方:

.onAppear(perform: {self.musicM.playSoundBand(sound: "Band", type: "wav")})

这是我的切换按钮:

 Toggle(isOn: self.$musicM.mOn) {
                    ZStack {
                        Image("Button")
                            .renderingMode(.original)
                            .resizable()
                            .aspectRatio(contentMode: .fit)
                            .rotationEffect(Angle(degrees: 180))
                            .padding([.leading, .trailing], 40);
                        Text("Music")
                            .padding(.all, 20)
                            .padding([.leading, .trailing], 40)
                            .font(.largeTitle)
                            .foregroundColor(.black)
                    }
                    Spacer()
                }.onTapGesture(perform: {if self.musicM.mOn == false { self.musicM.pauseMusicBand(); self.soundEffectsM.playSound(sound: "GunCock", type: "wav")}})

我已经尝试过各种变体并利用.stop(),但仍然无法正常工作。如果有帮助,这里也是我的soundmanager类:

class musicModel: ObservableObject {
    var audioPlayerBand:AVAudioPlayer?
    @Published var mOn: Bool = UserDefaults.standard.bool(forKey: "mOn") {
        didSet {
            UserDefaults.standard.set(self.mOn, forKey: "mOn")
        }
    }
    func pauseMusicBand() {
        UserDefaults.standard.set(false, forKey: "mOn"); audioPlayerBand?.pause()
    }
    func setVolume(volume: Float) {
        audioPlayerBand?.volume = volume
    }
    func playSoundBand(sound: String, type: String) {
        if let path = Bundle.main.path(forResource: sound, ofType: type) {
            do {
                audioPlayerBand = try AVAudioPlayer(contentsOf: URL(fileURLWithPath: path))
                audioPlayerBand?.numberOfLoops =  -1
                audioPlayerBand?.play()
            } catch {
                print("ERROR: Could not find sound file!")
            }; if self.mOn == false { pauseMusicBand() }
        }
    }
}
swift swiftui avaudioplayer audio-player togglebutton
1个回答
0
投票

此测试代码显示了如何立即关闭声音:

import SwiftUI
import Foundation
import AVFoundation

struct ContentView: View {

@ObservedObject var musicM = musicModel()

var body: some View {
        Toggle(isOn: Binding<Bool>(
            get: { self.musicM.mOn },
            set: { self.musicM.mOn = $0; self.doMusic() })) {
            ZStack {
                Image("Button")
                    .renderingMode(.original)
                    .resizable()
                    .aspectRatio(contentMode: .fit)
                    .rotationEffect(Angle(degrees: 180))
                    .padding([.leading, .trailing], 40);
                Text("Music")
                    .padding(.all, 20)
                    .padding([.leading, .trailing], 40)
                    .font(.largeTitle)
                    .foregroundColor(.black)
            }
            Spacer()
    }.onAppear(perform: self.startBackgroundMusic)
}

func startBackgroundMusic() {
    // if you want to always start the background music, then toggle should be set
//        self.musicM.mOn = true
//        self.musicM.playSoundBand(sound: "Band", type: "wav")

    // if you want to play the background music only if the user has set it last time
    if self.musicM.mOn {
        self.musicM.playSoundBand(sound: "Band", type: "wav")
    }
}

func doMusic() {
    if self.musicM.mOn {
        self.musicM.playSoundBand(sound: "Band", type: "wav")
    } else {
        self.musicM.audioPlayerBand?.pause()
     //   self.soundEffectsM.playSound(sound: "GunCock", type: "wav")
    }
}
}

class musicModel: ObservableObject {
var audioPlayerBand: AVAudioPlayer?

@Published var mOn: Bool = UserDefaults.standard.bool(forKey: "mOn") {
    didSet {
        UserDefaults.standard.set(self.mOn, forKey: "mOn")
    }
}
func pauseMusicBand() {
    UserDefaults.standard.set(false, forKey: "mOn")
    audioPlayerBand?.pause()
}
func setVolume(volume: Float) {
    audioPlayerBand?.volume = volume
}
func playSoundBand(sound: String, type: String) {
    if let path = Bundle.main.path(forResource: sound, ofType: type) {
        do {
            audioPlayerBand = try AVAudioPlayer(contentsOf: URL(fileURLWithPath: path))
            audioPlayerBand?.numberOfLoops =  -1
            audioPlayerBand?.play()
        } catch {
            print("ERROR: Could not find sound file!")
        }
    }
}
}
© www.soinside.com 2019 - 2024. All rights reserved.