App Delegate 访问环境对象

Jac*_*ump 4 appdelegate swift swiftui

我在一个类中有一个变量(一个描述游戏的标签),我需要在我的视图之间传递它,我通过 @EnvironmentObject 状态来实现。当一个更改该标签的函数(与变量在同一类中)被一个视图调用时,该变量会在其他视图中更新。但是,当通知被触发时,该函数也会被 AppDelegate 调用。目前,我已经将包含标签的类声明为 AppDelegate 中的新实例,这导致视图/结构中的变量没有更改。

是否可以让 AppDeleagte 访问环境对象(例如,通过 AppDelegate().environmentobject(myClass),如果是这样,在哪里?)还是有更好的方法来做到这一点?

简化代码:

包含播放列表标签和更改播放列表和标签的函数的类

class MusicManager: NSObject, ObservableObject {

    var playlistLabel: String = ""

    func playPlaylistNow(chosenPlaylist: String?) {  
        playlistLabel = "Playlist: \(chosenPlaylist!)"
    }

}
Run Code Online (Sandbox Code Playgroud)

显示标签的主页视图

struct HomeView: View {

    @EnvironmentObject var musicManager: MusicManager

    var body: some View {

        Text(musicManager.playlistLabel)

    }

}
Run Code Online (Sandbox Code Playgroud)

应用程序委托

class AppDelegate: UIResponder, UIApplicationDelegate, AVAudioPlayerDelegate {

    var musicManager: MusicManager = MusicManager()

        func application(_ application: UIApplication, didReceive notification: UILocalNotification) {
            var playlistName: String = ""
            if let userInfo = notification.userInfo {
                playlistName = userInfo["soundName"] as! String
            }
            musicPlayerManager.playPlaylist(chosenPlaylist: playlistName)

        }
    }
Run Code Online (Sandbox Code Playgroud)

Asp*_*eri 6

这是可能的方法。假设你AppDelegate有财产

var musicManager: MusicManager?
Run Code Online (Sandbox Code Playgroud)

在你的SceneDelegate,我想你创建的地方HomeView,你可以有以下代码

func scene(_ scene: UIScene, willConnectTo session: UISceneSession, options connectionOptions: UIScene.ConnectionOptions) {

    let musicManager = MusicManager()
    if let appDelegate = UIApplication.shared.delegate as? AppDelegate {
        addDelegate.musicManager = musicManager
    }
    let contentView = HomeView().environmentObject(musicManager)
    ...
Run Code Online (Sandbox Code Playgroud)

因此,既AppDelegateHomeView访问的同一个实例MusicManager

反之亦然

...
var musicManager: MusicManager?
if let appDelegate = UIApplication.shared.delegate as? AppDelegate {
    musicManager = addDelegate.musicManager
}
let contentView = HomeView().environmentObject(musicManager ?? MusicManager())
...
Run Code Online (Sandbox Code Playgroud)

取决于什么是可取的。