X-Git-Url: http://git.cascardo.eti.br/?a=blobdiff_plain;f=gzv.py;h=ac4dce3a9d94ee3563ba8c87219eaecd97517152;hb=6a65c73d806b38167701cee3d75f2751822f8f6d;hp=8eb7fdb9bdadc931455d53360e4a2c65498c69ee;hpb=5da18335d44591703fee8287d29e986b672b5cae;p=cascardo%2Fmovie.git diff --git a/gzv.py b/gzv.py index 8eb7fdb..ac4dce3 100644 --- a/gzv.py +++ b/gzv.py @@ -1,5 +1,5 @@ # -*- coding: utf-8; -*- -# gzv.py - an user interface to generate-zooming-video +# gzv.py - an user interface to select people in a picture # # Copyright (C) 2008 Lincoln de Sousa # @@ -266,7 +266,8 @@ class Gzv(GladeLoader): self.set_widgets_sensitivity(False) def set_widgets_sensitivity(self, sensitive): - for i in 'toolbutton1', 'toolbutton5', 'scrolledwindow1', 'hbox2': + for i in 'toolbutton1', 'toolbutton5', 'scrolledwindow1', \ + 'hbox2', 'imagemenuitem3': self.wid(i).set_sensitive(sensitive) def load_balls_to_treeview(self): @@ -317,10 +318,8 @@ class Gzv(GladeLoader): # point begining from the left image border wib = self.point_with_border(ball) - print wib.x, w - - self.wid('viewport').get_vadjustment().value = wib.x # + (w / 2) - self.wid('viewport').get_hadjustment().value = wib.y # + (h / 2) + #self.wid('viewport').get_vadjustment().value = wib.x # + (w / 2) + #self.wid('viewport').get_hadjustment().value = wib.y # + (h / 2) self.draw.queue_draw() @@ -356,6 +355,40 @@ class Gzv(GladeLoader): self.balls.save_to_file(self.project.focus_points_file) + def move_fp_up(self, *args): + selection = self.treeview.get_selection() + model, path = selection.get_selected() + if not path: + return + + pos = model[path][0] + newpos = max(pos - 1, 0) + self.balls.insert(newpos, self.balls.pop(pos)) + + # normalizing the position of elements. + for index, item in enumerate(self.balls): + item.position = index + + self.load_balls_to_treeview() + selection.select_path(str(newpos)) + + def move_fp_down(self, *args): + selection = self.treeview.get_selection() + model, path = selection.get_selected() + if not path: + return + + pos = model[path][0] + newpos = min(pos + 1, len(self.balls)) + self.balls.insert(newpos, self.balls.pop(pos)) + + # normalizing the position of elements. + for index, item in enumerate(self.balls): + item.position = index + + self.load_balls_to_treeview() + selection.select_path(str(newpos)) + def expose_draw(self, draw, event): if not self.image: return