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

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

Сообщение Anonymous »

Я строю просмотр Swiftui, где пользователи могут провести линию, перетаскивая ZSTACK. В настоящее время я захватываю точки сопротивления в массиве и рисую прямые линии между ними. Тем не менее, результирующий путь выглядит зазубренным и не таким гладким, как я хотел бы. Я хочу, чтобы нарисованный путь был сглажен (аналогично прикрепленному изображению), когда пользователь перетаскивает, так что недостатки в необработанных точках уточняются в более естественную изогнутую линию. < /P>
текущая реализация:
import SwiftUI

struct GlowingLine: View {
@Environment(\.presentationMode) var presentationMode
@State private var dragPath: [CGPoint] = []
@State var isCreated: Bool = false

var body: some View {
GeometryReader { geometry in
ZStack {
// Background image (if needed)
Image("")
.resizable()
.scaledToFit()

// Draw the drag path
Path { path in
for (index, point) in dragPath.enumerated() {
if index == 0 {
path.move(to: point)
} else {
path.addLine(to: point)
}
}
}
.stroke(Color.red, style: StrokeStyle(lineWidth: 5, lineCap: .round, lineJoin: .round))
.shadow(color: .red, radius: 10, x: 0, y: 0)

// UI Controls (simplified)
VStack {
Button("Clear") {
dragPath.removeAll()
isCreated = false
}
}
}
.background(Color.gray)
.gesture(
DragGesture(minimumDistance: 0)
.onChanged { value in
if !isCreated {
dragPath.append(value.location)
}
}
.onEnded { _ in
isCreated = true
}
)
}
.edgesIgnoringSafeArea(.all)
}
}

struct GlowingLine_Previews: PreviewProvider {
static var previews: some View {
GlowingLine()
}
}

< /code>
мой вопрос: < /strong> < /p>

Как я могу преобразовать этот путь перетаскивания в плавный Кривая в режиме реального времени? /li>
< /ul>
результат текущего кода < /strong> < /p>

Что я хочу в результате



Подробнее здесь: https://stackoverflow.com/questions/794 ... -real-time
Ответить

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

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

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

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

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