python自動裁剪圖像代碼分享
本代碼可以幫你自動剪切掉圖片的邊緣空白區(qū)域,如果你的圖片有大片空白區(qū)域(只要是同一顏色形成一定的面積就認為是空白區(qū)域),下面的python代碼可以幫你自動切除,如果是透明圖像,會自動剪切大片的透明部分。
本代碼需要PIL模塊
pil相關介紹
PIL:Python Imaging Library,已經是Python平臺事實上的圖像處理標準庫了。PIL功能非常強大,但API卻非常簡單易用。
由于PIL僅支持到Python 2.7,加上年久失修,于是一群志愿者在PIL的基礎上創(chuàng)建了兼容的版本,名字叫Pillow,支持最新Python 3.x,又加入了許多新特性,因此,我們可以直接安裝使用Pillow。
import Image, ImageChops def autoCrop(image,backgroundColor=None): '''Intelligent automatic image cropping. This functions removes the usless "white" space around an image. If the image has an alpha (tranparency) channel, it will be used to choose what to crop. Otherwise, this function will try to find the most popular color on the edges of the image and consider this color "whitespace". (You can override this color with the backgroundColor parameter) Input: image (a PIL Image object): The image to crop. backgroundColor (3 integers tuple): eg. (0,0,255) The color to consider "background to crop". If the image is transparent, this parameters will be ignored. If the image is not transparent and this parameter is not provided, it will be automatically calculated. Output: a PIL Image object : The cropped image. ''' def mostPopularEdgeColor(image): ''' Compute who's the most popular color on the edges of an image. (left,right,top,bottom) Input: image: a PIL Image object Ouput: The most popular color (A tuple of integers (R,G,B)) ''' im = image if im.mode != 'RGB': im = image.convert("RGB") # Get pixels from the edges of the image: width,height = im.size left = im.crop((0,1,1,height-1)) right = im.crop((width-1,1,width,height-1)) top = im.crop((0,0,width,1)) bottom = im.crop((0,height-1,width,height)) pixels = left.tostring() + right.tostring() + top.tostring() + bottom.tostring() # Compute who's the most popular RGB triplet counts = {} for i in range(0,len(pixels),3): RGB = pixels[i]+pixels[i+1]+pixels[i+2] if RGB in counts: counts[RGB] += 1 else: counts[RGB] = 1 # Get the colour which is the most popular: mostPopularColor = sorted([(count,rgba) for (rgba,count) in counts.items()],reverse=True)[0][1] return ord(mostPopularColor[0]),ord(mostPopularColor[1]),ord(mostPopularColor[2]) bbox = None # If the image has an alpha (tranparency) layer, we use it to crop the image. # Otherwise, we look at the pixels around the image (top, left, bottom and right) # and use the most used color as the color to crop. # --- For transparent images ----------------------------------------------- if 'A' in image.getbands(): # If the image has a transparency layer, use it. # This works for all modes which have transparency layer bbox = image.split()[list(image.getbands()).index('A')].getbbox() # --- For non-transparent images ------------------------------------------- elif image.mode=='RGB': if not backgroundColor: backgroundColor = mostPopularEdgeColor(image) # Crop a non-transparent image. # .getbbox() always crops the black color. # So we need to substract the "background" color from our image. bg = Image.new("RGB", image.size, backgroundColor) diff = ImageChops.difference(image, bg) # Substract background color from image bbox = diff.getbbox() # Try to find the real bounding box of the image. else: raise NotImplementedError, "Sorry, this function is not implemented yet for images in mode '%s'." % image.mode if bbox: image = image.crop(bbox) return image #范例:裁剪透明圖片: im = Image.open('myTransparentImage.png') cropped = autoCrop(im) cropped.show() #范例:裁剪非透明圖片 im = Image.open('myImage.png') cropped = autoCrop(im) cropped.show()
總結
以上就是本文關于python自動裁剪圖像代碼分享的全部內容,希望對大家有所幫助。如有不足之處,歡迎留言指出。感興趣的朋友可以繼續(xù)參閱本站:
相關文章
anaconda的安裝和配置環(huán)境及導入pycharm的方法
這篇文章主要介紹了anaconda的安裝和配置環(huán)境及導入pycharm的方法,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-03-03pycharm激活碼2020最新分享適用pycharm2020最新版親測可用
這篇文章主要介紹了pycharm激活碼2020最新分享適用pycharm2020最新版親測可用,同時也支持Intellij IDEA激活碼,PHPStorm激活碼大家可以放心使用需要的朋友可以參考下2020-11-11使用django的objects.filter()方法匹配多個關鍵字的方法
今天小編就為大家分享一篇使用django的objects.filter()方法匹配多個關鍵字的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-07-07