美文网首页
截屏与图片的截屏

截屏与图片的截屏

作者: Z了个L | 来源:发表于2017-01-24 21:05 被阅读26次
  • 布局图:
  • 主要代码:

// ViewController.h
#import <UIKit/UIKit.h>

@interface ViewController : UIViewController


@end

// ViewController.m
#import "ViewController.h"

@interface ViewController ()

@property (weak, nonatomic) IBOutlet UIImageView *imageV;

@property (nonatomic, assign)CGPoint startP;

@property (nonatomic, weak) UIView *coverView;

@end

@implementation ViewController

// 懒加载:1.什么时候用到什么时候才去创建
//      2.保持当前的View在内存当中只有一份.
//      3.保持用到View时,肯定是有值的.
-(UIView *)coverView {

    if (_coverView == nil) {
        //创建UIView
        UIView *coverView = [[UIView alloc] init];
        coverView.backgroundColor = [UIColor blackColor];
        coverView.alpha = 0.7;
        _coverView = coverView;
        [self.view addSubview:coverView];
    }
    return _coverView;

}

- (IBAction)pan:(UIPanGestureRecognizer *)pan {

    //获取当前手指所在的点
    CGPoint curP = [pan locationInView:self.imageV];
    //判断手势的状态
    if(pan.state == UIGestureRecognizerStateBegan) {
        //记录当前手指的开始点
        self.startP = curP;

    } else if(pan.state == UIGestureRecognizerStateChanged) {

        //rect
        CGFloat w = curP.x - self.startP.x;
        CGFloat h = curP.y - self.startP.y;
        CGRect rect = CGRectMake(self.startP.x, self.startP.y, w, h);

        self.coverView.frame = rect;

    } else if(pan.state == UIGestureRecognizerStateEnded) {


        // 生成一张图片
        // 1.开启位图上下文
        UIGraphicsBeginImageContext(self.imageV.bounds.size);

        // 2.设置裁剪区域
        UIBezierPath *path = [UIBezierPath bezierPathWithRect:self.coverView.frame];
        [path addClip];

        // 3.把UIImageV当中的内容渲染到上下文当中
        // 拿到当前上下文
        CGContextRef ctx = UIGraphicsGetCurrentContext();
        [self.imageV.layer renderInContext:ctx];

        // 4.从上下文当中获取图片
        UIImage *newImage = UIGraphicsGetImageFromCurrentImageContext();

        // 5.关闭上下文
        UIGraphicsEndImageContext();

        self.imageV.image = newImage;

        [self.coverView removeFromSuperview];
    }

}



- (void)viewDidLoad {
    [super viewDidLoad];
}


-(void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event {
    // 截屏
//    [self screenCapture];
}

// 截屏
- (void)screenCapture {
    // 生成图片
    // 1.开启一个位图上下文
    UIGraphicsBeginImageContext(self.view.bounds.size);
    // 拿到当前上下文,即当前位图上下文
    CGContextRef ctx =  UIGraphicsGetCurrentContext();
    // 2.把View的内容绘制到上下文当中
    // UIView内容想要绘制到上下文当中, 必须使用渲染的方式
    [self.view.layer renderInContext:ctx];
    // 3.从上下文当中生成一张图片
    UIImage *newImage = UIGraphicsGetImageFromCurrentImageContext();
    // 4.关闭上下文
    UIGraphicsEndImageContext();
    // 把图片转成二进制流
    // NSData *data = UIImageJPEGRepresentation(newImage, 1); // 1代表不压缩
    NSData *data = UIImagePNGRepresentation(newImage);

    [data writeToFile:@"/Users/apple/Desktop/newImage.png" atomically:YES];
}

@end

  • 赠送一个福利

// UIImage+Image.h
#import <UIKit/UIKit.h>

@interface UIImage (Image)


// 根据颜色生成一张尺寸为1*1的相同颜色图片
+ (UIImage *)imageWithColor:(UIColor *)color;


@end

// UIImage+Image.m
#import "UIImage+Image.h"

@implementation UIImage (Image)

+ (UIImage *)imageWithColor:(UIColor *)color {
    // 描述矩形
    CGRect rect = CGRectMake(0.0f, 0.0f, 1.0f, 1.0f);

    // 开启位图上下文
    UIGraphicsBeginImageContext(rect.size);
    // 获取位图上下文
    CGContextRef context = UIGraphicsGetCurrentContext();
    // 使用color演示填充上下文
    CGContextSetFillColorWithColor(context, [color CGColor]);
    // 渲染上下文
    CGContextFillRect(context, rect);
    // 从上下文中获取图片
    UIImage *theImage = UIGraphicsGetImageFromCurrentImageContext();
    // 结束上下文
    UIGraphicsEndImageContext();

    return theImage;
}


@end

  • 效果:

相关文章

  • 读袁靖老师关于长城保护的政协提案有感(修订版)

    截屏图片一: 截屏图片二: 截屏图片三: 截屏图片四: 正文: 当看到袁靖老师这一政协提案时,第一印象,这...

  • 截屏与图片的截屏

    布局图: 主要代码: 赠送一个福利 效果:

  • 如何成为一名有货的新媒体运营者

    图片制作 Snagit:支持滚动截屏 Faststone Capture:滚动截屏、自定义截屏、录制视频制作GIF...

  • android 截屏实现

    Android 截屏分为四种:View 截屏、WebView 截屏、系统截屏 和 adb 截屏 1、View 截屏...

  • Quartz 2D (2)

    1、圆形图片裁剪 2、实现手机屏幕截屏功能(把控制器中View的内容截屏生成一张新的图片) 3、图片截屏 4、图片...

  • Android 截屏方式整理

    Android 实现截屏方式整理 可能的需求: 截自己的屏 截所有的屏 带导航栏截屏 不带导航栏截屏 截屏并编辑选...

  • 安卓截图笔记

    Android截屏 Android截屏的原理:获取具体需要截屏的区域的Bitmap,然后绘制在画布上,保存为图片后...

  • Android截屏方案

    Android截屏 Android截屏的原理:获取具体需要截屏的区域的Bitmap,然后绘制在画布上,保存为图片后...

  • iOS 截屏&长截屏

    截屏在 iOS 开发中经常用到,本篇文章讲的是监听用户截屏操作,并且获取截屏图片,如果当前是UIScrollVie...

  • 图片截屏

    //1.开启图片上下文 UIGraphicsBeginImageContextWithOptions(self.v...

网友评论

      本文标题:截屏与图片的截屏

      本文链接:https://www.haomeiwen.com/subject/fxftittx.html