Difference between revisions of "Features/GTK3/Porting/Implode"

From Sugar Labs
< Features‎ | GTK3‎ | Porting
Jump to navigation Jump to search
(New signals)
 
(11 intermediate revisions by the same user not shown)
Line 8: Line 8:
  
 
There are some things related with <tt>gtk.DrawingArea</tt> that we have to change when we are porting an activity to Gtk3. The names of the signals change and the way that they work as well.
 
There are some things related with <tt>gtk.DrawingArea</tt> that we have to change when we are porting an activity to Gtk3. The names of the signals change and the way that they work as well.
 +
 +
== Get allocation size ==
 +
 +
''self.allocation'' property is no longer available and we should use <tt>self.get_allocation_width</tt> to get the allocation size:
 +
 +
self.allocation.width
 +
self.allocation.height
 +
 +
should be replaced by:
 +
 +
self.get_allocated_width()
 +
self.get_allocated_height()
  
 
== Signals ==
 
== Signals ==
  
 
=== expose-event ===
 
=== expose-event ===
 
* http://developer.gnome.org/gtk3/3.5/GtkWidget.html#GtkWidget-draw
 
  
 
This signal was override by '''draw''' and it have to be connected with the method that was connected with the ''expose-event'' before. The method itself does not change but the arguments that it receives do. This is the new definition of the function in my case:
 
This signal was override by '''draw''' and it have to be connected with the method that was connected with the ''expose-event'' before. The method itself does not change but the arguments that it receives do. This is the new definition of the function in my case:
Line 20: Line 30:
  
 
=== size-allocate ===
 
=== size-allocate ===
 
* http://developer.gnome.org/gtk3/3.5/GtkWidget.html#GtkWidget-configure-event
 
  
 
This signal was used to resize the gtk.DrawingArea every time the window grows and at the startup of the activity. This is useful to re-draw the widget for different resolutions (desktops and XOs for example).
 
This signal was used to resize the gtk.DrawingArea every time the window grows and at the startup of the activity. This is useful to re-draw the widget for different resolutions (desktops and XOs for example).
Line 29: Line 37:
 
  def _configure_event_cb(self, widget, event):
 
  def _configure_event_cb(self, widget, event):
  
I just used the ''size-allocate'' signal to save the the dimensions of the widget (width and height), so I can use them later on the '''draw''' signal.
+
== Focus ==
 +
 
 +
Implode defines a new widget called ''GridWidget'' and it should be focusable because we want to move a cursor with the key arrows on it. So, this widget was using:
 +
 
 +
self.set_flags(Gtk.CAN_FOCUS)
 +
 
 +
but that method (''set_flags'') is no longer available and we have to replace it by:
 +
 
 +
self.set_can_focus(True)
  
def _size_allocate_cb(self, widget, rect):
+
Another thing related with the focus is to know who has the actual focus. In gtk2 it was done by
    self.width = rect.width
 
    self.height = rect.height
 
  
= Focus =
+
.focus_child
  
Replace:
+
and in Gtk3 it should be replaced by:
 +
 
 +
.get_focus_child()
  
self.set_flags(Gtk.CAN_FOCUS)
 
  
by
+
= Handling .svg with rsvg =
  
self.set_can_focus(True)
+
'''rsvg''' is a library to manage ''.svg'' files. The only thing that I found that should be updated is the import and the loading of a rsvg from data.
  
----
+
Replace the usual import:
  
 
  import rsgv
 
  import rsgv
 +
 +
by the Gtk3 one:
  
 
  from gi.repository import Rsvg
 
  from gi.repository import Rsvg
 +
 +
This way to load a rsvg from data should be replaced:
  
 
  rsvg.Handle(data=data)
 
  rsvg.Handle(data=data)
 +
 +
by this new way
  
 
  Rsvg.Handle.new_from_data(data)
 
  Rsvg.Handle.new_from_data(data)
  
----
+
= Invalidate rectangle =
  
  .focus_child
+
<tt>Gdk.Window.invalidate_rect</tt> takes a ''Gdk.Rectangle'' instead a tuple in Gtk3.
 +
 
 +
  rect = Gdk.Rectangle()
 +
rect.x, rect.y, rect.width, rect.height = (0, 0, width, height)
 +
 
 +
self.get_window().invalidate_rect(rect, True)
 +
 
 +
= Notes =
 +
 
 +
* I had to add a third argument (None) to Gtk.Notebook.append_page but I don't know why
 +
* Use '''json''' instead of ''simplejson'' or so
 +
* Replace <tt>gtk.VISIBLE</tt> by '''Gtk.AccelFlags.VISIBLE'''
  
.get_focus_child()
+
= Missing things (not ported yet) =
  
'size-allocation' signal to save the size of the widget
+
* ''sugarless.py'' is not working. The board is not shown. Do we update this to keep it working? I mean, do we need to maintain this code?
 +
* [<span style="color: green;">DONE</span>] <del>help dialogue is not working. It shows the example board but it's one pixel size when it opens</del>
 +
* When the help dialogue is shown and you hover the animation with the mouse something strange happens and it starts to flap. [http://bugs.sugarlabs.org/attachment/ticket/3715/53.png Screenshot]
  
= gtk signals =
+
= Useful Links =
  
* "draw" / "expose" / "size-"
+
* http://developer.gnome.org/gtk3/3.5/GtkWidget.html#GtkWidget-draw
 +
* http://developer.gnome.org/gtk3/3.5/GtkWidget.html#GtkWidget-configure-event
 +
* http://developer.gnome.org/rsvg/stable/
 +
* http://developer.gnome.org/gdk3/stable/gdk3-Windows.html#gdk-window-invalidate-rect
 +
* http://developer.gnome.org/gtk3/3.5/GtkWidget.html#gtk-widget-get-allocated-width
 +
* http://developer.gnome.org/gtk3/3.5/GtkNotebook.html#gtk-notebook-append-page

Latest revision as of 07:43, 17 July 2012

This page is being performed while I'm porting Implode Activity to Gtk3.

There is a ticket with some useful information that I'm using on the porting and to keep tracking this port. Besides, this wiki page will be useful to write some code snippets about what are the difficulties that I'm having on the port and maybe can be useful for someone else.

I will take this guide as reference on the Gtk3 porting.

Porting Gtk.DrawingArea

There are some things related with gtk.DrawingArea that we have to change when we are porting an activity to Gtk3. The names of the signals change and the way that they work as well.

Get allocation size

self.allocation property is no longer available and we should use self.get_allocation_width to get the allocation size:

self.allocation.width
self.allocation.height

should be replaced by:

self.get_allocated_width()
self.get_allocated_height()

Signals

expose-event

This signal was override by draw and it have to be connected with the method that was connected with the expose-event before. The method itself does not change but the arguments that it receives do. This is the new definition of the function in my case:

def _draw_event_cb(self, widget, cr):

size-allocate

This signal was used to resize the gtk.DrawingArea every time the window grows and at the startup of the activity. This is useful to re-draw the widget for different resolutions (desktops and XOs for example).

I used the same function connected to this signal but I change the signal connected by configure-event. Here is the definition of the callback:

def _configure_event_cb(self, widget, event):

Focus

Implode defines a new widget called GridWidget and it should be focusable because we want to move a cursor with the key arrows on it. So, this widget was using:

self.set_flags(Gtk.CAN_FOCUS)

but that method (set_flags) is no longer available and we have to replace it by:

self.set_can_focus(True)

Another thing related with the focus is to know who has the actual focus. In gtk2 it was done by

.focus_child

and in Gtk3 it should be replaced by:

.get_focus_child()


Handling .svg with rsvg

rsvg is a library to manage .svg files. The only thing that I found that should be updated is the import and the loading of a rsvg from data.

Replace the usual import:

import rsgv

by the Gtk3 one:

from gi.repository import Rsvg

This way to load a rsvg from data should be replaced:

rsvg.Handle(data=data)

by this new way

Rsvg.Handle.new_from_data(data)

Invalidate rectangle

Gdk.Window.invalidate_rect takes a Gdk.Rectangle instead a tuple in Gtk3.

rect = Gdk.Rectangle()
rect.x, rect.y, rect.width, rect.height = (0, 0, width, height)
self.get_window().invalidate_rect(rect, True)

Notes

  • I had to add a third argument (None) to Gtk.Notebook.append_page but I don't know why
  • Use json instead of simplejson or so
  • Replace gtk.VISIBLE by Gtk.AccelFlags.VISIBLE

Missing things (not ported yet)

  • sugarless.py is not working. The board is not shown. Do we update this to keep it working? I mean, do we need to maintain this code?
  • [DONE] help dialogue is not working. It shows the example board but it's one pixel size when it opens
  • When the help dialogue is shown and you hover the animation with the mouse something strange happens and it starts to flap. Screenshot

Useful Links