- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我一直在尝试使用 CGAffinTransformScale 为 PhotoView (一个 UIImageView 实例)实现捏缩放/缩小(计划使用旋转,因此不能依靠帧进行缩放,并且会添加 subview ,因此 UIScrollView 会更复杂,我思考)。无论如何,这个概念很容易掌握,代码很快就组合在一起......从那时起,我一直试图使用三种不同的方法来解决相同的两个(相关的?!)问题,但一直无法做到这一点:1-我的代码以某种方式丢失了缩放中间的触摸计数(从 count = 2 到 count = 1)并返回到 iPhone 上的触摸计数,但模拟器上没有。2- 触摸点一和触摸点二在每次移动时都会来回跳跃几个像素,导致图像连续快速地缩小和放大,尽管总体效果是按照用户意图进行缩小或放大(两者都是) iPhone 和模拟器)。
代码如下:
#import "PhotoView.h"
@implementation PhotoView;
@synthesize originalCenter, distance, zooming;
- (id)initWithFrame:(CGRect)frame {
if (self = [super initWithFrame:frame]) {
// Initialization code
self.userInteractionEnabled = YES;
self.multipleTouchEnabled = YES;
zooming = NO;
}
return self;
}
float distanceBetweenTwoPoints(CGPoint point1, CGPoint point2)
{
NSLog(@"point1 x: %5.2f point 2 x: %5.2f ---- point 1 y: %5.2f point 2 y: %5.2f",point1.x,point2.x,point1.y,point2.y);
return (sqrt(pow(point1.x -point2.x,2) + pow(point1.y - point2.y,2)));
}
-(void) touchesBegan: (NSSet *) touches withEvent:(UIEvent *) event {
if ([touches count] > 1) {
NSLog(@"^^^^^^^^^^^^^^^Tocuhes began with double touch!");
distance = distanceBetweenTwoPoints([[[touches allObjects] objectAtIndex:0] locationInView:self],
[[[touches allObjects] objectAtIndex:1] locationInView:self]);
zooming = YES;
}
else {
zooming = NO;
origianlCenter = [[[touches allObjects] objectAtIndex:0] locationInView:self];
NSLog(@">>>>>>>>>>>>Touches began with single touch");
}
}
- (void)touchesEnded:(NSSet *)touches withEvent:(UIEvent *)event {
if (zooming) NSLog(@"!!!!!!!!!end zoom!!!!!!!");
zooming = NO;
if ([[touches anyObject] tapCount] == 2) {
UITouch *thisTouch = [touches anyObject];
CGPoint thisPoint = [thisTouch locationInView:self];
}
}
- (void) touchesMoved: (NSSet *) touches withEvent:(UIEvent *) event {
if ([touches count] > 1 && zooming) { // ignore if user added a second finger touch
float distanceNew = distanceBetweenTwoPoints([[[touches allObjects] objectAtIndex:0] locationInView:self],
[[[touches allObjects] objectAtIndex:1] locationInView:self]);
if (distance <= 0.f) { // should never be true - but it is sometimes!!!
distance = distanceNew;
}
float delta = 1.0f + ((distanceNew-distance)/distance);
self.transform = CGAffineTransformScale(self.transform, delta, delta);
distance = distanceNew;
}
else {
if (zooming) {
NSLog(@"*************shouldn't be here********* %d",[touches count]);
return;
}
CGPoint thisPoint = [[[touches allObjects] objectAtIndex:0] locationInView:self];
self.transform = CGAffineTransformTranslate(self.transform, thisPoint.x-originalCenter.x, thisPoint.y-originalCenter.y);
}
}
- (void)dealloc {
[super dealloc];
}
@end
日志示例:
^^^^^^^^^^^^^^^Tocuhes began with double touch!
point1 x: 87.33 point 2 x: 235.63 ---- point 1 y: 322.30 point 2 y: 117.09
point1 x: 90.76 point 2 x: 232.02 ---- point 1 y: 318.29 point 2 y: 123.51
point1 x: 86.22 point 2 x: 236.71 ---- point 1 y: 323.30 point 2 y: 117.42
point1 x: 89.51 point 2 x: 232.38 ---- point 1 y: 319.47 point 2 y: 123.47
point1 x: 84.97 point 2 x: 237.02 ---- point 1 y: 324.48 point 2 y: 116.56
*************shouldn't be here********* 1
point1 x: 88.49 point 2 x: 232.52 ---- point 1 y: 321.27 point 2 y: 122.91
*************shouldn't be here********* 1
point1 x: 83.95 point 2 x: 237.11 ---- point 1 y: 327.21 point 2 y: 116.96
!!!!!!!!!end zoom!!!!!!!
我开始怀疑我因为 CGAffinTransformScale 而失去了对触摸点的追踪;但是,我在网上没有发现任何内容表明这是一个问题。任何线索(包括“阅读 xyz 上的文档”)将不胜感激!
提前致谢。
最佳答案
也许是左字段的答案,但另一种方法可能是将 UIImageView 放入 UIScrollView 中,在 ScrollView 委托(delegate)上定义 viewForZoomingInScrollView:
方法,然后设置 maximumZoomScale
/minimumZoomScale
属性,您无需执行计算来自行设置变换即可进行捏缩放?我刚刚在最近的一个项目中做到了这一点,效果很好。
关于iPhone UIImageView 捏合缩放,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2135744/
我试图弄清楚为什么我的缩放在我的 OpenGL 相机上表现得很奇怪。它的目的是放大和缩小,但它的缩放非常随机。 这是我的代码: - (void)pinchDetected:(UIPinchGestur
我有一个带有 pdf 文件的 UIWebView。效果很好。但是我怎样才能启用pdf文件的缩放呢? 最佳答案 确保选中“缩放页面以适合” 关于pdf - 在 UIWebView 上启用缩放/捏合,我们
我使用 Ionic4 和 Angular8。 我想在智能手机上捏合/捏合屏幕。 我试过的以下说明已添加到 index.html。 但事与愿违,在真机上并没有运行。 我也试过了。 以下已添加到 . s
我有一个使用 canvas.drawLine 方法绘制图形的 onDraw 开发的运行图形库。在 onTouch 中,我实现了滚动功能。 现在我的客户想要缩放/捏合。是否可以在不重新绘制这些操作的情况
我被 UIScrollView 的问题困住了 我想在用户点击特定点时缩放 ScrollView ,并防止用户使用捏缩放手势放大/缩小,我该怎么做? [imgScroll setDelegate:sel
我的 map View 有一个 OnZoomListener,只要缩放比例发生变化,它就会被调用。这适用于底部的加号或减号按钮用于更改缩放比例的任何时候。但是,如果用户使用双指缩放来放大或缩小,则永远
我有一个 UITextView,可以在 UIImageView 中使用手势缩放、旋转和调整大小。当我缩放或调整它的大小然后输入一些文本时,文本容器会改变大小并且文本被截断。我尝试更改文本的大小以调整其
在 iPhone 上我只是这样做(而且它完美地工作): view.transform = CGAffineTransformRotate(transform, [(UIRotationGestureR
我已经从资源包中的 UIWebView 中加载了一个 PDF 文件。 现在,我无法缩放/收缩 PDF 文件。 我找到了以下 2 个相关链接,但没有一个答案被标记为正确 - How to zoom we
我正在做一个图像处理项目,我需要通过平移来拖动图像,通过旋转来旋转图像,通过捏合手势使图像变小和变大,最后通过双击禁用所有手势。如何实现这一目标,因为我对 Android 开发还很陌生。 提前致谢 最
我正在尝试将具有特定位置的 div(“childItem”)覆盖在具有背景图像的较大 div(“parentContainer”)之上。然后我使用 iscroll 允许在父 div 上捏合/缩放。这行
在 android 平板电脑上用谷歌浏览器打开的 html 页面上,我需要捕捉该用户已经做了一些放大(捏合)并在几秒钟后将其重置为默认值。 (缩小到默认屏幕大小。但我不想完全阻止缩放,我想允许它,但一
下面通过图文并茂的方式给大家分享下IOS手势操作(拖动、捏合、旋转、点按、长按、轻扫、自定义)的相关内容。 1、UIGestureRecognizer 介绍 手势识别在 iOS 中非常重要,他极大
谁能指导如何在 Angular 2 RC2 中使用移动手势。 可能是这样的: 从API可以看出 HAMMER_GESTURE_CONFIG HammerGestureConfig 下 @angula
不久前我在一家帆船公司制作了一个 WordPress 网站,xssailing.com并且当前将视口(viewport)设置为: 该站点在计算机上运行良好,我可以在 iPhone/iPad 上进行缩
ios 七种手势操作 今天为大家介绍一下ios 的七种手势,手势在开发中经常用到,所以就简单 通俗易懂的说下, 话不多说,直接看代码: 1、uigesturerecognizer 介绍 手势识
目前我正在尝试创建某种图像查看器,您可以在其中单击图像,然后以全尺寸显示该图像。现在我想给它添加手势来缩放。我想了解并查看如何添加捏合手势来放大和缩小,以便能够在图像周围平移并使用双击手势快速放大。我
我正在尝试使 ImageView 像 Instagram 故事帖 subview 一样工作。我在 UIImageView 上添加了 UIPinchGestureRecognizer、UIPanGest
我是一名优秀的程序员,十分优秀!