Implement the grid, regress UI a bit
This commit is contained in:
		
							parent
							
								
									61058e0110
								
							
						
					
					
						commit
						21b19924ea
					
				@ -6,25 +6,25 @@ import conf
 | 
				
			|||||||
from sugar.canvas.IconItem import IconItem
 | 
					from sugar.canvas.IconItem import IconItem
 | 
				
			||||||
from sugar.canvas.IconColor import IconColor
 | 
					from sugar.canvas.IconColor import IconColor
 | 
				
			||||||
from sugar.presence import PresenceService
 | 
					from sugar.presence import PresenceService
 | 
				
			||||||
from frame.Panel import Panel
 | 
					from sugar.canvas.GridLayout import GridGroup
 | 
				
			||||||
 | 
					from sugar.canvas.GridLayout import GridConstraints
 | 
				
			||||||
 | 
					
 | 
				
			||||||
class ActivityItem(IconItem):
 | 
					class ActivityItem(IconItem):
 | 
				
			||||||
	def __init__(self, activity, size):
 | 
						def __init__(self, activity):
 | 
				
			||||||
		icon_name = activity.get_icon()
 | 
							icon_name = activity.get_icon()
 | 
				
			||||||
		if not icon_name:
 | 
							if not icon_name:
 | 
				
			||||||
			act_type = activity.get_type()
 | 
								act_type = activity.get_type()
 | 
				
			||||||
			raise RuntimeError("Activity %s did not have an icon!" % act_type)
 | 
								raise RuntimeError("Activity %s did not have an icon!" % act_type)
 | 
				
			||||||
		IconItem.__init__(self, icon_name=icon_name,
 | 
							IconItem.__init__(self, icon_name=icon_name, color=IconColor('white'))
 | 
				
			||||||
						  color=IconColor('white'), size=size)
 | 
					 | 
				
			||||||
		self._activity = activity
 | 
							self._activity = activity
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	def get_bundle_id(self):
 | 
						def get_bundle_id(self):
 | 
				
			||||||
		return self._activity.get_id()
 | 
							return self._activity.get_id()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
class InviteItem(IconItem):
 | 
					class InviteItem(IconItem):
 | 
				
			||||||
	def __init__(self, invite, size):
 | 
						def __init__(self, invite):
 | 
				
			||||||
		IconItem.__init__(self, icon_name=invite.get_icon(),
 | 
							IconItem.__init__(self, icon_name=invite.get_icon(),
 | 
				
			||||||
						  color=invite.get_color(), size=size)
 | 
											  color=invite.get_color())
 | 
				
			||||||
		self._invite = invite
 | 
							self._invite = invite
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	def get_activity_id(self):
 | 
						def get_activity_id(self):
 | 
				
			||||||
@ -33,12 +33,11 @@ class InviteItem(IconItem):
 | 
				
			|||||||
	def get_bundle_id(self):
 | 
						def get_bundle_id(self):
 | 
				
			||||||
		return self._invite.get_bundle_id()
 | 
							return self._invite.get_bundle_id()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
class ActivityBar(goocanvas.Group):
 | 
					class BottomPanel(GridGroup):
 | 
				
			||||||
	def __init__(self, shell, invites, height):
 | 
						def __init__(self, shell, invites):
 | 
				
			||||||
		goocanvas.Group.__init__(self)
 | 
							GridGroup.__init__(self, 16, 1)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		self._shell = shell
 | 
							self._shell = shell
 | 
				
			||||||
		self._height = height
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
		registry = conf.get_activity_registry()
 | 
							registry = conf.get_activity_registry()
 | 
				
			||||||
		for activity in registry.list_activities():
 | 
							for activity in registry.list_activities():
 | 
				
			||||||
@ -66,37 +65,14 @@ class ActivityBar(goocanvas.Group):
 | 
				
			|||||||
			logging.info("Activity %s did not have an icon.  Won't show it." % name)
 | 
								logging.info("Activity %s did not have an icon.  Won't show it." % name)
 | 
				
			||||||
			return
 | 
								return
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		item = ActivityItem(activity, self._height)
 | 
							item = ActivityItem(activity)
 | 
				
			||||||
		item.connect('clicked', self.__activity_clicked_cb)
 | 
							item.connect('clicked', self.__activity_clicked_cb)
 | 
				
			||||||
 | 
							constraints = GridConstraints(self.get_n_children() + 1, 0, 1, 1)
 | 
				
			||||||
		icon_size = self._height
 | 
							constraints.padding = 6
 | 
				
			||||||
		x = (icon_size + 6) * self.get_n_children()
 | 
							self._layout.set_constraints(item, constraints)
 | 
				
			||||||
		item.set_property('x', x)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		self.add_child(item)
 | 
							self.add_child(item)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	def add_invite(self, invite):
 | 
						def add_invite(self, invite):
 | 
				
			||||||
		item = InviteItem(invite, self._height)
 | 
							item = InviteItem(invite)
 | 
				
			||||||
		item.connect('clicked', self.__invite_clicked_cb)
 | 
							item.connect('clicked', self.__invite_clicked_cb)
 | 
				
			||||||
 | 
					 | 
				
			||||||
		icon_size = self._height
 | 
					 | 
				
			||||||
		x = (icon_size + 6) * self.get_n_children()
 | 
					 | 
				
			||||||
		item.set_property('x', x)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		self.add_child(item)
 | 
							self.add_child(item)
 | 
				
			||||||
 | 
					 | 
				
			||||||
class BottomPanel(Panel):
 | 
					 | 
				
			||||||
	def __init__(self, shell, invites):
 | 
					 | 
				
			||||||
		Panel.__init__(self)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		self._shell = shell
 | 
					 | 
				
			||||||
		self._invites = invites
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	def construct(self):
 | 
					 | 
				
			||||||
		Panel.construct(self)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		root = self.get_root()
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		activity_bar = ActivityBar(self._shell, self._invites,
 | 
					 | 
				
			||||||
								   self.get_height())
 | 
					 | 
				
			||||||
		root.add_child(activity_bar)
 | 
					 | 
				
			||||||
 | 
				
			|||||||
@ -1,38 +1,66 @@
 | 
				
			|||||||
import gtk
 | 
					import gtk
 | 
				
			||||||
import gobject
 | 
					import gobject
 | 
				
			||||||
 | 
					import goocanvas
 | 
				
			||||||
 | 
					
 | 
				
			||||||
from frame.BottomPanel import BottomPanel
 | 
					from frame.BottomPanel import BottomPanel
 | 
				
			||||||
from frame.RightPanel import RightPanel
 | 
					from frame.RightPanel import RightPanel
 | 
				
			||||||
from frame.TopPanel import TopPanel
 | 
					from frame.TopPanel import TopPanel
 | 
				
			||||||
from frame.Panel import Panel
 | 
					from frame.PanelWindow import PanelWindow
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					from sugar.canvas.ScreenContainer import ScreenContainer
 | 
				
			||||||
 | 
					from sugar.canvas.GridLayout import GridLayout
 | 
				
			||||||
 | 
					from sugar.canvas.GridLayout import GridConstraints
 | 
				
			||||||
 | 
					from sugar.canvas.GridLayout import GridGroup
 | 
				
			||||||
 | 
					
 | 
				
			||||||
class Frame:
 | 
					class Frame:
 | 
				
			||||||
	def __init__(self, shell, owner):
 | 
						def __init__(self, shell, owner):
 | 
				
			||||||
		size = 30
 | 
							self._windows = []
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		self._panels = []
 | 
							self._model = goocanvas.CanvasModelSimple()
 | 
				
			||||||
 | 
							item = goocanvas.Rect(x=0, y=0, width=800, height=600,
 | 
				
			||||||
 | 
												  line_width=0, fill_color="#4f4f4f")
 | 
				
			||||||
 | 
							self._model.get_root_item().add_child(item)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							self._screen_layout = GridLayout()
 | 
				
			||||||
 | 
							self._screen_container = ScreenContainer(self._windows)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							group = GridGroup()
 | 
				
			||||||
 | 
							group.props.width = 800
 | 
				
			||||||
 | 
							group.props.height = 600
 | 
				
			||||||
 | 
							layout = group.get_layout()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							constraints = GridConstraints(0, 11, 16, 1)
 | 
				
			||||||
 | 
							self._create_window(constraints)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		panel = BottomPanel(shell, owner.get_invites())
 | 
							panel = BottomPanel(shell, owner.get_invites())
 | 
				
			||||||
		panel.set_position(size, 0)
 | 
							layout.set_constraints(panel, constraints)
 | 
				
			||||||
		panel.move(0, gtk.gdk.screen_height() - size)
 | 
							group.add_child(panel)
 | 
				
			||||||
		panel.resize(gtk.gdk.screen_width(), size)
 | 
					 | 
				
			||||||
		self._panels.append(panel)
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
		panel = RightPanel(shell, owner.get_friends())
 | 
							# Top
 | 
				
			||||||
		panel.move(gtk.gdk.screen_width() - size, size)
 | 
							constraints = GridConstraints(0, 0, 16, 1)
 | 
				
			||||||
		panel.resize(size, gtk.gdk.screen_height() - size * 2)
 | 
							self._create_window(constraints)
 | 
				
			||||||
		self._panels.append(panel)
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
		panel = TopPanel(shell)
 | 
							# Left
 | 
				
			||||||
		panel.set_position(size, 0)
 | 
							constraints = GridConstraints(0, 1, 1, 10)
 | 
				
			||||||
		panel.move(0, 0)
 | 
							self._create_window(constraints)
 | 
				
			||||||
		panel.resize(gtk.gdk.screen_width(), size)
 | 
					 | 
				
			||||||
		self._panels.append(panel)
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
		panel = Panel()
 | 
							# Right
 | 
				
			||||||
		panel.move(0, size)
 | 
							constraints = GridConstraints(15, 1, 1, 10)
 | 
				
			||||||
		panel.resize(size, gtk.gdk.screen_height() - size * 2)
 | 
							self._create_window(constraints)
 | 
				
			||||||
		self._panels.append(panel)
 | 
					
 | 
				
			||||||
 | 
							self._model.get_root_item().add_child(group)
 | 
				
			||||||
 | 
							self._screen_container.set_layout(self._screen_layout)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						def _create_window(self, constraints):
 | 
				
			||||||
 | 
							layout = self._screen_layout
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							window = PanelWindow(self._model)
 | 
				
			||||||
 | 
							layout.set_constraints(window, constraints)
 | 
				
			||||||
 | 
							self._windows.append(window)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							bounds = layout.get_bounds(self._screen_container, constraints)
 | 
				
			||||||
 | 
							window.get_view().set_bounds(bounds[0], bounds[1],
 | 
				
			||||||
 | 
														 bounds[2], bounds[3])
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	def __hide_timeout_cb(self):
 | 
						def __hide_timeout_cb(self):
 | 
				
			||||||
		self.hide()
 | 
							self.hide()
 | 
				
			||||||
@ -43,15 +71,15 @@ class Frame:
 | 
				
			|||||||
		gobject.timeout_add(seconds * 1000, self.__hide_timeout_cb)
 | 
							gobject.timeout_add(seconds * 1000, self.__hide_timeout_cb)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	def show(self):
 | 
						def show(self):
 | 
				
			||||||
		for panel in self._panels:
 | 
							for panel in self._windows:
 | 
				
			||||||
			panel.show()
 | 
								panel.show()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	def hide(self):
 | 
						def hide(self):
 | 
				
			||||||
		for panel in self._panels:
 | 
							for panel in self._windows:
 | 
				
			||||||
			panel.hide()
 | 
								panel.hide()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	def toggle_visibility(self):
 | 
						def toggle_visibility(self):
 | 
				
			||||||
		for panel in self._panels:
 | 
							for panel in self._windows:
 | 
				
			||||||
			if panel.props.visible:
 | 
								if panel.props.visible:
 | 
				
			||||||
				panel.hide()
 | 
									panel.hide()
 | 
				
			||||||
			else:
 | 
								else:
 | 
				
			||||||
 | 
				
			|||||||
@ -1,72 +0,0 @@
 | 
				
			|||||||
import gtk
 | 
					 | 
				
			||||||
import goocanvas
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
class PanelView(goocanvas.CanvasView):
 | 
					 | 
				
			||||||
	BORDER = 4
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	def construct(self, x, y):
 | 
					 | 
				
			||||||
		model = goocanvas.CanvasModelSimple()
 | 
					 | 
				
			||||||
		root = model.get_root_item()
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		item = goocanvas.Rect(x=0, y=0,
 | 
					 | 
				
			||||||
							  width=self.get_allocation().width,
 | 
					 | 
				
			||||||
							  height=self.get_allocation().height,
 | 
					 | 
				
			||||||
							  line_width=0, fill_color="#4f4f4f")
 | 
					 | 
				
			||||||
		root.add_child(item)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		self._group = goocanvas.Group()
 | 
					 | 
				
			||||||
		root.add_child(self._group)
 | 
					 | 
				
			||||||
		self._group.translate(x + PanelView.BORDER, y + PanelView.BORDER)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		self.set_model(model)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	def get_root_group(self):
 | 
					 | 
				
			||||||
		return self._group
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
class Panel(gtk.Window):
 | 
					 | 
				
			||||||
	def __init__(self):
 | 
					 | 
				
			||||||
		gtk.Window.__init__(self)
 | 
					 | 
				
			||||||
		self._x = 0
 | 
					 | 
				
			||||||
		self._y = 0
 | 
					 | 
				
			||||||
		self._constructed = False
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		self._view = PanelView()
 | 
					 | 
				
			||||||
		self.add(self._view)
 | 
					 | 
				
			||||||
		self._view.show()
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		self.set_decorated(False)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		self.realize()
 | 
					 | 
				
			||||||
		self.window.set_type_hint(gtk.gdk.WINDOW_TYPE_HINT_DIALOG)
 | 
					 | 
				
			||||||
		self.window.set_accept_focus(False)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		screen = gtk.gdk.screen_get_default()
 | 
					 | 
				
			||||||
		self.window.set_transient_for(screen.get_root_window())
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	def get_view(self):
 | 
					 | 
				
			||||||
		return self._view
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	def get_root(self):
 | 
					 | 
				
			||||||
		return self._view.get_root_group()
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	def get_height(self):
 | 
					 | 
				
			||||||
		height = self._view.get_allocation().height
 | 
					 | 
				
			||||||
		return height - PanelView.BORDER * 2
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	def get_width(self):
 | 
					 | 
				
			||||||
		width = self._view.get_allocation().width
 | 
					 | 
				
			||||||
		return width - PanelView.BORDER * 2
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	def set_position(self, x, y):
 | 
					 | 
				
			||||||
		self._x = x
 | 
					 | 
				
			||||||
		self._y = y
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	def construct(self):
 | 
					 | 
				
			||||||
		self._view.construct(self._x, self._y)
 | 
					 | 
				
			||||||
		self._constructed = True
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	def show(self):
 | 
					 | 
				
			||||||
		gtk.Window.show(self)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		if not self._constructed:
 | 
					 | 
				
			||||||
			self.construct()
 | 
					 | 
				
			||||||
							
								
								
									
										16
									
								
								shell/frame/PanelWindow.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								shell/frame/PanelWindow.py
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,16 @@
 | 
				
			|||||||
 | 
					import gtk
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					from sugar.canvas.CanvasWindow import CanvasWindow
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					class PanelWindow(CanvasWindow):
 | 
				
			||||||
 | 
						def __init__(self, model):
 | 
				
			||||||
 | 
							CanvasWindow.__init__(self, model)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							self.set_decorated(False)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							self.realize()
 | 
				
			||||||
 | 
							self.window.set_type_hint(gtk.gdk.WINDOW_TYPE_HINT_DIALOG)
 | 
				
			||||||
 | 
							self.window.set_accept_focus(False)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							screen = gtk.gdk.screen_get_default()
 | 
				
			||||||
 | 
							self.window.set_transient_for(screen.get_root_window())
 | 
				
			||||||
@ -1,40 +1,129 @@
 | 
				
			|||||||
 | 
					import gobject
 | 
				
			||||||
 | 
					import goocanvas
 | 
				
			||||||
 | 
					
 | 
				
			||||||
class GridConstraints:
 | 
					class GridConstraints:
 | 
				
			||||||
	def __init__(x, y, width, height):
 | 
						def __init__(self, x, y, width, height):
 | 
				
			||||||
		self.x = x
 | 
							self.x = x
 | 
				
			||||||
		self.y = y
 | 
							self.y = y
 | 
				
			||||||
		self.width = width
 | 
							self.width = width
 | 
				
			||||||
		self.height = height
 | 
							self.height = height
 | 
				
			||||||
 | 
							self.padding = 0
 | 
				
			||||||
 | 
					
 | 
				
			||||||
class GridLayout:
 | 
					class GridLayout:
 | 
				
			||||||
	def __init__(self, rows, cols):
 | 
						def __init__(self, rows=16, cols=12):
 | 
				
			||||||
		self._rows = rows
 | 
							self._rows = rows
 | 
				
			||||||
		self._cols = cols
 | 
							self._cols = cols
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		self._constraints = {}
 | 
							self._constraints = {}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	def set_constraints(component, constraints):
 | 
						def set_constraints(self, component, constraints):
 | 
				
			||||||
		self._constraints[component] = constraints
 | 
							self._constraints[component] = constraints
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	def _get_geometry(self, container, component):
 | 
						def _get_geometry(self, container, component):
 | 
				
			||||||
		constraints = self._constraints[component]
 | 
							constraints = self._constraints[component]
 | 
				
			||||||
		if constraints:
 | 
							if constraints:
 | 
				
			||||||
			x = constraints.x * component.props.width / self._rows
 | 
								return self.get_bounds(container, constraints)
 | 
				
			||||||
			y = constraints.y * component.props.height / self._cols
 | 
					 | 
				
			||||||
			width = constraints.width * component.props.width / self._rows
 | 
					 | 
				
			||||||
			height = constraints.height * component.props.height / self._cols
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
			return [x, y, width, height]
 | 
					 | 
				
			||||||
		else:
 | 
							else:
 | 
				
			||||||
			return [0, 0, 0, 0]
 | 
								return [0, 0, 0, 0]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	def layout_canvas_group(group):
 | 
						def get_bounds(self, container, constraints):
 | 
				
			||||||
 | 
							w = container.props.width
 | 
				
			||||||
 | 
							h = container.props.height
 | 
				
			||||||
 | 
							padding = constraints.padding
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							x = constraints.x * w / self._rows + padding
 | 
				
			||||||
 | 
							y = constraints.y * h / self._cols + padding
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							width = constraints.width * w / self._rows - padding * 2
 | 
				
			||||||
 | 
							height = constraints.height * h / self._cols + padding * 2
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							return [x, y, width, height]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						def layout_canvas_group(self, group):
 | 
				
			||||||
		i = 0
 | 
							i = 0
 | 
				
			||||||
		while i < group.get_n_children():
 | 
							while i < group.get_n_children():
 | 
				
			||||||
			item = group.get_child(i)
 | 
								item = group.get_child(i)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
			[x, y, width, height] = self._get_geometry(group, item)
 | 
								[x, y, width, height] = self._get_geometry(group, item)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								print item
 | 
				
			||||||
 | 
								print [x, y, width, height]
 | 
				
			||||||
 | 
								print group.props.width
 | 
				
			||||||
 | 
					
 | 
				
			||||||
			item.props.x = x
 | 
								item.props.x = x
 | 
				
			||||||
			item.props.y = y
 | 
								item.props.y = y
 | 
				
			||||||
			item.props.width = width
 | 
					
 | 
				
			||||||
			item.props.height = height
 | 
								try:
 | 
				
			||||||
 | 
									item.props.width = width
 | 
				
			||||||
 | 
									item.props.height = height
 | 
				
			||||||
 | 
								except:
 | 
				
			||||||
 | 
									item.props.size = width
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								i += 1
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						def layout_screen(self, screen):
 | 
				
			||||||
 | 
							for window in screen.get_windows():
 | 
				
			||||||
 | 
								[x, y, width, height] = self._get_geometry(screen, window)
 | 
				
			||||||
 | 
								window.move(x, y)
 | 
				
			||||||
 | 
								window.resize(width, height)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					class GridGroup(goocanvas.Group):
 | 
				
			||||||
 | 
						__gproperties__ = {
 | 
				
			||||||
 | 
							'x'    	   : (int, None, None, 0, 1600, 800,
 | 
				
			||||||
 | 
										  gobject.PARAM_READWRITE),
 | 
				
			||||||
 | 
							'y'        : (int, None, None, 0, 1200, 600,
 | 
				
			||||||
 | 
										  gobject.PARAM_READWRITE),
 | 
				
			||||||
 | 
							'width'    : (int, None, None, 0, 1600, 800,
 | 
				
			||||||
 | 
										  gobject.PARAM_READWRITE),
 | 
				
			||||||
 | 
							'height'   : (int, None, None, 0, 1200, 600,
 | 
				
			||||||
 | 
										  gobject.PARAM_READWRITE)
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						def _update_position(self):
 | 
				
			||||||
 | 
							if self._x != 0 or self._y != 0:
 | 
				
			||||||
 | 
								self.translate(self._x, self._y)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						def do_set_property(self, pspec, value):
 | 
				
			||||||
 | 
							if pspec.name == 'width':
 | 
				
			||||||
 | 
								self._width = value
 | 
				
			||||||
 | 
								self._layout.layout_canvas_group(self)
 | 
				
			||||||
 | 
							elif pspec.name == 'height':
 | 
				
			||||||
 | 
								self._height = value
 | 
				
			||||||
 | 
								self._layout.layout_canvas_group(self)
 | 
				
			||||||
 | 
							elif pspec.name == 'x':
 | 
				
			||||||
 | 
								self._x = value
 | 
				
			||||||
 | 
								self._update_position()
 | 
				
			||||||
 | 
							elif pspec.name == 'y':
 | 
				
			||||||
 | 
								self._y = value
 | 
				
			||||||
 | 
								self._update_position()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						def do_get_property(self, pspec):
 | 
				
			||||||
 | 
							if pspec.name == 'width':
 | 
				
			||||||
 | 
								return self._width
 | 
				
			||||||
 | 
							elif pspec.name == 'height':
 | 
				
			||||||
 | 
								return self._height
 | 
				
			||||||
 | 
							elif pspec.name == 'x':
 | 
				
			||||||
 | 
								return self._x
 | 
				
			||||||
 | 
							elif pspec.name == 'x':
 | 
				
			||||||
 | 
								return self._x
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						def __init__(self, rows=-1, cols=-1):
 | 
				
			||||||
 | 
							self._x = 0
 | 
				
			||||||
 | 
							self._y = 0
 | 
				
			||||||
 | 
							self._width = 0
 | 
				
			||||||
 | 
							self._height = 0
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							goocanvas.Group.__init__(self)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							if rows < 0 and cols < 0:
 | 
				
			||||||
 | 
								self._layout = GridLayout()
 | 
				
			||||||
 | 
							else:
 | 
				
			||||||
 | 
								self._layout = GridLayout(rows, cols)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							self.connect('child-added', self.__child_added_cb)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						def get_layout(self):
 | 
				
			||||||
 | 
							return self._layout
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						def __child_added_cb(self, child, position):
 | 
				
			||||||
 | 
							self._layout.layout_canvas_group(self)
 | 
				
			||||||
 | 
				
			|||||||
@ -119,9 +119,10 @@ class IconView(goocanvas.ItemViewSimple, goocanvas.ItemView):
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
		cr.translate(self.item.x, self.item.y)
 | 
							cr.translate(self.item.x, self.item.y)
 | 
				
			||||||
		scale_factor = float(self.item.size) / float(_ICON_SIZE)
 | 
							scale_factor = float(self.item.size) / float(_ICON_SIZE)
 | 
				
			||||||
		cr.scale(scale_factor, scale_factor)
 | 
					
 | 
				
			||||||
		
 | 
							if scale_factor != 0.0:
 | 
				
			||||||
		handle.render_cairo(cr)
 | 
								cr.scale(scale_factor, scale_factor)		
 | 
				
			||||||
 | 
								handle.render_cairo(cr)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		cr.restore()
 | 
							cr.restore()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -139,20 +140,18 @@ class IconItem(goocanvas.ItemSimple, goocanvas.Item):
 | 
				
			|||||||
		'y'        : (float, None, None, -10e6, 10e6, 0,
 | 
							'y'        : (float, None, None, -10e6, 10e6, 0,
 | 
				
			||||||
					  gobject.PARAM_READWRITE),
 | 
										  gobject.PARAM_READWRITE),
 | 
				
			||||||
		'icon-name': (str, None, None, None,
 | 
							'icon-name': (str, None, None, None,
 | 
				
			||||||
					  gobject.PARAM_CONSTRUCT_ONLY |
 | 
					 | 
				
			||||||
					  gobject.PARAM_READWRITE),
 | 
										  gobject.PARAM_READWRITE),
 | 
				
			||||||
		'color'    : (object, None, None,
 | 
							'color'    : (object, None, None,
 | 
				
			||||||
					  gobject.PARAM_CONSTRUCT_ONLY |
 | 
					 | 
				
			||||||
					  gobject.PARAM_READWRITE),
 | 
										  gobject.PARAM_READWRITE),
 | 
				
			||||||
		'size'     : (int, None, None,
 | 
							'size'     : (int, None, None,
 | 
				
			||||||
					  0, 1024, 24,
 | 
										  0, 1024, 24,
 | 
				
			||||||
					  gobject.PARAM_CONSTRUCT_ONLY |
 | 
					 | 
				
			||||||
					  gobject.PARAM_READWRITE)
 | 
										  gobject.PARAM_READWRITE)
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	def __init__(self, **kwargs):
 | 
						def __init__(self, **kwargs):
 | 
				
			||||||
		self.x = 0.0
 | 
							self.x = 0.0
 | 
				
			||||||
		self.y = 0.0
 | 
							self.y = 0.0
 | 
				
			||||||
 | 
							self.size = 24
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		goocanvas.ItemSimple.__init__(self, **kwargs)
 | 
							goocanvas.ItemSimple.__init__(self, **kwargs)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
		Reference in New Issue
	
	Block a user