- (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辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
相关阅读更多精彩内容
- 项目中需求监测用户截屏行为 并生成图片诱导用户分享。像飞猪此类APP已经实现分享功能产品需求是改变用户系统截图的本...
- 写在前面 公司近期让做一个录制屏幕类的App,我研究了iOS9新增的Replaykit框架,使用起来确实挺简单的,...