ada*_*ges 8 ipad ios ios-simulator swift swiftui
所以我有以下代码:
import SwiftUI
struct ContentView : View {
    @State private var draggingLocation = CGPoint.zero
    @State private var startLocation = CGPoint.zero
    @State private var dragging = false
    var body: some View {
        let GR = DragGesture(minimumDistance: 10, coordinateSpace: .global)
            .onEnded { value in
                self.dragging = false
                self.draggingLocation = CGPoint.zero
                self.startLocation = CGPoint.zero
            }
            .onChanged { value in
                if !self.dragging {
                    self.dragging = true
                }
                if self.startLocation == CGPoint.zero {
                    self.startLocation = value.startLocation
                }
                self.draggingLocation = value.location
            }
        return ZStack {
            if self.dragging {
                Path { path in
                    path.move(to: CGPoint(x: self.startLocation.x-5, y: self.startLocation.y-5))
                    path.addLine(to: CGPoint(x: self.draggingLocation.x-5, y: self.draggingLocation.y+5))
                    path.addLine(to: CGPoint(x: self.draggingLocation.x+5, y: self.draggingLocation.y-5))
                    path.addLine(to: CGPoint(x: self.startLocation.x+5, y: self.startLocation.y+5))
                }
                .fill(Color.black)
            }
            Circle()
            .fill(self.dragging ? Color.blue : Color.red)
            .frame(width: 100, height: 100)
            .gesture(GR)
            .offset(
                x: 75,
                y: 75
            )
            Circle()
            .fill(self.dragging ? Color.blue : Color.red)
            .frame(width: 100, height: 100)
            .gesture(GR)
            .offset(
                x: -75,
                y: -75
            )
        }
        .frame(width: 400, height: 400)
        .background(Color.gray)
    }
}
#if DEBUG
struct ContentView_Previews : PreviewProvider {
    static var previews: some View {
        ContentView()
    }
}
#endif
这导致这种行为:
我希望能够将边缘从一个圆拖到另一个圆中,当然问题是 的坐标空间Path是相对于灰色框 ( ContentView) 而不是全局的。A在文档中Path有一个属性coordinateSpace,但关于如何使用它的信息很少,并且使用 SwiftUI 搜索该术语会返回三个结果,所有这些结果实际上只是指向 Apple 当前稀疏文档的链接。任何人都知道如何最好地解决这个问题?
kon*_*iki 10
坐标空间有 3 种风格:.local、.global 和 .named。前两个是显而易见的。第三个命名坐标空间在像您这样的情况下非常有用。它们与 GeometryReader 结合使用也很有用。有关更多详细信息,请查看https://swiftui-lab.com/geometryreader-to-the-rescue/
命名坐标空间可让您在另一个视图的坐标空间中表达一个视图的坐标。为此,SwiftUI 允许您为视图的坐标空间指定名称。然后,在代码的其他地方,您可以引用它。在您的示例中,命名 ZStack 的坐标是可行的方法。
这是重构后的代码:
注意:我移动了下面的路径,只是为了让它在圆圈前面绘制。而且,请注意第一个路径,它只是为了防止我认为是 ZStack 中的错误。
import SwiftUI
struct ContentView : View {
    @State private var draggingLocation = CGPoint.zero
    @State private var startLocation = CGPoint.zero
    @State private var dragging = false
    var body: some View {
        let GR = DragGesture(minimumDistance: 10, coordinateSpace: .named("myCoordinateSpace"))
            .onEnded { value in
                self.dragging = false
                self.draggingLocation = CGPoint.zero
                self.startLocation = CGPoint.zero
        }
        .onChanged { value in
            if !self.dragging {
                self.dragging = true
            }
            if self.startLocation == CGPoint.zero {
                self.startLocation = value.startLocation
            }
            self.draggingLocation = value.location
        }
        return ZStack(alignment: .topLeading) {
            Circle()
                .fill(self.dragging ? Color.blue : Color.red)
                .frame(width: 100, height: 100)
                .overlay(Text("Circle 1"))
                .gesture(GR)
                .offset(x: 75, y: 75)
            Circle()
                .fill(self.dragging ? Color.blue : Color.red)
                .frame(width: 100, height: 100)
                .overlay(Text("Circle 2"))
                .gesture(GR)
                .offset(x: 200, y: 200)
            if self.dragging {
                Path { path in
                    path.move(to: CGPoint(x: self.startLocation.x-5, y: self.startLocation.y-5))
                    path.addLine(to: CGPoint(x: self.draggingLocation.x-5, y: self.draggingLocation.y+5))
                    path.addLine(to: CGPoint(x: self.draggingLocation.x+5, y: self.draggingLocation.y-5))
                    path.addLine(to: CGPoint(x: self.startLocation.x+5, y: self.startLocation.y+5))
                }
                .fill(Color.black)
            }
        }
        .coordinateSpace(name: "myCoordinateSpace")
        .frame(width: 400, height: 400, alignment: .topLeading)
        .background(Color.gray)
    }
}
| 归档时间: | 
 | 
| 查看次数: | 2997 次 | 
| 最近记录: |