3

私はPythonの初心者で、画像を循環し、別のファイルから変数を取得して画像を「解決」する、やや奇妙なスライドショースクリプトを作成しています。

私のコードは悲劇的だと確信しています。しかし、それは機能します(以下を参照)!

私の質問は、ぎくしゃくした画像が一時的に白になり、現在の次の画像に移動するのではなく、画像間でフェードさせるにはどうすればよいですか?確認する必要のあるトランジションモジュールはありますか?

from Tkinter import *
import Image, ImageTk, random, string

class MyApp(Tk):

def __init__(self):
    Tk.__init__(self)
    fr = Frame(self)
    fr.pack()
    self.canvas  = Canvas(fr, height = 400, width = 600)
    self.canvas.pack()

    self.old_label_image = None
    self.position = 0
    self.command = 0
    self.oldcommand = 0

    self.slideshow()
    self.debug()

def debug(self):
    self.QUIT = Button(self)
    self.QUIT["text"] = "QUIT!" + str(self.command)
    self.QUIT["fg"]   = "red"
    self.QUIT["command"] =  self.quit

    self.QUIT.pack({"side": "right"})

def slideshow (self):

    if self.command != self.oldcommand:
        self.after_cancel(self.huh)
        # run through random between 2-5 changes 
        # then settle on command for 30 seconds
        self.title("Title: PAUSE")
        self.oldcommand = self.command
        self.slideshow()
    else:
        file = str(self.position) + '.jpg'
        image1 = Image.open(file)
        self.tkpi = ImageTk.PhotoImage(image1)
        label_image = Label(self, image=self.tkpi)
        label_image.place(x=0,y=0,width=image1.size[0],height=image1.size[1])
        self.title("Title: " + file)

        if self.old_label_image is not None:
            self.old_label_image.destroy()
        self.old_label_image = label_image

        # make this random instead of pregressional
        if self.position is not 1:
            self.position = self.position + 1
        else:
            self.position = 0

        commandfile = open('command.txt', 'r')
        self.command = string.atoi(commandfile.readline())
        commandfile.close()

        int = random.randint(2000, 5000)
        self.huh = self.after(int, self.slideshow)
        #self.after_cancel(huh) - works ! so maybe can do from below Fn?

if __name__ == "__main__":
root = MyApp()
root.mainloop()
4

1 に答える 1

2

これは、ブレンド機能を使用して実現できます。

 Image.blend(image1, image2, alpha) ⇒ image

一定のアルファを使用して、指定されたイメージ間を補間することにより、新しいイメージを作成します。両方のイメージのサイズとモードは同じでなければなりません。

out = image1 * (1.0 - alpha) + image2 * alpha

アルファが 0.0 の場合、最初のイメージのコピーが返されます。アルファが 1.0 の場合、2 番目のイメージのコピーが返されます。アルファ値に制限はありません。必要に応じて、許容される出力範囲に収まるように結果が切り取られます。

したがって、次のようなものがあります。

alpha = 0
while 1.0 > alpha:
    image.blend(img1,img2,alpha)
    alpha = alpha + 0.01
    label_image.update()

例はここにあります。これをテストする時間がありませんでしたが、アイデアはわかります-

from PIL import image
import time
white = image.open("white_248x.jpg")
black = image.open("black_248x.jpg")
new_img = image.open("white_248x.jpg")
root = Tk()
image_label = label(root, image=new_img)
image_label.pack()
alpha = 0
while 1.0 > alpha:
    new_img = image.blend(white,black,alpha)
    alpha = alpha + 0.01
    time.sleep(0.1)
    image_label.update()
root.mainloop()
于 2014-06-15T21:48:08.530 に答える