[绍棠] 通过捏合手势缩放图片

{

    UIImage* srcImage;

    CGFloat currentScale;

}


- (void)setupUI {

    self.coverImage = [[UIImageView alloc] initWithFrame:CGRectZero];

    [self.view addSubview:self.coverImage];

    [self.coverImage mas_makeConstraints:^(MASConstraintMaker *make) {

        make.left.right.equalTo(self.coverImage.superview);

        make.top.equalTo(self.navView.mas_bottom).offset(0);

        make.height.equalTo(@((ScreenWidth*9/16)));

    }];

    self.coverImage.contentMode = UIViewContentModeCenter;

    self.coverImage.backgroundColor = [UIColor grayColor];

    self.coverImage.layer.masksToBounds = YES;

    [self.coverImage setUserInteractionEnabled:YES];

    [self.coverImage setMultipleTouchEnabled:YES];

    // 捏合手势

    UIPinchGestureRecognizer *pinchGestureRecognizer = [[UIPinchGestureRecognizer alloc] initWithTarget:self action:@selector(pinchView:)];

    [self.coverImage addGestureRecognizer:pinchGestureRecognizer];

}


#pragma mark - 手势处理

// 处理缩放手势

- (void) pinchView:(UIPinchGestureRecognizer *)pinchGestureRecognizer

{

    CGFloat scale = pinchGestureRecognizer.scale;

    // 如果捏合手势刚刚开始

    if (pinchGestureRecognizer.state == UIGestureRecognizerStateBegan)

    {       // 计算当前缩放比

        currentScale = self.coverImage.image.size.width / srcImage.size.width;

    }

    // 根据手势处理器的缩放比例计算图片缩放后的目标大小

    CGSize targetSize = CGSizeMake(srcImage.size.width * scale * currentScale,

                                   srcImage.size.height * scale * currentScale);

    // 对图片进行缩放

    self.coverImage.image = [srcImage scaleToSize:targetSize];

}


注:scaleToSize:是对图片进行缩放的方法, 是UIImage类的扩展

内部实现

- (UIImage *)scaleToSize:(CGSize)size {

    UIGraphicsBeginImageContext(size);

    [self drawInRect:CGRectMake(0,0, size.width, size.height)];

    UIImage * scaledImage = UIGraphicsGetImageFromCurrentImageContext();

    UIGraphicsEndImageContext();

    return scaledImage;

}




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值