首页 > 解决方案 > SwiftUI:如何在没有 AppDelegate 的情况下强制景观

问题描述

我正在制作带有视频播放器的应用程序,我的整个结构仅用于纵向视图,除了这个视频播放器。我想为此视图启用横向旋转。但是我已经访问了很多论坛,每个答案都是向 App Delegate 添加一些代码,但我没有。那我能做什么。

标签: iosswiftuirotation

解决方案


这是给你的演示。您可以通过调用函数将方向更改为您喜欢的方向changeOrientation。您还可以在完成后反转方向更改,使用.onReceive. .onReceive每次发生方向变化时都会调用 ,因此您可以反转您不喜欢的方向变化。
我知道这不是最优的,但这是我在不使用大量 UIKit 和 AppDelegate 的情况下能找到的最好的。您可以使用 AppDelegate 获得更好的结果(我认为)。

import SwiftUI
import UIKit

struct ContentView: View {
    
    private let rotationChangePublisher = NotificationCenter.default
        .publisher(for: UIDevice.orientationDidChangeNotification)
    @State private var isOrientationLocked = false
    
    var body: some View {
        VStack {
            Button("Change orientation") {
                if UIDevice.current.orientation.isPortrait {
                    changeOrientation(to: .landscapeLeft)
                } else {
                    changeOrientation(to: .portrait)
                }
            }.padding()
            
            Button("Orientation is \(isOrientationLocked ? "" : "NOT ")Locked to portrait-only") {
                isOrientationLocked.toggle()
            }.padding()
        }
        .font(.system(size: 17, weight: .semibold))
        .onReceive(rotationChangePublisher) { _ in
            // This is called when there is a orientation change
            // You can set back the orientation to the one you like even
            // if the user has turned around their phone to use another
            // orientation.
            if isOrientationLocked {
                changeOrientation(to: .portrait)
            }
        }
    }
    
    func changeOrientation(to orientation: UIInterfaceOrientation) {
        // tell the app to change the orientation
        UIDevice.current.setValue(orientation.rawValue, forKey: "orientation")
        print("Changing to", orientation.isPortrait ? "Portrait" : "Landscape")
    }
}

此外,请确保您事先允许使用不同的方向:

在此处输入图像描述


推荐阅读