蝈蝈这两天正忙着收拾家当去公司报道,结果做PHP的发小蛐蛐找到了他,说是想要一个可以截图工具。

大致需要做出这样的效果。

虽然已经很久不写Python代码了,但是没办法,盛情难却啊,只好硬着头皮上了。


关于这个需求,蝈蝈想了想,脑海里大概有这么几个实现的方式。

  • 调用QQ的截图工具。
  • 自己写一个。

这第一个嘛,应了那句老话。理想很丰满,现实很骨感。因为被集成的缘故,剖不出来是没办法用的,自认为技术还不到家的蝈蝈很快放弃了这个方法。

那么只能自己写一个了。从谷哥那了解到PIL的ImageGrab可以很方便的截图,默认截图是全屏范围,当然也可以传递一个Bbox元组来实现截图的范围截图。于是思路就很明确了:获取鼠标位置,调用ImageGrab截图


获取鼠标位置

这个嘛,其实还是很简单的。借助pyHook就可以啦。

global old_x, old_y, new_x, new_y, full, hm
    if event.MessageName == "mouse left down":
        old_x, old_y = event.Position
    if event.MessageName == "mouse left up":
        new_x, new_y = event.Position

按下鼠标的那一刻开始记录初始坐标,然后鼠标抬起的那一刻更新结束坐标。这两个坐标的范围就是要截图的范围。这里面需要注意的就是鼠标坐标默认从左上角(0, 0)开始


截图的具体实现

关于具体实现,无非是一个full标记,默认也是截全屏的图,当fullFalse的时候,按照两次鼠标的绝对位置实现范围截图。

# 划屏
    if full:
        image = ImageGrab.grab((0, 0, gsm(0), gsm(1)))
    else:
        image = ImageGrab.grab((old_x, old_y, new_x, new_y))
    image.show()

好啦,核心功能已经做好啦。为了方便蛐蛐进行自定义的拓展,蝈蝈把源码发给了他。

# coding: utf8

# @Author: 郭 璞
# @File: capture.py
# @Time: 2017/7/24
# @Contact: 1064319632@qq.com
# @blog: http://blog.csdn.net/marksinoberg
# @Description: 根据鼠标移动进行划屏截图

import pyHook
import pythoncom
import win32gui
from PIL import Image, ImageGrab
from win32api import GetSystemMetrics as gsm

# 提前绑定鼠标位置事件
old_x, old_y = 0, 0
new_x, new_y = 0, 0
def hotkey(key=None):
    """绑定热键,开始进行划屏截图操作"""
    pass

def on_mouse_event(event):
    global old_x, old_y, new_x, new_y, full, hm
    if event.MessageName == "mouse left down":
        old_x, old_y = event.Position
    if event.MessageName == "mouse left up":
        new_x, new_y = event.Position
        # 解除事件绑定
        hm.UnhookMouse()
        hm = None

    # 划屏
    if full:
        image = ImageGrab.grab((0, 0, gsm(0), gsm(1)))
    else:
        image = ImageGrab.grab((old_x, old_y, new_x, new_y))
    image.show()

full = False
hm = None
def capture():

    hm = pyHook.HookManager()
    hm.SubscribeMouseAll(on_mouse_event)
    hm.HookMouse()
    pythoncom.PumpMessages()

capture()

核心功能已经算是完成了,虽然貌似并没有什么太大的用处。


因为就要走了,所以蝈蝈没有多少时间来润色,只能这样匆匆交差了。除了代码,蝈蝈特意嘱咐了下面这几句话:

  • 增加保存到本地功能。
  • 绑定系统快捷键,这样打游戏的时候也可以截图。
  • 增加蒙层,截图的时候提供更好的用户体验。

蛐蛐听完之后,貌似也有了自己的想法,然后就自己琢磨去了。其实他不知道的是,蝈蝈对于截到的图的另一层处理。

简易图片相似度分析

# coding: utf8

# @Author: 郭 璞
# @File: similar.py
# @Time: 2017/7/23
# @Contact: 1064319632@qq.com
# @blog: http://blog.csdn.net/marksinoberg
# @Description: 两张图片相似度计算实现。

from PIL import Image

def pixel_way(img1, img2):
    image1 = Image.open(img1, 'r')
    image2 = Image.open(img2, 'r')

    return get_pixel_details(image1)==get_pixel_details(image2)

def get_pixel_details(img):
    pixels = img.load()
    r, g, b = 0, 0, 0
    counter = 0
    for x in range(img.size[0]):
        for y in range(img.size[1]):
            counter += 1
            r1, g1, b1 = pixels[x, y]
            r += r1
            g += g1
            b += b1
    return (r/counter, g/counter, b/counter)

if __name__ == '__main__':
    image1 = r'./1.png'
    image2 = r'./1.png'
    img = Image.open(image1, 'r')
    img.resize((256,256)).convert("RGB")
    print(pixel_way(image1, image2))

图片像素直方图

# coding: utf8

# @Author: 郭 璞
# @File: pixel-compare.py
# @Time: 2017/7/24
# @Contact: 1064319632@qq.com
# @blog: http://blog.csdn.net/marksinoberg
# @Description: 计算RGB值相关

from PIL import Image
from PIL import ImageDraw

im = Image.open('1.png')
im = im.convert("L")

width, height = im.size
pix = im.load()
a = [0]*256
for w in range(width):
    for h in range(height):
        p = pix[w, h]
        a[p] = a[p] + 1

x = max(a)
print(a, "---", len(a), '-----', x)

image = Image.new('RGB', (256, 256), (255, 255, 255))
draw = ImageDraw.Draw(image)

for k in range(256):
    a[k] = a[k]*200/x
    source = (k, 255)
    target = (k, 255-a[k])
    draw.line([source, target], (100, 100, 100))

image.show()

还有很多更好玩的,但是有时候,话多,不是一件好事,想到这里,蝈蝈又不自觉的回忆起了那段不堪的帮忙的经历,无奈……

                                      the end.

Python自定义大小截屏的更多相关文章

  1. Python 实现网页截屏、查库、发邮件

    本文介绍了使用 Python(2.7版本)实现网页截屏.查库.发邮件的 demo.用到了 selenium.phantomjs.mailer.jinja2.mysqldb 还有 image,都是比较典 ...

  2. 简单易用的PIL,教你如何使用python实现自动化截屏

    Python有个第三方模块叫做PIL是Python Imaging Library的缩写,是用来进行图像处理的,比如,改变图片颜色,图片缩放,图片裁剪等等基本图片操作.它还包含一个截屏的功能. 从以上 ...

  3. cocos2dx 3.2 Touch Listen和menu回调实现截屏

    在Cocos2d-X 3.x里面,已经集成了截屏功能,单独放在utils命名空间里,实现在base/ccUtils.h文件里面.看下函数申明 /** Capture the entire screen ...

  4. MonkeyRunner 实现自动点击截屏后与本地图库进行对比输出

    先说下本人是菜鸟,通过网上资料学习,终于调通了MonkeyRunner 实现自动点击截屏后与本地图库进行对比输出,以后做静态UI测试就不需要眼睛盯着看图了,这一切交给MonkeyRunner了. 首先 ...

  5. 使用Python中PIL图形库进行截屏

    目的:通过使用Python的一个图形库PIL(Python Image Library)对屏幕进行截图 步骤: 1.下载PIL(路径)并安装 2.新建文件“截屏.py”,右键Edit with IDL ...

  6. Python: 截屏

    最近项目中想实现截屏功能,使用的笔记本是高清屏,实际屏幕设置成了150%,所以在截屏的时候遇到个各种问题. 最开始使用PIL ImageGrab来截取屏幕,如果本来是100%的设置没有问题,能截取到全 ...

  7. < python PIL - 批量图像处理 - 生成自定义大小图像 >

    < python PIL - 批量图像处理 - 生成自定义大小图像 > 直接用python自带的PIL图像库,对一个文件夹下所有jpg/png的图像进行自定义像素变换 from PIL i ...

  8. python 调用麦克风;摄像头;截屏;

    # -*- coding: utf-8 -*- """ Created on Mon Jun 24 14:47:35 2019 @author: erio "& ...

  9. robotFramework——截屏

    测试执行过程中进行截屏并且保存,是任何一款自动化测试工具或者框架必备的功能.那么Robotframework如何进行截屏呢?Robotframework提供了一个“Screenshot”库.    使 ...

随机推荐

  1. 20145109 实验四 Andoid开发基础

    安装Android 打开 默认程序中有helloworld 按下下图红框中的键: 遇到问题: 方法:修改build.gradle

  2. SaltStack配置salt-api第十二篇

    介绍 SaltStack官方提供有REST API格式的 salt-api项目,将使Salt与第三方系统集成变得尤为简单.本文讲带你了解如何安装配置Salt-API, 如何利用Salt-API获取想要 ...

  3. Pandas学习1

    pandas有两种自己独有的基本数据结构Series和DataFrame Series 数据结构 data 100 300 500 index 0 1 2 或者 index data 0 100 1 ...

  4. 【Detection】R-FCN: Object Detection via Region-based Fully Convolutional Networks论文分析

    目录 0. Paper link 1. Overview 2. position-sensitive score maps 2.1 Background 2.2 position-sensitive ...

  5. counting the buildings - 第一类斯特灵数

    2017-08-10 21:10:08 writer:pprp //TLE #include <iostream> #include <cstdio> #include < ...

  6. Generator 函数的异步应用

    异步编程对 JavaScript 语言太重要.Javascript 语言的执行环境是“单线程”的,如果没有异步编程,根本没法用,非卡死不可.本章主要介绍 Generator 函数如何完成异步操作. 传 ...

  7. iQuery移动端手势事件插件-jGestures

    jGestures下载 jGestures事件简介 orientationchange 代表设备顺时针或者逆时针旋转.此事件可以被设备触发,可能使用的是重力传感器. pinch 缩放手势(两个手指在屏 ...

  8. [Vue]Scoped Css与Css Modules的区别

    均为解决CSS全局作用域问题(样式冲突(污染))的一个解决方案. 1.Scoped CSS 当 <style> 标签有 scoped 属性时,相当于在元素中添加了一个唯一属性用来区分. & ...

  9. Javascript中的void

    原来void是将其后的字面量当元表达式执行,并永远返回undefined.同时undefined不是关键词.. 由于JS表达式偏啰嗦,于是最近便开始采用Coffeescript来减轻负担.举个栗子,当 ...

  10. Java多态性的理解2

    多态的基础理解请参考:http://www.cnblogs.com/liujinhong/p/6003144.html Java的多态一直是我们理解的一个难点.在读过<深入理解Java虚拟机&g ...