图片截屏的是现实思路

- (IBAction)pan:(UIPanGestureRecognizer *)pan{
    //获取当前手指所在的点.
    CGPoint curP = [pan locationInView:self.view];
    if(pan.state == UIGestureRecognizerStateBegan){
        
        CGPoint startP = curP;
        self.startP = startP;
        
    }else if(pan.state == UIGestureRecognizerStateChanged){
        
        CGFloat offsetX = curP.x - self.startP.x;
        CGFloat offsetY = curP.y - self.startP.y;
        //确定遮盖的区域位置
        CGRect rect = CGRectMake(self.startP.x, self.startP.y, offsetX, offsetY);
        //每次移动时,调用遮盖的Frame.
        self.coverView.frame = rect;
        
        
    }else if(pan.state == UIGestureRecognizerStateEnded){
        
        
        //1.开启一个跟原始图片相同大小的图片上下文.
        UIGraphicsBeginImageContextWithOptions(self.imageV.bounds.size, NO, 0);
        //把self.cover.frame 设为裁剪区域
        UIBezierPath *path = [UIBezierPath bezierPathWithRect:self.coverView.frame];
        [path addClip];
        //获取当前上下文.
        CGContextRef ctx = UIGraphicsGetCurrentContext();
        //把UIImageView当中的图片给绘制上下文当中.
        [self.imageV.layer renderInContext:ctx];
        //从上下文当中生成一张新的图片
        UIImage *newImage = UIGraphicsGetImageFromCurrentImageContext();
        //关闭上下文.
        UIGraphicsEndImageContext();
        //给图片重新赋值
        self.imageV.image = newImage;
        //移除遮盖
        [self.coverView removeFromSuperview];
        
    }
    
    
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容