Как правильно различить горизонтальные жесты прокрутки и увеличения в Swiftui с диаграммами?IOS

Программируем под IOS
Ответить
Anonymous
 Как правильно различить горизонтальные жесты прокрутки и увеличения в Swiftui с диаграммами?

Сообщение Anonymous »

Я работаю над графическим интерфейсом в Swiftui, используя диаграммы Swift, и я реализовал жест увеличения для масштабирования (изменение значений оси X) с использованием увеличения. Это частично работает, но у меня также есть горизонтальная прокрутка для диаграммы, которая, по -видимому, противоречит распознаванию жестов. При выполнении жеста «вертикально», он, кажется, признан намного лучше. Вот мой код: < /p>

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

import Charts
import SwiftUI

@MainActor
struct GraphScreen: View {
@Environment(ThemeManager.self) private var theme
@Environment(DataModel.self) private var dataModel: DataModel

@State private var scrollPosition = Date()
@State private var selectedPrice: CandlestickDataPoint?

@State var investmentData: [CandlestickDataPoint] = []
@State var minimum: Double = 0
@State var maximum: Double = 1
@State var minimumAdjusting: Double = 0.995
@State var maximumAdjusting: Double = 1.005

@State private var currentZoom = 0.0
@State private var totalZoom = 24.0
@State private var strideMinuteCount = 15
@State private var barWidth: CGFloat = 10

var body: some View {
content
.task {
do {
let response = try await dataModel.userStock()
investmentData = ChartManager.shared.process(response: response)
totalZoom = 12
} catch {
print(error.localizedDescription)
}
}
.onChange(of: totalZoom, { oldValue, newValue in
// Adjust the barWidth and strideMinuteCount based on the zoom level
strideMinuteCount = Int(5 * newValue) // Adjust the stride count based on some formula
barWidth = max(1, CGFloat(48 / newValue)) // Adjust the bar width

let visibleData = getVisibleValues()
setMinMax(forValues: visibleData)
})
}

func getVisibleValues() -> [CandlestickDataPoint] {
let minDate = scrollPosition
let maxDate = scrollPosition.addingTimeInterval((currentZoom + totalZoom) * 1800)
let values = investmentData.filter({ $0.date >= minDate && $0.date  item.open ? Color.green : Color.red)

RuleMark(
x: .value("Date", item.date),
yStart: .value("Low", item.low),
yEnd: .value("High", item.high)
)
.foregroundStyle(item.close >  item.open ? Color.green : Color.red)
}
.chartYScale(domain: [minimum, maximum])
.chartYAxis {
AxisMarks(position: .automatic, values: .automatic) {
AxisGridLine()
.foregroundStyle(theme.selected.bodyTextGrayColor)

AxisValueLabel()
.foregroundStyle(theme.selected.bodyTextGrayColor)
}
}
.chartXAxis {
AxisMarks(values: .stride(by: .minute, count: strideMinuteCount)) {
AxisGridLine()
.foregroundStyle(theme.selected.bodyTextGrayColor)

AxisValueLabel()
.foregroundStyle(theme.selected.bodyTextGrayColor)
}
}
//.disabled(true)
.chartScrollableAxes([.horizontal])
.chartScrollPosition(x: $scrollPosition)
.onChange(of: scrollPosition) {
print(scrollPosition)
let visibleData = getVisibleValues()
setMinMax(forValues: visibleData)
}
.chartXVisibleDomain(length: (currentZoom + totalZoom) * 1800)
.chartGesture { chartProxy in
magnifyGesture
}
}
}
Когда я отключаю взаимодействие всей диаграммы, жест увеличения работает хорошо, но затем я теряю горизонтальную функцию прокрутки и должен был бы реализовать его вручную, потенциально усложняя другие взаимодействия графиков.>

Подробнее здесь: https://stackoverflow.com/questions/784 ... tion-gestu
Ответить

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

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

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

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

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