gpt4 book ai didi

swift - 在 SwiftUI (Xcode 12) 中折叠侧边栏

转载 作者:行者123 更新时间:2023-12-03 09:20:04 26 4
gpt4 key购买 nike

我正在尝试利用 SwiftUI 2.0 的新多平台项目模板在 SwiftUI 中做一个简单的应用程序,我希望像许多其他应用程序一样添加折叠侧边栏的选项。
我尝试添加一个 bool 状态变量来控制侧边栏是否应该显示,但这不起作用,因为然后主 View 变为半透明(我猜这是因为 macOS 认为侧边栏现在是主 View )。
有没有办法在 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)
}
}
Sidebar.swift
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()
}
}

最佳答案

这对我有用-
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 的 View 中,因此您只需要 macOS 的一些条件。

关于swift - 在 SwiftUI (Xcode 12) 中折叠侧边栏,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62577208/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com