在SwiftUI中折叠边栏(Xcode 12)

iAlex11

我正在尝试利用SwiftUI 2.0的新多平台项目模板在SwiftUI中创建一个简单的应用程序,我希望像其他许多应用程序一样添加折叠边栏的选项。

我尝试添加一个布尔状态变量来控制边栏是否应该显示,但是这不起作用,因为随后主视图变为半透明(我猜这是因为macOS认为边栏现在是主视图)。

有没有一种方法可以在SwiftUI中本地实现?请注意,我正在使用macOS Big Sur,Xcode 12和SwiftUI 2.0

提前致谢。

我的密码

ContentView.swift

import SwiftUI

struct ContentView: View {

    #if os(iOS)
    @Environment(\.horizontalSizeClass) private var horizontalSizeClass
    #endif
    
    @ViewBuilder var body: some View {
        #if os(iOS)
        if horizontalSizeClass == .compact {
            TabController()
        } else {
            SidebarNavigation()
        }
        #else
        SidebarNavigation()
            .frame(minWidth: 900, maxWidth: .infinity, minHeight: 500, maxHeight: .infinity)
        #endif
    }
    
}

struct ContentView_Previews: PreviewProvider {
    static var previews: some View {
        ContentView()
            .previewLayout(.sizeThatFits)
    }
}

侧边栏

import SwiftUI

struct SidebarNavigation: View {
    
    enum HyperspaceViews {
        case home
        case localTimeline
        case publicTimeline
        case messages
        case announcements
        case community
        case recommended
        case profile
    }

    @State var selection: Set<HyperspaceViews> = [.home]
    @State var searchText: String = ""
    @State var showComposeTootView: Bool = false
    @State var showNotifications: Bool = false
    @State private var showCancelButton: Bool = false
    
    
    var sidebar: some View {
        
        VStack {
            
            HStack {
                TextField("Search...", text: $searchText)
                    .cornerRadius(4)
            }
                .padding()
                .textFieldStyle(RoundedBorderTextFieldStyle())
            
            List(selection: self.$selection) {
                    
                Group {
                    
                    NavigationLink(destination: Timeline().container.frame(maxWidth: .infinity, maxHeight: .infinity)) {
                        Label("Home", systemImage: "house")
                    }
                        .accessibility(label: Text("Home"))
                        .tag(HyperspaceViews.home)
                    
                    NavigationLink(destination: Text("Local").frame(maxWidth: .infinity, maxHeight: .infinity)) {
                        Label("Local", systemImage: "person.2")
                    }
                        .accessibility(label: Text("Local"))
                        .tag(HyperspaceViews.localTimeline)
                    
                    NavigationLink(destination: Text("Public").frame(maxWidth: .infinity, maxHeight: .infinity)) {
                        Label("Public", systemImage: "globe")
                    }
                        .accessibility(label: Text("Public"))
                        .tag(HyperspaceViews.localTimeline)
                    
                    NavigationLink(destination: Text("Messages").frame(maxWidth: .infinity, maxHeight: .infinity)) {
                        Label("Messages", systemImage: "bubble.right")
                    }
                        .accessibility(label: Text("Message"))
                        .tag(HyperspaceViews.localTimeline)
                    
                    Divider()
                        
                    NavigationLink(destination: Text("Announcements").frame(maxWidth: .infinity, maxHeight: .infinity)) {
                        Label("Announcements", systemImage: "megaphone")
                    }
                        .accessibility(label: Text("Announcements"))
                        .tag(HyperspaceViews.announcements)
                    
                    NavigationLink(destination: Text("Community").frame(maxWidth: .infinity, maxHeight: .infinity)) {
                        Label("Community", systemImage: "flame")
                    }
                        .accessibility(label: Text("Community"))
                        .tag(HyperspaceViews.community)
                    
                    NavigationLink(destination: Text("Recommended").frame(maxWidth: .infinity, maxHeight: .infinity)) {
                        Label("Recommended", systemImage: "star")
                    }
                        .accessibility(label: Text("Community"))
                        .tag(HyperspaceViews.recommended)
                    
                    Divider()
                    NavigationLink(destination: Text("Recommended").frame(maxWidth: .infinity, maxHeight: .infinity)) {
                        Label("hyperspacedev", systemImage: "tag")
                    }
                        .accessibility(label: Text("Community"))
                        .tag(HyperspaceViews.recommended)
                        
                }
                
            }
                .overlay(self.profileButton, alignment: .bottom)
            .listStyle(SidebarListStyle())
            
        }
    }
    
    var profileButton: some View {
        VStack(alignment: .leading, spacing: 0) {
            Divider()
            NavigationLink(destination: ProfileView().container.frame(maxWidth: .infinity, maxHeight: .infinity)) {
                HStack {
                    Image("amodrono")
                        .resizable()
                        .clipShape(Circle())
                        .frame(width: 25, height: 25)
                    Text("amodrono")
                        .font(.headline)
                }
                .contentShape(Rectangle())
            }
            .accessibility(label: Text("Your profile"))
            .padding(.vertical, 8)
            .padding(.horizontal, 16)
            .buttonStyle(PlainButtonStyle())
        }
            .tag(HyperspaceViews.profile)
    }
    
    var body: some View {
        NavigationView {
            
            #if os(macOS)
            sidebar.frame(minWidth: 100, idealWidth: 180, maxWidth: 200, maxHeight: .infinity)
            #else
            sidebar
            #endif
            
            Text("Content List")
                .frame(maxWidth: .infinity, maxHeight: .infinity)
            
        }
            .sheet(isPresented: self.$showComposeTootView) {
                ComposeTootView(showComposeTootView: self.$showComposeTootView)
                    .frame(minWidth: 400, maxWidth: .infinity, minHeight: 200, maxHeight: .infinity)
            }

            .toolbar {
                
                ToolbarItem {
                    
                    Button(action: {
                        
                        self.showNotifications.toggle()
                        
                    }) {
                        
                        Image(systemName: "bell")
                        
                    }
                        .popover(
                            isPresented: self.$showNotifications,
                            arrowEdge: .bottom
                        ) {
                            LazyVStack {
                                ForEach(0 ..< 10 ) { i in
                                    
                                    Label("@\(i) liked your post!", systemImage: "hand.thumbsup")
                                        .padding()
                                    
                                    Divider()
                                    
                                }
                            }
                        }
                    
                }
                
                ToolbarItem {
                    
                    Button(action: {
                        
                        self.showComposeTootView.toggle()
                        
                    }) {
                        
                        Image(systemName: "square.and.pencil")
                        
                    }
                }
                
             }
    }
    
}

struct SidebarNavigation_Previews: PreviewProvider {
    static var previews: some View {
        SidebarNavigation()
    }
}
Fabpabs

这对我有用-https://developer.apple.com/forums/thread/651807

struct SwiftUIView: View {
    var body: some View {
        NavigationView{

        }.toolbar {
            ToolbarItem(placement: .navigation) {
                Button(action: toggleSidebar, label: {
                    Image(systemName: "sidebar.left")
                })
            }
        }
    }
}

func toggleSidebar() {
        NSApp.keyWindow?.firstResponder?.tryToPerform(#selector(NSSplitViewController.toggleSidebar(_:)), with: nil)
}

struct SwiftUIView_Previews: PreviewProvider {
    static var previews: some View {
        SwiftUIView()
    }
}

它显示在iOS上的视图中,因此您仅需要macOS的某些条件。

本文收集自互联网,转载请注明来源。

如有侵权,请联系[email protected] 删除。

编辑于
0

我来说两句

0条评论
登录后参与评论

相关文章

来自分类Dev

在SwiftUI Xcode 12中无法使用Stepper

来自分类Dev

Xcode 12折叠所有构建目标

来自分类Dev

使用Publish的ObservableObject中的SwiftUI ObservableObject在Xcode 12中的downloadURL回调后不更新视图

来自分类Dev

在Xcode 12中使用@main

来自分类Dev

对齐在iOS14中不起作用,xcode12 swiftUI

来自分类Dev

Xcode 12和SwiftUI:无法在此文件中预览-无法更新预览

来自分类Dev

SwiftUI:在Xcode 12 / iOS 14中使用环境对象(->如何/在环境中放置对象的位置?)

来自分类Dev

在Xcode 12的SwiftUI项目中使用ViewRouter

来自分类Dev

Xcode 12 SwiftUI应用因UIRequiredDeviceCapabilities plist键被拒绝

来自分类Dev

使用SwiftUI,XCode 12和Catalina的新项目失败

来自分类Dev

AudioKit Xcode 12 Beta版

来自分类Dev

XCode 12,FIRAnalyticsConnector,生成错误

来自分类Dev

细分错误:11,xcode -12

来自分类Dev

XCode 12-无法找到或加载主类12

来自分类Dev

Bootstrap 3.3.5中折叠的导航栏文本的边距

来自分类Dev

在Xcode中启用代码折叠栏

来自分类Dev

如何在IOS 12中访问搜索栏的searchtextfield

来自分类Dev

iOS 12 在 QuickType 栏中建议电话号码

来自分类Dev

IntelliJ Idea 12中的调试

来自分类Dev

在 iOS 12 中获取数据

来自分类Dev

如何在Xcode 12中使用iOS 12模拟器

来自分类Dev

SwiftUI:尝试在Xcode 12 beta 2中构建到iOS 13和iOS 14时使用if #available时出错

来自分类Dev

使用Xcode 12访问SwiftUI中的ViewModel字段:“在安装到视图上之外访问State的值”

来自分类Dev

SwiftUI在NavigationView中添加个人警报视图,后退按钮不适用于Xcode 12 iOS14

来自分类Dev

在折叠的折叠工具栏布局中为标题添加边距

来自分类Dev

调用SwiftUI的#11,#12处的额外参数

来自分类Dev

SceneKit不会在Xcode 12中填充屏幕

来自分类Dev

如何在Xcode 12的新更新中显示视图控件?

来自分类Dev

XCode 12和IOS 14中的UITableView问题

Related 相关文章

  1. 1

    在SwiftUI Xcode 12中无法使用Stepper

  2. 2

    Xcode 12折叠所有构建目标

  3. 3

    使用Publish的ObservableObject中的SwiftUI ObservableObject在Xcode 12中的downloadURL回调后不更新视图

  4. 4

    在Xcode 12中使用@main

  5. 5

    对齐在iOS14中不起作用,xcode12 swiftUI

  6. 6

    Xcode 12和SwiftUI:无法在此文件中预览-无法更新预览

  7. 7

    SwiftUI:在Xcode 12 / iOS 14中使用环境对象(->如何/在环境中放置对象的位置?)

  8. 8

    在Xcode 12的SwiftUI项目中使用ViewRouter

  9. 9

    Xcode 12 SwiftUI应用因UIRequiredDeviceCapabilities plist键被拒绝

  10. 10

    使用SwiftUI,XCode 12和Catalina的新项目失败

  11. 11

    AudioKit Xcode 12 Beta版

  12. 12

    XCode 12,FIRAnalyticsConnector,生成错误

  13. 13

    细分错误:11,xcode -12

  14. 14

    XCode 12-无法找到或加载主类12

  15. 15

    Bootstrap 3.3.5中折叠的导航栏文本的边距

  16. 16

    在Xcode中启用代码折叠栏

  17. 17

    如何在IOS 12中访问搜索栏的searchtextfield

  18. 18

    iOS 12 在 QuickType 栏中建议电话号码

  19. 19

    IntelliJ Idea 12中的调试

  20. 20

    在 iOS 12 中获取数据

  21. 21

    如何在Xcode 12中使用iOS 12模拟器

  22. 22

    SwiftUI:尝试在Xcode 12 beta 2中构建到iOS 13和iOS 14时使用if #available时出错

  23. 23

    使用Xcode 12访问SwiftUI中的ViewModel字段:“在安装到视图上之外访问State的值”

  24. 24

    SwiftUI在NavigationView中添加个人警报视图,后退按钮不适用于Xcode 12 iOS14

  25. 25

    在折叠的折叠工具栏布局中为标题添加边距

  26. 26

    调用SwiftUI的#11,#12处的额外参数

  27. 27

    SceneKit不会在Xcode 12中填充屏幕

  28. 28

    如何在Xcode 12的新更新中显示视图控件?

  29. 29

    XCode 12和IOS 14中的UITableView问题

热门标签

归档