恰好最近在作個商城項目,甲方爸爸說我們要求不高,你就照着淘寶來就好,額~~~~bash
好吧,咱就不吐槽了,直接開擼吧,慣例先上一下效果圖 ide
咱們要實現的功能有以下幾個:動畫
圖片的放大縮小以及平移功能能夠直接經過 UIScrollView 來實現,考慮到複用以及使用場景,因此就直接把功能都封裝在 UIImageView 裏,方便之後直接使用。ui
@interface LWShowImageView()<UIActionSheetDelegate,UIScrollViewDelegate>
/** 展現手勢*/
@property (nonatomic, strong) UITapGestureRecognizer *showTap;
/** 收起手勢*/
@property (nonatomic, strong) UITapGestureRecognizer *hideTap;
/** 長按手勢*/
@property (nonatomic, strong) UILongPressGestureRecognizer *longTap;
@property (nonatomic, strong) UIScrollView *scrollView;
@property (nonatomic, strong) UIImageView *newImageView;
@implementation LWShowImageView
{
CGRect _oldframe;//原始尺寸
CGRect _newframe;//新尺寸
CGFloat _scale;// 縮放比例
}
-(instancetype)init
{
if (self = [super init]) {
self.userInteractionEnabled = YES;
[self createGesture];
}
return self;
}
/** 建立手勢*/
-(void)createGesture
{
self.showTap= [[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(showImageView)];
[self addGestureRecognizer:self.showTap];
self.hideTap = [[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(hideImageView:)];
self.longTap = [[UILongPressGestureRecognizer alloc] initWithTarget:self action:@selector(viewLongPress:)];
self.longTap.minimumPressDuration = 1;
}
#pragma mark -- 懶加載
-(UIScrollView *)scrollView
{
if (!_scrollView) {
_scrollView = [[UIScrollView alloc] initWithFrame:CGRectMake(0, 0, [UIScreen mainScreen].bounds.size.width, [UIScreen mainScreen].bounds.size.height)];
[_scrollView setBackgroundColor:[UIColor colorWithRed:0/255.0 green:0/255.0 blue:0/255.0 alpha:1]];
[_scrollView setAlpha:0];
// 縮放級別
_scrollView.minimumZoomScale = 1;
_scrollView.maximumZoomScale = 8;
_scrollView.delegate = self;
// 添加回收手勢
[_scrollView addGestureRecognizer:self.hideTap];
// 添加長按手勢
[_scrollView addGestureRecognizer:self.longTap];
[_scrollView addSubview:self.newImageView];
}
return _scrollView;
}
-(UIImageView *)newImageView
{
if (!_newImageView) {
_newImageView = [[UIImageView alloc] initWithFrame:_oldframe];
[_newImageView setImage:self.image];
_newImageView.contentMode =UIViewContentModeScaleAspectFit;
}
return _newImageView;
}
複製代碼
#pragma MARK-- UIScrollViewDelegate
// 縮放後的視圖
- (UIView *)viewForZoomingInScrollView:(UIScrollView *)scrollView {
return self.newImageView;
}
// 調整視圖位置
- (void)scrollViewDidZoom:(UIScrollView *)scrollView {
CGRect frame = self.newImageView.frame;
frame.origin.y = (self.scrollView.frame.size.height - self.newImageView.frame.size.height) > 0 ? (self.scrollView.frame.size.height - self.newImageView.frame.size.height) * 0.5 : 0;
frame.origin.x = (self.scrollView.frame.size.width - self.newImageView.frame.size.width) > 0 ? (self.scrollView.frame.size.width - self.newImageView.frame.size.width) * 0.5 : 0;
self.newImageView.frame = frame;
self.scrollView.contentSize = CGSizeMake(self.newImageView.frame.size.width + 30, self.newImageView.frame.size.height + 30);
}
// 縮放比例
-(void)scrollViewDidEndZooming:(UIScrollView *)scrollView withView:(UIView *)view atScale:(CGFloat)scale
{
_scale = scale;
}
複製代碼
/**
* 全屏瀏覽
*/
-(void)showImageView
{
if (!self.image) {
// 圖片尚未加載完畢
return;
}
// 保存放大前的frame
_oldframe = [self convertRect:self.bounds toView:[UIApplication sharedApplication].keyWindow];
[[UIApplication sharedApplication].keyWindow addSubview:self.scrollView];
// 移除
[self removeGestureRecognizer:self.showTap];
// 動畫放大所展現的ImageView
[UIView animateWithDuration:0.4 animations:^{
CGFloat y,width,height;
y = ([UIScreen mainScreen].bounds.size.height - self.image.size.height * [UIScreen mainScreen].bounds.size.width / self.image.size.width) * 0.5;
width = [UIScreen mainScreen].bounds.size.width;
height = self.image.size.height * [UIScreen mainScreen].bounds.size.width / self.image.size.width;
_newframe = CGRectMake(0, y, width, height);
[self.newImageView setFrame:_newframe];
[self.scrollView setAlpha:1];
} completion:^(BOOL finished) {
}];
}
/**
* 恢復imageView原始尺寸
*/
- (void)hideImageView:(UITapGestureRecognizer *)tap{
if (_scale > 2.5) {
[self.newImageView setFrame:_newframe];
self.scrollView.contentSize = CGSizeMake(_newframe.size.width + 30, _newframe.size.height + 30);
}
// 恢復
[UIView animateWithDuration:0.4 animations:^{
[self.newImageView setFrame:_oldframe];
[self.scrollView setAlpha:0];
} completion:^(BOOL finished) {
[self addGestureRecognizer:self.showTap];
[self.newImageView removeFromSuperview];
self.newImageView = nil;
[self.scrollView removeFromSuperview];
self.scrollView = nil;
}];
}
/** 長按手勢*/
-(void)viewLongPress:(UILongPressGestureRecognizer *)sender
{
if (sender.state == UIGestureRecognizerStateBegan) {
UIActionSheet *actionSheet = [[UIActionSheet alloc]initWithTitle:@"保存圖片" delegate:self cancelButtonTitle:@"取消"destructiveButtonTitle:@"肯定" otherButtonTitles:nil];
[actionSheet showInView:self.scrollView];
}
}
複製代碼
-(void)actionSheet:(UIActionSheet *)actionSheet clickedButtonAtIndex:(NSInteger)buttonIndex
{
if (buttonIndex == 0) {
// 保存到相冊
UIImageWriteToSavedPhotosAlbum(self.image, self, @selector(image:didFinishSavingWithError:contextInfo:), (__bridge void *)self);
}
}
- (void)image:(UIImage *)image didFinishSavingWithError:(NSError *)error contextInfo:(void *)contextInfo
{
NSLog(@"image = %@, error = %@, contextInfo = %@", image, error, contextInfo);
}
複製代碼
至此,封裝工做所有完成。atom