项目中的一个优化案例,提升用户体验,对地铁线路图点击放大、缩小,并且点击位置居中;
正常ScrollView 我们点击某一点比如屏幕右侧,想要点的位置向左移动到中心位置,很简单只有算出该点位置距中心位置的距离:point.x - contentOffset.x -SCREEN_WIDTH*0.5,然后问设置contentOffset.x+相应的距离即可。上下也同理.
但是这里要处理的双击 放大的同时,也要实现上面的效果。经过单步调试,查看
- (void)scrollViewDidScroll:(UIScrollView *)scrollView 代理方法的log:
NSLog(@"%f--%f -%f",scrollView.contentOffset.x,scrollView.contentOffset.y,scrollView.zoomScale);
发现移动移动图上的某一点到达屏幕的边界contentOffset.x变化与缩放倍数成正比!!!正比!!!
在根据简单版的居中原理的方法,应用到缩放后的ScrollView中,所有相关参数都*相应的缩放倍数!!正比关系记得。
下面是具体实现代码 :(PS 有更好更简单实现方法欢迎提供交流,本文描述有不当处欢迎指正谢谢!!)
- (void)showPointToCenterWithPoint:(CGPoint)pt withZoomScale:(CGFloat)zs{ [UIView animateWithDuration:0.3 animations:^{ __block CGPoint point = pt; _baseScrollView.zoomScale = zs; CGFloat offsetX = _baseScrollView.contentOffset.x*zs; CGFloat offsetY = _baseScrollView.contentOffset.y*zs; CGFloat contentW = _baseScrollView.contentSize.width; CGFloat contentH = _baseScrollView.contentSize.height; CGFloat x = 0; CGFloat y = 0; point = CGPointMake(point.x*zs, point.y*zs); //右侧 if (offsetX + SCREEN_WIDTH < contentW && (point.x - offsetX) > SCREEN_WIDTH*0.5) { //居中所要移动的距离:(point.x - offsetX)-SCREEN_WIDTH*0.5) ;移动后 还没有超过边界即满足居中 if ((offsetX + (point.x - offsetX)-SCREEN_WIDTH*0.5) + SCREEN_WIDTH < contentW) { x = offsetX + (point.x - offsetX)- SCREEN_WIDTH*0.5; }else{ //不满足居中 x = offsetX + (contentW - offsetX - SCREEN_WIDTH); } }else{
//左侧 满足居中 if (offsetX - (SCREEN_WIDTH*0.5 - (point.x - offsetX))>=0) { x = offsetX - (SCREEN_WIDTH*0.5 - (point.x - offsetX)); }else{ x = 0; } } //下侧 if (offsetY + SCREEN_HEIGHT < contentH && (point.y - offsetY) > SCREEN_HEIGHT*0.5) { if ((offsetY + (point.y - offsetY)-SCREEN_HEIGHT*0.5) + SCREEN_HEIGHT < contentH) { y = offsetY + (point.y - offsetY)- SCREEN_HEIGHT*0.5; }else{ y = offsetY + (contentH - offsetY - SCREEN_HEIGHT); } }else{ if (offsetY - (SCREEN_HEIGHT*0.5 - (point.y - offsetY)) >= 0) { y = offsetY - (SCREEN_HEIGHT*0.5 - (point.y - offsetY)); }else{ y = 0; } } [_baseScrollView setContentOffset:CGPointMake(x, y)animated:NO]; } completion:^(BOOL finished) { }]; }