我正在使用 pdfkit 并添加了具有固定大小和宽度的圆形注释,但我想使用动态高度和宽度进行绘制。这是我的代码:
这里:开始是我的 CGPoint,从我开始到手指结束是我结束移动手指的第二个 CGPoint。使用 start.x 和 end.y
let circle = PDFAnnotation(bounds: CGRect(x: start.x, y: end.y, width: 100, height: 100), forType: .circle, withProperties: nil)
circle.color = hexStringToUIColor(hex: "#0000FF")
let border = PDFBorder()
border.lineWidth = 3.0
circle.border = border
page?.addAnnotation(circle)
这是用动态高度和宽度绘制圆的第二种方法:
这是代码:
let centerX = (start!.x + end!.x)/2
let centerY = (start!.y + end!.y)/2
var distance = (end!.x - centerX) * 2
if distance < 0 {
distance = (start!.x - centerX) * 2
}
let halfDistance = distance/2
self.annotation = PDFAnnotation(bounds: CGRect(x: centerX - halfDistance, y: centerY - halfDistance, width: distance, height: distance), forType: .circle, withProperties: nil)
let page = self.pdfview.currentPage
annotation.color = hexStringToUIColor(hex: "#0000FF")
let border = PDFBorder()
border.lineWidth = 3.0
annotation.border = border
page?.addAnnotation(annotation)
第二种方法绘制具有动态高度和宽度的圆圈,但不是我想要的。如果我画圈,它们是 8 种情况:
- 手指从左向右滑动 - 它在适当的位置画圈。
- 手指从右向左滑动 - 它在适当的位置画圈。
- 手指从左上角滑到右下角 - 它画出一半大小的圆圈
- 手指从右下角滑到左上角 - 它画出一半大小的圆圈
- 手指从上到下滑动 - 圆半径值为 2 或 3 宽度和高度
- 手指从下向上滑动 - 圆半径值为 2 或 3 宽度和高度
- 手指从右上角滑到左下角 - 它画出一半大小的圆圈
- 手指从左下角滑到右上角 - 它画出一半大小的圆圈