iOS zoomToRect with duration [duplicate]
Possible Duplicate:
Any way of changing the duration of zoomToRect for UIScrollView?
Is there any way to replicate the behaviour of [UIScrollView zoomToRect:zoomRect animated:YES] suc开发者_高级运维h that the animation lasts for a given duration?
You can put this in your UIScrollView
subclass:
- (void)zoomToRect:(CGRect)rect animated:(BOOL)animated
{
[UIView animateWithDuration:(animated?0.3f:0.0f)
delay:0
options:UIViewAnimationOptionBeginFromCurrentState
animations:^{
[super zoomToRect:rect animated:NO];
}
completion:nil];
}
How about using:
[UIView beginAnimations:@"" context:nil];
[UIView setAnimationDuration:2.0]; //Or any other duration
[theScroll setContentOffset:offsetPoint]; //offsetPoint is a CGPoint that defines the point you want your scroller to show
[UIView commitAnimations];
The downside is that you need to calculate the exact CGPoint to achieve the correct offset you want to get to.
I managed to implement zoomToRect using some CA3DTransforms. I will paste the code here in case anyone is interested.
I had to keep the a reference to the original frame of the scrollView for this to work.
rect.origin.x = ((int)rect.origin.x) % (int)self.initialFrame.size.width;
float scale = MIN(self.initialFrame.size.width / rect.size.width,self.initialFrame.size.height / rect.size.height);
CGSize scaledFrameSize = CGSizeMake(self.initialFrame.size.width / scale, self.initialFrame.size.height / scale);
CGPoint middleOfFrame = CGPointMake(self.initialFrame.size.width / 2 ,self.initialFrame.size.height / 2);
CGPoint transformPoint = CGPointMake(rect.origin.x + scaledFrameSize.width / 2,rect.origin.y + scaledFrameSize.height/2);
CGPoint offsetToCenter = CGPointMake((scaledFrameSize.width - rect.size.width) / 2 * scale,( scaledFrameSize.height - rect.size.height)/ 2 * scale);
[UIView animateWithDuration:1 animations:^ {
self.layer.transform = CATransform3DConcat(CATransform3DConcat(CATransform3DConcat(CATransform3DMakeTranslation(middleOfFrame.x,middleOfFrame.y, 0),
CATransform3DMakeTranslation(-transformPoint.x, -transformPoint.y,0)),
CATransform3DMakeScale(scale, scale, 1)),
CATransform3DMakeTranslation(offsetToCenter.x, offsetToCenter.y, 0));
}];
精彩评论