【发布时间】:2013-07-15 20:50:09
【问题描述】:
我目前有一个应用程序,用户可以在其中拍照或从他们的照片库中选择。
在下一个控制器上,它将显示被选择/拍摄的图像。
我现在想做的是在图像视图之上显示某种视图。视图的边缘将是半透明的,并且有一个圆圈可以显示下方的图像(不是半透明的)。基本上这是选择图像的一部分。
然后我需要保存一些视图在屏幕上的位置,因为它也应该可以由用户移动。
解决这个问题的最佳方法是什么?
我需要一个可以移动的覆盖视图。圆圈将是固定大小,始终内部显示下方的图像视图,外部将是 0.5 半透明度,因此您仍然可以看到图像但不能完全看到。然后保存被移动的圆圈的位置?
---- 编辑 -----
这是我创建的示例图像。
我有一个视图,其中有一张照片作为 UIImageView(底层)。最重要的是,我正在尝试添加一个视图(如上图)。请注意,上面的图片实际上是建议的png。但是,此叠加层是可移动的。圆圈是透明的 (0),因此您可以完全看到它下面的照片。外部(灰色)部分透明(0.5),因此您仍然可以看到不完全。
顶视图(圆形部分)将在照片上四处移动以标记照片上的特定点。在这个例子中,如果圆圈移动了一边(灰色)在屏幕上结束,因此我需要制作一个考虑到视图移动的巨大图像——这肯定不是最好的方法吗?
编辑 2 ---- 我现在在 photoView 的顶部有一个 UIImageView(另一个 UIImageView)。叠加层是屏幕的 4 倍,中间有一个圆圈。
当项目被移动时,我会运行一个手势识别器:
-(void)handlePan:(UIPanGestureRecognizer *)gesture {
NSLog(@"Pan Gesture");
gesture.view.center = [gesture locationInView:self.view];
}
目前从上面看,UIImageView 是从中间点移动的,这样当手指移动时,圆圈看起来就是在移动。
这一切都很好,但是如何将建议的答案实现到我的 handlePan 方法中。所以我需要检查中间点是不是太靠近边缘。理想情况下,我希望屏幕周围有 50 个边距,这样圆圈看起来不会完全(或大部分)离开屏幕?
【问题讨论】:
-
它并不需要那么大 - 只需在圆圈的右侧和左侧提供一个边距 frame.size.width 并在顶部和底部提供 frame.size.height 就足够了确保用户不会看到灰色区域的边框
-
上面的例子是两个UIImageViews。底部的一个是照片,第二个是灰色区域和圆圈合二为一。边距如何仅增加灰色区域的宽度?
-
我的意思是把半透明和半透明区域一起移动,这样从圆的右边缘到半透明区域的右边缘的距离等于frame.size.width的UIImageView 下面。实际上,它可能小于这个值,具体取决于您希望圆圈移动多远。如果它必须保持在 imageView 的边界内,那么 imageView.frame.size.width - (circleRadius * 2) 在右侧和左侧应该足够了。 (以此类推,有高度,在顶部和底部)
-
对不起,我不明白,可以提交一个代码示例作为答案吗?
-
看看这是否有助于您的叠加视图 - stackoverflow.com/questions/11792563/…
标签: ios view uiimageview transparency uiresponder