-1

现在我最初为 Windows 制作了WidgetArea,但主要是 Linux 用户。我也想为 Linux 制作它,但主要是为了更多地了解 PyGTK 中的文件对话框。因此,我查看了教程以更好地理解它,同时处理这个简单而小型的应用程序,因为这对我来说更容易学习和通过实验来理解。

所以这是我的源代码。

#!/usr/bin/env python

import sys, os
import pygtk, gtk, gobject
import pygst
pygst.require("0.10")
import gst

class WidgetArea(gtk.Window):

   def addwidget(self, w):
    self.win = gtk.Window(gtk.WINDOW_TOPLEVEL)
    self.win.set_title("Widget")
    self.win.set_decorated(False)
    self.win.set_has_frame(False)
    self.win.set_resizable(False)
    self.win.set_keep_above(True)
    self.win.set_property('skip-taskbar-hint', True)
    self.previewimage = gtk.Image()
    self.win.add(self.previewimage)
    self.win.show_all()

   def pinning(self, checkbox):
    if checkbox.get_active():
     self.set_keep_above(True)
    else:
     self.set_keep_above(False)

   def change_size(self, w):
     width = int(self.entryw.get_text())
     height = int(self.entryh.get_text())
     self.win.set_size_request(width,height)

   def __init__(self):
    super(WidgetArea, self).__init__()
    self.set_position(gtk.WIN_POS_CENTER)
    self.set_title("WidgetArea")
    self.set_resizable(False)
    self.set_keep_above(True)
    self.set_property('skip-taskbar-hint', True)
    self.connect("destroy", gtk.main_quit, "WM destroy")
    vbox = gtk.VBox(spacing=0)
    hbox = gtk.HBox(spacing=0)
    hbox2 = gtk.HBox(spacing=0)
    hbox3 = gtk.HBox(spacing=0)
    hbox4 = gtk.HBox(spacing=0)

    self.widgetsize = gtk.Label("Widget Size:")
    self.widgetsize.set_size_request(100, 30)

    self.entryw = gtk.Entry()
    self.entryh = gtk.Entry()
    self.entryw.set_text("270")
    self.entryw.set_size_request(75, 30)
    labelcoma = gtk.Label(",")
    labelcoma.set_size_request(10, 30)
    self.entryh.set_text("221")
    self.entryh.set_size_request(75, 30)
    labelspac1 = gtk.Label(" ")
    labelspac1.set_size_request(10, 30)
    hbox.pack_start(self.widgetsize)
    hbox.pack_start(self.entryw)
    hbox.pack_start(labelcoma)
    hbox.pack_start(self.entryh)
    hbox.pack_start(labelspac1, 0, 0, 10)

    check = gtk.CheckButton("Pin This Window")
    check.set_active(True)
    check.connect("clicked", self.pinning)
    hbox.pack_start(check, 0, 0, 10)

    labelspac2 = gtk.Label(" ")
    labelspac2.set_size_request(250, 15)
    hbox2.pack_start(labelspac2)

    filefilter = gtk.FileFilter()
    filefilter.set_name("Images")
    filefilter.add_mime_type("image/png")
    filefilter.add_mime_type("image/jpeg")
    filefilter.add_mime_type("image/gif")
    filefilter.add_mime_type("image/tiff")
    filefilter.add_mime_type("image/svg+xml")
    filefilter.add_pattern("*.jpg")

    self.ref_file_button = gtk.FileChooserButton('Add Widget')
    self.ref_file_button.set_current_folder("/".join([self.rootdir,"pics"]))
    self.ref_file_button.set_filter(filefilter)
    self.ref_file_button.connect("file-set", self.on_open_clicked)
    hbox3.pack_start(self.ref_file_button, 150, 150, 10)

    labelspac5 = gtk.Label(" ")
    labelspac5.set_size_request(0, 10)
    hbox4.pack_start(labelspac5)

    vbox.pack_start(hbox)
    vbox.pack_start(hbox2)
    vbox.pack_start(hbox3)
    vbox.pack_start(hbox4)
    self.add(vbox)
    self.show_all()

   def on_open_clicked(self, widget, data=None):
    ref_image_path = widget.get_filename()
    self.previewimage.set_from_file(ref_image_path)
    self.addwidg.connect("clicked", self.addwidget)
    self.addwidg.connect("clicked", self.change_size)
    ref_image_path.destroy()

WidgetArea()
gtk.gdk.threads_init()
gtk.main()

由于以下错误(第 2 次),我删除了以下代码(第 1 次)。

self.ref_file_button.set_current_folder("/".join([self.rootdir,"pics"]))

Traceback (most recent call last):
  File "./widgetarea.py", line 109, in <module>
    WidgetArea()
  File "./widgetarea.py", line 86, in __init__
    self.ref_file_button.set_current_folder("/".join([self.rootdir,"pics"]))
AttributeError: 'WidgetArea' object has no attribute 'rootdir'

现在这不是什么大问题。我的主要目标是让图像显示在新窗口中。所以在我删除了上面的代码之后,由于那个错误我得到了另一个。

Traceback (most recent call last):
  File "./widgetarea.py", line 103, in on_open_clicked
    self.previewimage.set_from_file(ref_image_path)
AttributeError: 'WidgetArea' object has no attribute 'previewimage'

我遇到的所有问题是当您浏览以选择我想要选择的图像的图像时,当按下 OK 启动作为在该窗口中显示所选图像的新窗口时,如上所述。

4

2 回答 2

2

要更正第一个错误,请使用gtk.FILE_CHOOSER_ACTION_OPEN而不是gtk.FileChooserAction.OPEN.

第二个问题是因为您的代码中没有image在该点命名的变量(第 116 行)。也许您来自 C++ 或 Java 背景,image可以通过查看封闭类的属性来解析类似的名称,即this.image

在 Python 中你不能这样做。您必须self.image在您的addwidget()方法中明确分配给。否则,该名称将image保留在该方法的本地,并且在该addwidget()方法之外不可用。

这引发了一个不同的问题,每次单击并addwidget()调用按钮时会发生什么?self.win并被self.image覆盖。这可能是你想要的,但我只是提醒你注意——这对我来说似乎有点奇怪。

于 2012-05-24T09:54:21.663 回答
1

我在我的一个项目中使用了类似的东西。它在 Linux 中对我来说运行良好。

def __init__(self):
    # Define all the widgets   
    image_filter = gtk.FileFilter()
    image_filter.set_name("Images")
    image_filter.add_mime_type("image/png")
    image_filter.add_mime_type("image/jpeg")
    image_filter.add_mime_type("image/gif")
    image_filter.add_mime_type("image/tiff")
    image_filter.add_mime_type("image/svg+xml")
    image_filter.add_pattern("*.jpg")

    self.ref_file_button = gtk.FileChooserButton('Select Image')
    self.ref_file_button.set_size_request(100,30)
    self.ref_file_button.set_current_folder("/".join([self.rootdir,"pics"])) # set directory path
    self.ref_file_button.set_filter(image_filter)
    self.ref_file_button.set_tooltip_text('Select Image')
    self.ref_file_button.connect("file-set", self.ref_image_selected)

def ref_image_selected(self,widget,data=None):
    ref_image_path = widget.get_filename()
    print ref_image_path

获取图片的路径后,可以使用 gtk.Image 加载

编辑:

你的代码有点错误。您永远不会调用函数 addwidget(),因此未定义 self.previewimage。所以它给出了AttributeError。

def __init__(self):
    # your code
    self.add(vbox)
    self.addwidget(200)   # I don't know what 'w' is. so I took a random number.
    self.show_all()

def  on_open_clicked(self, widget, data=None):
    ref_image_path = widget.get_filename()
    self.previewimage.set_from_file(ref_image_path)
    self.addwidg.connect("clicked", self.addwidget)
    self.addwidg.connect("clicked", self.change_size)
    ref_image_path.destroy()

什么是self.addwidg

我现在可以查看图像了。

于 2012-05-24T21:11:48.920 回答