hor*_*921 7 macos toolbar swiftui swiftui-navigationview
在这个问题之后,如何在 swiftUI 生命周期中为三列视图添加工具栏分隔符 ,我有一个稍微不同的问题。我正在尝试实现相同的目标,但第二列和第三列包含在一个视图中,该视图又添加到第一列(即侧边栏)旁边的导航视图内。
代码示例
import SwiftUI
@main
struct ThreeColumnsAppApp: App {
var body: some Scene {
WindowGroup {
ContentView()
.frame(minWidth: 900, maxWidth: .infinity, minHeight: 600, maxHeight: .infinity)
}
.windowStyle(DefaultWindowStyle())
.windowToolbarStyle(UnifiedWindowToolbarStyle(showsTitle: true))
}
}
struct ContentView: View {
var body: some View {
NavigationView {
Sidebar()
.toolbar { Button(action: {}, label: { Image(systemName: "sidebar.left") }) }
MainContentView()
}
.frame(maxWidth: .infinity, maxHeight: .infinity)
}
}
struct Sidebar: View {
var body: some View {
List {
Text("Menu 1")
Text("Menu 2")
Text("Menu 3")
Text("Menu 4")
}
.frame(minWidth: 250)
.listStyle(SidebarListStyle())
}
}
struct MainContentView: View {
var body: some View {
NavigationView {
ListItemView()
DetailView()
}
.navigationTitle("Items List")
.navigationSubtitle("5 items found")
}
}
struct ListItemView: View {
var body: some View {
List {
Text("List item 1")
Text("List item 2")
Text("List item 3")
Text("List item 4")
Text("List item 5")
}
.frame(minWidth: 250)
.listStyle(InsetListStyle())
.toolbar {
Button(action: {}, label: { Image(systemName: "arrow.up.arrow.down.square") })
}
}
}
struct DetailView: View {
var body: some View {
Text("Detail of list 1")
.frame(maxWidth: .infinity, maxHeight: .infinity)
.toolbar {
Button(action: {}, label: { Image(systemName: "plus") })
Button(action: {}, label: { Image(systemName: "minus") })
Button(action: {}, label: { Image(systemName: "pencil") })
}
}
}
Run Code Online (Sandbox Code Playgroud)
输出
如下所示,应该位于第二列工具栏上的箭头图标与详细视图的工具栏图标一起被推到右侧。看来 NavigationView 将 ListItemView 和 DetailView 工具栏视为一个工具栏。
所需输出
问题
所以,我的问题是如何使工具栏图标与其视图对齐?
为了正确执行此操作,您需要ToolbarItem在视图的三列中的每一列上都有一个。例如,这个:
struct TripleNavView: View {
var body: some View {
NavigationView {
Text("Column 1")
.toolbar {
ToolbarItem {
Button(action: {}, label: {Image(systemName: "sidebar.left")})
}
}
Text("Column 2")
.toolbar {
ToolbarItem {
Button(action: {}, label: {Image(systemName: "plus")})
}
}
Text("Column 3")
.toolbar {
ToolbarItem {
Button(action: {}, label: {Image(systemName: "trash")})
}
}
}
.navigationTitle("Title")
}
}
Run Code Online (Sandbox Code Playgroud)
产生这个:
重要的是,第 2 列和第 3 列都需要有ToolbarItem某种类型的 a。如果您只在其中一列上放置一个按钮,那么 SwiftUI 会将其一直放置在工具栏的后缘,并破坏外观。
因此,如果您不想在特定列上使用按钮,请用 a 代替Spacer该按钮。
请注意,将其留空或使用EmptyView()将不起作用 - SwiftUI 会对其进行优化,并且表现得就像您ToolbarItem一开始就没有包含 a 一样!
| 归档时间: |
|
| 查看次数: |
1749 次 |
| 最近记录: |