使用UIScrollView縮放圖片并保持圖片在屏幕中心的正確方式(+雙擊圖片以點擊坐標為中心縮放):

//變量定義
@property(strong,nonatomic)UIImageView *imgView;
@property(strong,nonatomic)UIImage *image;
@property(strong,nonatomic)UIScrollView *bgView ;
float maxScale=2.0f;
BOOL isTwiceTaping;

//-----------------設置UIScrollView-----------------------
//初始化
_bgView = [[UIScrollView alloc] init];
_bgView.frame = [UIScreen mainScreen].bounds;
_bgView.backgroundColor = [UIColor blackColor];
_imgView = [[UIImageView alloc] initWithImage:_image];
[_imgView setContentMode:UIViewContentModeScaleAspectFit];
[_bgView addSubview:_imgView];

// 設置_imgView的位置大小
CGRect frame ;
frame.size.width = bgView.frame.size.width;
frame.size.height =frame.size.width*(_image.size.height/_image.size.width);
_imgView.frame = frame;
_imgView.center=bgView.center;
[[[UIApplication sharedApplication] keyWindow] addSubview:bgView];

// 設置WindowLevel與狀態(tài)欄平級,起到隱藏狀態(tài)欄的效果
[[[UIApplication sharedApplication] keyWindow] setWindowLevel:UIWindowLevelStatusBar];

//設置最大放大比例、內容大小和代理
_bgView.maximumZoomScale = maxScale;
_bgView.contentSize=_imgView.frame.size;
_bgView.delegate = self;

//隱藏滾動條
_bgView.showsVerticalScrollIndicator = NO;
_bgView.showsHorizontalScrollIndicator = NO;

//添加雙擊手勢
 UITapGestureRecognizer *tapTwice = [[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(tapTwiceAction:)];
    tapTwice .numberOfTapsRequired = 2;
    tapTwice .numberOfTouchesRequired = 1;
    [_bgView addGestureRecognizer:tapTwice];
//----------------------雙擊手勢操作----------------------
-(void)tapTwiceAction:(UIGestureRecognizer *)sender{
    if(isTwiceTaping){//三次點擊不執(zhí)行
        return;
    }
    isTwiceTaping = YES;
    CGFloat newScale;
    if(_bgView.zoomScale>1){
        newScale=1.0;
    }else{
        newScale=maxScale;
    }
    CGRect zoomRect = [self zoomRectForScale:newScale withCenter:[sender locationInView:sender.view]];
    [_bgView zoomToRect:zoomRect animated:YES];
    //延時做標記判斷,使用戶點擊3次時的單擊效果不生效。
    [self performSelector:@selector(tapTimes) withObject:nil afterDelay:0.35];
    
}
-(void)tapTimes{
    isTwiceTaping = NO;
}
- (CGRect)zoomRectForScale:(float)scale withCenter:(CGPoint)center
{
    CGRect zoomRect;
    zoomRect.size.height =_bgView.frame.size.height / scale;
    zoomRect.size.width  =_bgView.frame.size.width  / scale;
    zoomRect.origin.x = center.x - (zoomRect.size.width  /2);
    zoomRect.origin.y = center.y - (zoomRect.size.height /2);
    return zoomRect;
}

//------------------------ScrollView代理方法----------------------

-(UIView *)viewForZoomingInScrollView:(UIScrollView *)scrollView

{
return _imgView;
}

- (void)scrollViewDidZoom:(UIScrollView *)scrollView
{
CGFloat xcenter = scrollView.center.x , ycenter = scrollView.center.y;
//目前contentsize的width是否大于原scrollview的contentsize,如果大于,設置imageview中心x點為contentsize的一半,以固定imageview在該contentsize中心。如果不大于說明圖像的寬還沒有超出屏幕范圍,可繼續(xù)讓中心x點為屏幕中點,此種情況確保圖像在屏幕中心。

xcenter = scrollView.contentSize.width > scrollView.frame.size.width ? scrollView.contentSize.width/2 : xcenter;

ycenter = scrollView.contentSize.height > scrollView.frame.size.height ? scrollView.contentSize.height/2 : ycenter;

[_imgView setCenter:CGPointMake(xcenter, ycenter)];
}

參考:http://blog.163.com/it__man/blog/static/1371999042013565147299/

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
【社區(qū)內容提示】社區(qū)部分內容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發(fā)布,文章內容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內容

友情鏈接更多精彩內容