SwiftUI: настройка положения изображения в TabView - PullRequest
2 голосов
/ 25 января 2020

Я использую следующий код для создания TabView с SwiftUI:

struct TabbedView: View {
    @State private var selected = 0

    var body: some View {
        TabView(selection: $selected) {
            View1().tabItem {
                Image("Tab1")
            }.tag(1)

            View2().tabItem {
                Image("Tab2")
                .offset(y: 20) //<--- has no effect
                }.tag(2)

            View3().tabItem {
                Image("Tab3")
            }.tag(3)
        }
    }
}

Я использую только Image представлений для элементов вкладок без текста, результат следующий:

enter image description here

Мне нужно расположить (или выровнять по вертикали) виды Image вниз к центру TabView, но не смог найти простой способ сделать это.

1 Ответ

4 голосов
/ 25 января 2020

Стандарт TabView не позволяет теперь изменять выравнивание контента tabItem ... но можно создавать пользовательские плавающие элементы в виде табуляции на основе Button, как показано ниже, что позволит выравнивать и / или настроить внешний вид и при этом активировать элементы TabView программно.

struct TabbedView: View {
    @State private var selected = 0

    var body: some View {
        ZStack(alignment: Alignment.bottom) {
            TabView(selection: $selected) {
                View1().tabItem {
                    Text("") // < invisible tab item
                }.tag(1)

                View2().tabItem {
                    Text("")
                    }.tag(2)

                View3().tabItem {
                    Text("")
                }.tag(3)
            }
            // tab-items cover - do anything needed, height, position, alignment, etc.
            HStack { 
                Button(action: { self.selected = 1 } ) {
                    Image("Tab1") // << align & highlight as needed
                }
                Button(action: { self.selected = 2 } ) {
                    Image("Tab2") // << align & highlight as needed
                }
                Button(action: { self.selected = 3 } ) {
                    Image("Tab3") // << align & highlight as needed
                }
            }
        }
    }
}

Примечание: это могут быть даже кнопки без кнопок, только изображения с жестом касания и т. д. c.

...