ios - 命中测试以确定哪个 CGPoint 最接近触摸 - 1 个 UIView 中的 16 个 CGPoint 点
问题描述
我一直在修改 LMinh 的这个名为 LMGaugeView 的自定义 UIView,以使其看起来像一个 16 瓶圆形“瓶转盘”。
想象一下 16 个点 (CGPoints) 均匀分布在圆 (UIView) 的边缘。我希望能够执行以下方案:
图片显示了 10 个小瓶,但你明白了。一旦我触摸圆形视图,我希望能够仅根据它们的 CGPoint 值来确定我点击了哪个“小瓶”。
我创建了一个需要该方法的应用程序(称为 Twinstones,只是为了把它扔出去)hitTest:withEvent:
,但我正在处理可以触摸的 2 个子视图(在它们的父视图的框架内。)
为此,圆圈是唯一的视图(这意味着hitTest:withEvent:
每次我接触它时都会返回圆圈视图。)
这是那个hitTest:...
实现:
- (UIView *)hitTest:(CGPoint)point withEvent:(UIEvent *)event {
if (!self.isUserInteractionEnabled || self.isHidden || self.alpha <= 0.01) {
return nil;
}
CGRect touchRect = CGRectInset(self.bounds, -14, -14);
if (CGRectContainsPoint(touchRect, point)) {
for (UIView *subview in [self.subviews reverseObjectEnumerator]) {
CGPoint convertedPoint = [subview convertPoint:point fromView:self];
UIView *hitTestView = [subview hitTest:convertedPoint withEvent:event];
if (hitTestView) {
return hitTestView;
}
}
return self;
}
return nil;
}
我需要使用另一种与 hitTest 相关的方法来使其正常工作吗?如果您需要查看更多代码,请告诉我。
解决方案
勾股定理在这里很有用。您可以获取用户触摸屏幕的点,然后使用 map() 计算到每个小瓶的距离并找到最小值:
let p1 = //where your user touched the view
let vialDistances = vials.map { // your vials array
let p2 = // vial position
let diffX = p1.x - p2.x
let diffY = p1.y - p2.y
return diffX * diffX + diffY * diffY
}
let index = find(vialDistances, vialDistances.min())
let closestVial = vials[index]
推荐阅读
- javascript - 两次导入同一个模块会引发 ReferenceError
- reactjs - graphql中的动态查询名称
- node.js - AWS Rabbitmq 与 nodejs 连接失败
- testing - 如何在 Jetpack Compose 中使用 Rotation Change 测试 rememberSaveable
- html - 如何在 IE7 中垂直对齐内联 div 元素?
- macos - 列出特定架构的所有应用程序(英特尔、Apple Silicon、通用或其他)
- java - 如何解决 Groovy 代码中的无效 URL?
- java - 无法从 Jena 的 jar 文件中的 owl 文件加载模型
- python-3.x - 在 Python 中使用多个绑定变量执行 Oracle SQL 查询
- python - 用第二个字典中的映射值替换字典值