2015-06-02 68 views
1

目前我的應用程序中有一個縮放功能,效果很好,但是我希望實際縮放框是一個圓形。下面是目前變焦的樣子: enter image description here創建圓形圖像PIL Tkinter

放大後的矩形是當鼠標指針位置,和周圍的區域被放大,但我怎麼能做出這種放大對象的圓,而不是一個正方形?這裏是我的代碼:

def zoom(self, event): 
    if(event.delta > 0): 
     if self.zoomValue != 4 : self.zoomValue += 1 
    elif(event.delta < 0): 
     if self.zoomValue != 0 : self.zoomValue -= 1 
    self.crop(event) 

def crop(self, event): 
    if self.zimg_id: self.canvasLower.delete(self.zimg_id) 
    if (self.zoomValue) != 0: 
     x, y = event.x, event.y 
     if self.zoomValue == 1: 
      tmp = self.orig_img.crop((x-45, y-30, x+45, y+30)) 
     elif self.zoomValue == 2: 
      tmp = self.orig_img.crop((x-30, y-20, x+30, y+20)) 
     elif self.zoomValue == 3: 
      tmp = self.orig_img.crop((x-15, y-10, x+15, y+10)) 
     elif self.zoomValue == 4: 
      tmp = self.orig_img.crop((x-6, y-4, x+6, y+4)) 
     size = 200, 200 
     # crop tmp somehow to make the image a circle? maybe? 
     self.zimg = ImageTk.PhotoImage(tmp.resize(size)) 
     self.zimg_id = self.canvasLower.create_image(event.x, event.y, image=self.zimg) 
+2

請問您的圖像有一個alpha通道?通常圓形圖像只是角落透明的方形圖像。 – ballsatballsdotballs

回答

3

this answer適應(你需要ImageOpsImageDrawPIL進口),您可以使用您的放大圖像創建一個圓形掩蔽:

def create_mask(self): 
    self.mask = Image.new('L', (200,200), 0) 
    draw = ImageDraw.Draw(self.mask) 
    draw.ellipse((0, 0) + self.mask.size, fill=255) 

然後,你必須申請面膜在你crop功能:

output = ImageOps.fit(tmp, self.mask.size, centering=(0.5, 0.5)) 
output.putalpha(self.mask) 
self.zimg = ImageTk.PhotoImage(output) 

作爲參考,一個完整的工作的例子是這樣的:

import Tkinter as tk 
from PIL import Image, ImageTk, ImageOps, ImageDraw 

class App(): 
    def __init__(self, master, image_path): 
     self.orig_img = Image.open(image_path) 
     self.tk_img = ImageTk.PhotoImage(self.orig_img) 

     w, h = self.orig_img.size 
     self.canvas = tk.Canvas(master, width=w, height=h) 
     self.canvas.pack() 

     self.canvas.create_image(0, 0, image=self.tk_img, anchor='nw') 
     self.canvas.bind_all("<MouseWheel>", self.zoom) 
     self.canvas.bind_all("<Motion>", self.crop) 

     self.create_mask() 
     self.zoomValue = 0 
     self.zimg_id = None 

    def create_mask(self): 
     self.mask = Image.new('L', (200,200), 0) 
     draw = ImageDraw.Draw(self.mask) 
     draw.ellipse((0, 0) + self.mask.size, fill=255)   

    def zoom(self, event): 
     if(event.delta > 0): 
      if self.zoomValue != 4 : self.zoomValue += 1 
     elif(event.delta < 0): 
      if self.zoomValue != 0 : self.zoomValue -= 1 
     self.crop(event) 

    def crop(self, event): 
     if self.zimg_id: self.canvas.delete(self.zimg_id) 

     if (self.zoomValue) != 0: 
      x, y = event.x, event.y 
      if self.zoomValue == 1: 
       tmp = self.orig_img.crop((x-45, y-30, x+45, y+30)) 
      elif self.zoomValue == 2: 
       tmp = self.orig_img.crop((x-30, y-20, x+30, y+20)) 
      elif self.zoomValue == 3: 
       tmp = self.orig_img.crop((x-15, y-10, x+15, y+10)) 
      elif self.zoomValue == 4: 
       tmp = self.orig_img.crop((x-6, y-4, x+6, y+4)) 

      output = ImageOps.fit(tmp, self.mask.size, centering=(0.5, 0.5)) 
      output.putalpha(self.mask) 
      self.zimg = ImageTk.PhotoImage(output) 
      self.zimg_id = self.canvas.create_image(event.x, event.y, image=self.zimg) 

root = tk.Tk() 
App(root, r'C:\Users\user\Desktop\bg.gif') 
root.mainloop()