截图

屏幕截图

- (void)touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event
{
    // 截屏,生成跟view一样的图片

    // 开启位图上下文
    UIGraphicsBeginImageContextWithOptions(self.view.bounds.size, NO, 0);

    // 获取当前上下文==>位图上下文
    CGContextRef ctx = UIGraphicsGetCurrentContext();


    // 获取view图层
    CALayer *vcLayer = self.view.layer;

    // 把图层渲染到上下文,图层只能渲染,不能绘制
    [vcLayer renderInContext:ctx];
//    [vcLayer drawInContext:ctx];



    // 从上下文中取出图片
    UIImage *image = UIGraphicsGetImageFromCurrentImageContext();

    // 关闭上下文
    UIGraphicsEndImageContext();

    // Quality:图片质量  当后面值为1时,质量最大,可以通过这种形式压缩图片
   NSData *data = UIImageJPEGRepresentation(image, 0.0000001);

    [data writeToFile:@"存储位置" atomically:YES];
}

图片截图

这里写图片描述
用SB拖线手势

@interface ViewController ()
@property (weak, nonatomic) IBOutlet UIImageView *imageView;

@property (nonatomic, assign) CGPoint startP;

@property (weak, nonatomic) IBOutlet UIView *redView;
@property (nonatomic, weak) UIView *cover;

@end

@implementation ViewController

- (UIView *)cover
{
    if (_cover == nil) {
        UIView *cover = [[UIView alloc] init];
        cover.backgroundColor = [UIColor blackColor];
        cover.alpha = 0.6;
        [self.view addSubview:cover];
        _cover = cover;
    }
    return _cover;
}

// 当手指在UIImageView上移动的时候调用
- (IBAction)pan:(UIPanGestureRecognizer *)sender {

    // 获取当前触摸点
    CGPoint curP = [sender locationInView:_imageView];
    if (sender.state == UIGestureRecognizerStateBegan) { // 开始拖动的时候调用
        // translationInView:获取手指的偏移量
        // locationInView:获取手指触摸点

        // 记录起始点
        _startP = curP;
    }
    // 计算裁剪区域
    CGFloat clipW = curP.x - _startP.x;
    CGFloat clipH = curP.y - _startP.y;
    CGRect clipR = CGRectMake(_startP.x, _startP.y, clipW, clipH);

    // 设置灰色蒙版尺寸
    self.cover.frame = clipR;

    if (sender.state == UIGestureRecognizerStateEnded) { // 手指抬起
        // 裁剪图片

        // 开启位图上下文
        UIGraphicsBeginImageContextWithOptions(_imageView.bounds.size, NO, 0);

        // 设置裁剪区域
        UIBezierPath *path = [UIBezierPath bezierPathWithRect:clipR];
        [path addClip];

        // 画图片
        [_imageView.layer renderInContext:UIGraphicsGetCurrentContext()];

        // 从上下文中获取图片
       UIImage *image =  UIGraphicsGetImageFromCurrentImageContext();

        // 关闭上下文
        UIGraphicsEndImageContext();

        _imageView.image = image;

        // 先移除
        [self.cover removeFromSuperview];
    }  
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,您的问题是关于如何用 Python 编写一个截图工具,包含点击按钮进入截屏状态,框选屏幕某个区域进行截图截图内容可保存于剪切板,并继续截图的功能。 首先,Python 中可用的常用截图库有两个,分别是 PIL 和 PyAutoGUI。PIL 负责处理图像,而 PyAutoGUI 则负责控制鼠标和键盘等操作。我们今天的实现选用 PyAutoGUI 库。 首先,您需要在您的 Python 环境中安装 PyAutoGUI 库,您可以使用 pip 命令安装(pip install pyautogui)。然后在您的代码中导入 PyAutoGUI 库和 tkinter 库。 接下来,您需要创建一个 GUI 界面,包含一个 “截图” 按钮。在 pyautogui 库中,使用 hotkey() 函数进行热键的注册。具体而言,代码如下: ``` python import tkinter as tk import pyautogui def take_screenshot(): # 执行截图功能 screenshot_image = pyautogui.screenshot() # 将截图保存至剪切板 pyautogui.hotkey('ctrl', 'c', image=screenshot_image) # 继续截图 m.mainloop() # 创建 tk 主窗口 m = tk.Tk() m.geometry('200x100') m.title("Screenshot Tool") # 创建按钮 screenshot_button = tk.Button(m, text='截图', command=take_screenshot) screenshot_button.pack() # 注册热键 m.bind('<Return>', take_screenshot) m.mainloop() ``` 上述代码中,我们定义了一个 take_screenshot() 函数来执行截图功能。此函数中,我们使用 pyautogui.screenshot() 函数来执行屏幕截图操作,并使用 pyautogui.hotkey() 函数将截图保存至剪切板。在本例中,我们使用 'ctrl' + 'c' 快捷键将图像复制到剪切板中。 最后,我们将 take_screenshot() 函数与截图按钮进行关联,并在主循环中使用 PyAutoGUI 的 hotkey() 函数注册一个快捷键(在本例中为 Enter 键),以便用户可以使用键盘快捷键来执行截图操作。 注意,由于 PyAutoGUI 涉及控制鼠标和键盘等操作,在运行代码之前请确保您的计算机鼠标指针和键盘处于安全区域内,以免造成一些不必要的损失。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值