Tabview и клавиша нажмите в Swiftui на iPadIOS

Программируем под IOS
Ответить
Anonymous
 Tabview и клавиша нажмите в Swiftui на iPad

Сообщение Anonymous »

Я хочу использовать нажатия клавиш для перемещения между страницами в приложении Swiftui. Вместо того, чтобы вызывать закрытие OnKeyPress, приложение рисует синий прямоугольник вокруг вида, а затем вызывает закрытие на последующих нажатиях клавиш. Есть ли способ избежать этого?

Код: Выделить всё

import Foundation
import SwiftUI

@main
struct TestTabView1App: App {
var body: some Scene {
WindowGroup {
ContentView()
}
}
}

struct ViewModel: Observable {
var pageIndex: Int
}

struct ContentView: View {
@State var viewModel = ViewModel(pageIndex: 0)
@FocusState private var focused: Bool

var body: some View {
TabView(selection: $viewModel.pageIndex) {
ForEach(0 ..< 3) { i in
VStack {
Image(systemName: "globe")
.imageScale(.large)
.foregroundStyle(.tint)
Text("Hello, world, page \(i)")
}
.padding()
}
}
.tabViewStyle(.page(indexDisplayMode: .never))
.focusable()
.focused($focused)
.onKeyPress(phases: [.down]) { keyPress in
switch keyPress.key {
case .leftArrow:
viewModel.pageIndex = max(0, viewModel.pageIndex - 1)
case .rightArrow:
viewModel.pageIndex = min(2, viewModel.pageIndex + 1)
default:
()
}
return .handled
}
.onAppear() {
focused = true
}
.padding()
}
}

#Preview {
ContentView(viewModel: ViewModel(pageIndex: 0))
}
Кроме того, вот скриншот синего прямоугольника:


Подробнее здесь: https://stackoverflow.com/questions/796 ... ui-on-ipad
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «IOS»