Συζήτηση
Γεια χαρά, Επισκέπτης
Όνομα χρήστη: Κωδικός: Να με θυμάσαι

ΘΕΜΑ: Search screenlet

Search screenlet 15 Χρόνια 1 Ημέρα πριν #633

  • malos
  • Το Άβαταρ του/της malos
  • Αποσυνδεμένος
  • py____
  • Δημοσιεύσεις: 23
Καλησπέρα παιδιά.
Πάνω στη γενικότερη αναζήτησή μου προς εκμάθηση :woohoo: κατάφερα (με χαρά) αυτό:

forum.ubuntu-gr.org/viewtopic.php?f=9&t=4416&start=30#p83234

Απλά διάβαζα και ξαναδιάβαζα τον κώδικα μέχρι να τον καταλάβω κάτα 10% τουλάχιστον. Τελικά πρόσθεσα 5-6 γραμμές, μιμούμενος απλά τα ήδη υπάρχοντα κουμπιά.
Έλα που ο κώδικας του Radio screenlet ... μου έφερνε σε πιο φιλικός !!!!!


Με το Search screenlet όμως τα βρήκα πιο σκούρα! Εδώ έχουμε pygtk ! Και ενώ άλλοι δεν χωνεύουν το qt εγώ πάλι σαν να με φοβίζει το gtk :laugh:

Παρόλο που στο παρακάτω παράδειγμα μου φάνηκε πολύ πιο εύκολο ακόμα και από το tkinter !!!
#!/usr/bin/python
import gtk
window = gtk.Window()
entry = gtk.Entry()
entry.props.editable = True
entry.props.has_focus = False
window.add(entry)
window.show_all()
gtk.main()

Ειλικρινά είναι πολύ απλό !

Και ενώ έψαξα ότι μπορούσα για pygtk και για τα screenlets
δεν έβγαλα άκρη.

Το screenlet που θέλω να πειράξω είναι το πάνω της φωτογραφίας (αυτό το καφέ με ροζ μέσα) :


Αυτό που βλέπετε λοιπόν έχει πολλές μηχανές αναζήτησης μέσα ( και φυσικά του βάζουμε κι άλλες από τον κώδικα). Με δεξί κλικ πάνω του επιλέγεις μηχανή. Αν κάνεις κλικ μέσα στο ροζ (άσπρο ήταν, άλλαξα το image) και πληκτρολογήσεις κάτι, θα ανοίξει ο firefox
στο google με τα αποτελέσματα του λείματος.

Ωραία και καλά όλα αυτά, αλλά ... με το κλικ...δεν σκάει μύτη κανένας κερσοράκος !
Κι όσο νάναι αυτό είναι δύσχρηστο ! Δεν σε βοηθάει να γράψεις κάτι μέσα ! Τα γράμματα φαίνονται βεβαίως (και μάλιστα τα είχαν στα δεξιά! Πολύ άσχημο ! Τα έβαλα να αρχίζουν από αριστερά όπως στη μπάρα του google που ξέρουμε)

Πως θα βάλω όμως cursor ;
Προσπάθησα με αυτά εδώ

www.pygtk.org/docs/pygtk/class-gdkcursor.html

faq.pygtk.org/index.py?req=show&file=faq05.006.htp

αλλά δεν έχω καταλάβει πιο είναι το main widget ώστε να του κάνω add τον κέρσορα!

Στο παραπάνω παραδειγματάκι είναι κατανοητό.
Εδώ όμως έχουμε μία svg εικόνα (το ροζ).

ο Κώδικας όλος είναι
#!/usr/bin/env python
 
# This application is released under the GNU General Public License 
# v3 (or, at your option, any later version). You can find the full 
# text of the license under http://www.gnu.org/licenses/gpl.txt. 
# By using, editing and/or distributing this software you agree to 
# the terms and conditions of this license. 
# Thank you for using free software!
 
# SearchScreenlet (c) Whise <helder.fraga@hotmail.com>
#
# INFO:
# - A screenlet that searches the most popular search engines sites
 
 
import screenlets
from screenlets.options import StringOption, ColorOption
import cairo
import pango
import gtk
from os import system
from urllib import quote
from screenlets import DefaultMenuItem
 
class SearchScreenlet(screenlets.Screenlet):
	"""A screenlet performing various numerical conversions."""
 
	# default meta-info for Screenlets
	__name__ = 'SearchScreenlet'
	__version__ = '0.1'
	__author__ = 'Helder Fraga aka whise'
	__desc__ = 'A screenlet that searches the most popular search engines'
 
	# a list of the converter class objects
	__engines = [
		{"name": "Delicious",	"icon": "delicious.png",	"url": "http://del.icio.us/search/?p=%s&type=all"},
		{"name": "Digg",	"icon": "digg.png",		"url": "http://www.digg.com/search?section=news&s=%s"},
		{"name": "Google",	"icon": "google.png",		"url": "http://www.google.com/search?q=%s&ie=utf-8&oe=utf-8&aq=t&client=SearchScreenlet"},
		{"name": "IMDb",	"icon": "imdb.png",		"url": "http://imdb.com/find?q=%s"},
		{"name": "Wikipedia",	"icon": "wikipedia.png",	"url": "http://wikipedia.org/wiki/%s"},
		{"name": "Yahoo!",	"icon": "yahoo.png",		"url": "http://search.yahoo.com/search?p=%s"},
		{"name": "-",	"icon": "",		"": ""},
		{"name": "Dictionary",	"icon": "dictionary.png",		"url": "http://dictionary.reference.com/browse/%s"},
		{"name": "Thesaurus",	"icon": "thesaurus.png",		"url": "http://thesaurus.reference.com/browse/%s"},
		{"name": "Reference",	"icon": "reference.png",		"url": "http://www.reference.com/search?q=%s"},
		{"name": "-",	"icon": "",		"": ""},
		{"name": "ThePirateBay",	"icon": "icon_piratebay.png",	"url": "http://thepiratebay.org/search/%s"},
		{"name": "Demonoid",	"icon": "delicious.png",	"url": "http://www.demonoid.com/files/?category=0&subcategory=All&quality=All&seeded=0&external=2&query=%s"},
		{"name": "TorrentSpy",	"icon": "icon_torrentspry.png",		"url": "http://www.torrentspy.com/search?query=%s"},
		{"name": "Isohunt",	"icon": "icon_isohunt.png",		"url": "http://isohunt.com/torrents/?ihq=%s"},
		{"name": "Mininova",	"icon": "icon_minienova.png",		"url": "http://www.mininova.org/search/?search=%s"},
	]
	__engine = __engines[2]
	__has_focus = True
	__query = ''
	frame_color = (0, 0, 0, 0.7)
	# editable options
	# the name, i.e., __title__ of the active converter
	engine = 'Google'
	p_layout = None
	# constructor
	def __init__(self, **keyword_args):
		#call super
		screenlets.Screenlet.__init__(self, width=201, height=40, 
				**keyword_args)
		# set theme
		self.theme_name = "default"
 
		# add options
		self.add_options_group('Engine', 'Web search engine settings')
		self.add_option(StringOption('Engine', 'engine', self.engine,
			'TorrentSearch engine', 'TorrentSearch engine',
			choices = [dictitem["name"] for dictitem in self.__engines]))
		self.add_option(ColorOption('Engine','frame_color', 
			self.frame_color, 'Frame color', 
			'Frame color'))
		# connect additional event handlers
		# self.window.connect('key-press-event', self.key_press)
		# initialize default converter
		# self.set_converter('BaseConverter')
 
	def __setattr__(self, name, value):
		# call Screenlet.__setattr__ in baseclass (ESSENTIAL!!!!)
		screenlets.Screenlet.__setattr__(self, name, value)
		if name == 'engine':
			# This condition allows us to cache the option while avoiding 
			# recursion when the converter is selected from menu
			if value != self.__engine['name']:
				self.set_engine(value)
 
	def set_engine(self, name):
		"""Set the active converter and related variables, either python or 
		human-readable name can be specified"""
		for engine in self.__engines:
			if engine["name"] == name:
				break
		self.__engine = engine
		# make the option be cached and show in the Options dialog
		self.engine = engine['name']
		self.redraw_canvas()
 
	# I don't want to call this on_key_press, I consider such a name reserved 
	# for future versions of screenlets.
	def on_key_down(self, keycode, keyvalue, event):
		"""Called when a keypress-event occured in Screenlet's window."""
		key = gtk.gdk.keyval_name(event.keyval)
		if key == "Return" or key == "Tab":
			# submit query
			system("gnome-open '" + self.__engine['url'].replace('%s', quote(self.__query)) + "'")
			self.__query = ''
			self.redraw_canvas()
		elif key == "BackSpace":
			self.__query = self.__query[:-1]
			self.redraw_canvas()
		elif key == "space":
			self.__query += " "
			self.redraw_canvas()
		else:
			self.__query += keyvalue
			self.redraw_canvas()
 
	def on_init(self):
		for dictitem in self.__engines:
			self.add_menuitem('engine = ' + str(dictitem["name"]), str(dictitem["name"]))	
		self.add_default_menuitems()
 
	def on_mouse_down(self, event):
		# filter events
		if event.button != 1 or event.type != gtk.gdk.BUTTON_PRESS:
			return False
		# recalculate cursor position
		x = event.x / self.scale
		y = event.y / self.scale
		# compute space between fields
		n = 1
		m = 10
		# find if a click occured over some field...
		#self.kursor = gtk.gtk_cursor_blink		
		if x >= 50 and x <= 190:
			if y >= m and y <= 100:
				d = y - m
				if d % (20 + m) <= 20:
					self.redraw_canvas()
					watch = gtk.gdk.Cursor(gtk.gdk.WATCH)					
					self.redraw_canvas.set_cursor(watch)
 
					return True
		return False
 
	def on_focus(self, event):
		self.__has_focus = True
 
 
		#if self.__converter:
		#	self.__converter.replace = True
		self.redraw_canvas()
 
	def on_unfocus(self, event):
		self.__has_focus = False
		self.redraw_canvas()
 
	def on_draw(self, ctx):
		# if a converter or theme is not yet loaded, there's no way to continue
		# set scale relative to scale-attribute
		ctx.scale(self.scale, self.scale)
		# render background
		if self.theme:
			ctx.set_source_rgba(*self.frame_color)
			if self.theme_name == 'default':self.draw_rounded_rectangle(ctx,0,0,8,200,40)
			self.theme.render(ctx,'background2')
		# compute space between fields
		n = 1
		m = 10
		# draw fields
		ctx.save()
		ctx.translate(8, 6)
		ctx.scale(1.5,1.5)
		ctx.set_source_surface(self.theme[self.__engine['icon']], 0, 0)
		ctx.paint()
		ctx.restore()
		ctx.save()
		ctx.translate(50, m)
		for i in range(n):
			if self.__has_focus:
				self.theme.render(ctx,'fieldh')
				# cursor: disabled - it looks weird
				ctx.rectangle(185, 3, 2, 16)
				ctx.fill()
			else:
				self.theme.render(ctx,'field')
			ctx.translate(0, m + 20)
		ctx.restore()
		# render field names
		# ctx.save()
		ctx.set_source_rgba(0,0,0,1)
		if self.p_layout == None :
 
			self.p_layout = ctx.create_layout()
		else:
 
			ctx.update_layout(self.p_layout)
		p_fdesc = pango.FontDescription()
		p_fdesc.set_family_static("Free Sans")
		p_fdesc.set_size(11 * pango.SCALE)
		self.p_layout.set_font_description(p_fdesc)
		self.p_layout.set_width(40 * pango.SCALE)
		ctx.save()
		ctx.translate(55, m + 3)
		self.p_layout.set_alignment(pango.ALIGN_LEFT)
		self.p_layout.set_width(130 * pango.SCALE)
		self.p_layout.set_ellipsize(pango.ELLIPSIZE_START)
		for i in range(n):
			if self.has_focus:
				self.p_layout.set_markup(self.__query + '_')
			else:
				self.p_layout.set_markup(self.__query)
			ctx.show_layout(self.p_layout)
			ctx.translate(0, m + 20)
		ctx.restore()
		# ...and finally something to cover this all
 
 
	def on_draw_shape(self, ctx):
		if self.theme:
			ctx.scale(self.scale, self.scale)
			# the background will serve well
			self.theme.render(ctx,'background')
 
	def on_menuitem_select (self, id):
		"""handle MenuItem-events in right-click menu"""
		if id == "hide_show":
			# TODO: use DBus-call for this
			#self.switch_hide_show()
			pass
		elif id[:4] == "add:":
			# make first letter uppercase (workaround for xml-menu)
			name = id[4].upper()+id[5:][:-9]
			 #and launch screenlet (or show error)
			if not screenlets.launch_screenlet(name):
				screenlets.show_error(self, 'Failed to add %sScreenlet.' % name)
		elif id[:6] == "engine":
			# execute shell command
			engine = id[9:][:+20]
			self.set_engine(id[9:][:+20])
			self.redraw_canvas()
			print  (engine)
 
# If the program is run directly or passed as an argument to the python
# interpreter then create a Screenlet instance and show it
if __name__ == "__main__":
	import screenlets.session
	screenlets.session.create_session(SearchScreenlet)

Στις γραμμές 137 - 145 είναι ότι τελευταίο προσπάθησα
#self.kursor = gtk.gtk_cursor_blink		
		if x >= 50 and x <= 190:
			if y >= m and y <= 100:
				d = y - m
				if d % (20 + m) <= 20:
					self.redraw_canvas()
					watch = gtk.gdk.Cursor(gtk.gdk.WATCH)					
					self.redraw_canvas.set_cursor(watch)
 
					return True
		return False

Δυστυχώς δεν έχω την αρχική του μορφή ... τα έκανα λίγο μπάχαλο ! Αλλά περίπου αυτή είναι! Δεν πείραξα κάτι άλλο !
Πρέπει να είστε εγγεγραμμένο μέλος του Φόρουμ για να κάνετε μια δημοσίευση.

Απ:Search screenlet 15 Χρόνια 1 Ημέρα πριν #634

  • myle
  • Το Άβαταρ του/της myle
  • Αποσυνδεμένος
  • Admin
  • Δημοσιεύσεις: 467
  • Ληφθείσες Ευχαριστίες 15
Κατά αρχάς συγχαρητήρια για την προσπάθεια!
Ακόμα δεν το έχω τρέξει/διαβάσει τον κώδικα, αλλά είναι πολύ σημαντικό το ότι προσπάθησες!

Αύριο μάλλον θα έχεις και σχόλια επ' αυτού!
«Αν υποθέσουμε ότι αυτό είναι δυνατό, (να μεταδώσουμε τη σοφία παντού) τότε ειλικρινά ο τρόπος ζωής των θεών θα περάσει στους ανθρώπους. Τα πάντα θα είναι γεμάτα...
Τελευταία διόρθωση: 15 Χρόνια 1 Ημέρα πριν από myle.
Πρέπει να είστε εγγεγραμμένο μέλος του Φόρουμ για να κάνετε μια δημοσίευση.
Συντονιστές: pmav99
Χρόνος δημιουργίας σελίδας: 0.526 δευτερόλεπτα

Μοιράσου το!

Powered by CoalaWeb

Λίστα Ταχυδρομείου