小編給大家分享一下Python如何實現(xiàn)可自定義大小的截屏功能,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
創(chuàng)新互聯(lián)是一家專注于網(wǎng)站制作、成都做網(wǎng)站與策劃設(shè)計,站前網(wǎng)站建設(shè)哪家好?創(chuàng)新互聯(lián)做網(wǎng)站,專注于網(wǎng)站建設(shè)十多年,網(wǎng)設(shè)計領(lǐng)域的專業(yè)建站公司;建站業(yè)務(wù)涵蓋:站前等地區(qū)。站前做網(wǎng)站價格咨詢:13518219792大致需要做出這樣的效果。
雖然已經(jīng)很久不寫Python代碼了,但是沒辦法,盛情難卻啊,只好硬著頭皮上了。
關(guān)于這個需求,蟈蟈想了想,腦海里大概有這么幾個實現(xiàn)的方式。
① 調(diào)用QQ的截圖工具。
② 自己寫一個。
這第一個嘛,應(yīng)了那句老話。理想很豐滿,現(xiàn)實很骨感。因為被集成的緣故,剖不出來是沒辦法用的,自認為技術(shù)還不到家的蟈蟈很快放棄了這個方法。
那么只能自己寫一個了。從谷哥那了解到PIL的ImageGrab可以很方便的截圖,默認截圖是全屏范圍,當(dāng)然也可以傳遞一個Bbox元組來實現(xiàn)截圖的范圍截圖。于是思路就很明確了:獲取鼠標(biāo)位置,調(diào)用ImageGrab截圖
獲取鼠標(biāo)位置
這個嘛,其實還是很簡單的。借助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
按下鼠標(biāo)的那一刻開始記錄初始坐標(biāo),然后鼠標(biāo)抬起的那一刻更新結(jié)束坐標(biāo)。這兩個坐標(biāo)的范圍就是要截圖的范圍。這里面需要注意的就是鼠標(biāo)坐標(biāo)默認從左上角(0, 0)開始。
截圖的具體實現(xiàn)
關(guān)于具體實現(xiàn),無非是一個full標(biāo)記,默認也是截全屏的圖,當(dāng)full為False的時候,按照兩次鼠標(biāo)的絕對位置實現(xiàn)范圍截圖。
# 劃屏 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()
好啦,核心功能已經(jīng)做好啦。為了方便蛐蛐進行自定義的拓展,蟈蟈把源碼發(fā)給了他。
# coding: utf8 # @Author: 郭 璞 # @File: capture.py # @Time: 2017/7/24 # @Contact: 1064319632@qq.com # @blog: http://blog.csdn.net/marksinoberg # @Description: 根據(jù)鼠標(biāo)移動進行劃屏截圖 import pyHook import pythoncom import win32gui from PIL import Image, ImageGrab from win32api import GetSystemMetrics as gsm # 提前綁定鼠標(biāo)位置事件 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()
核心功能已經(jīng)算是完成了,雖然貌似并沒有什么太大的用處。
因為就要走了,所以蟈蟈沒有多少時間來潤色,只能這樣匆匆交差了。除了代碼,蟈蟈特意囑咐了下面這幾句話:
① 增加保存到本地功能。
② 綁定系統(tǒng)快捷鍵,這樣打游戲的時候也可以截圖。
③ 增加蒙層,截圖的時候提供更好的用戶體驗。
蛐蛐聽完之后,貌似也有了自己的想法,然后就自己琢磨去了。其實他不知道的是,蟈蟈對于截到的圖的另一層處理。
簡易圖片相似度分析
# coding: utf8 # @Author: 郭 璞 # @File: similar.py # @Time: 2017/7/23 # @Contact: 1064319632@qq.com # @blog: http://blog.csdn.net/marksinoberg # @Description: 兩張圖片相似度計算實現(xiàn)。 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值相關(guān) 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()
以上是“Python如何實現(xiàn)可自定義大小的截屏功能”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計公司行業(yè)資訊頻道!
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機、免備案服務(wù)器”等云主機租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。