Statistiques
| Révision :

root / ase / gui / rotate.py @ 18

Historique | Voir | Annoter | Télécharger (1,5 ko)

1
import numpy as np
2
import gtk
3

    
4
from ase.gui.widgets import pack
5
from ase.utils import rotate, irotate
6

    
7

    
8
class Rotate(gtk.Window):
9
    update = True
10
    
11
    def __init__(self, gui):
12
        gtk.Window.__init__(self)
13
        angles = irotate(gui.axes)
14
        self.set_title('Rotate')
15
        vbox = gtk.VBox()
16
        pack(vbox, gtk.Label('Rotation angles:'))
17
        self.rotate = [gtk.Adjustment(value=a, lower=-360, upper=360,
18
                                      step_incr=1, page_incr=10)
19
                       for a in angles]
20
        pack(vbox, [gtk.SpinButton(a, climb_rate=0, digits=1)
21
                    for a in self.rotate])
22
        for r in self.rotate:
23
            r.connect('value-changed', self.change)
24
        button = pack(vbox, gtk.Button('Update'))
25
        button.connect('clicked', self.update_angles)
26
        pack(vbox, gtk.Label('Note:\nYou can rotate freely\n'
27
                             'with the mouse, by holding\n'
28
                             'down mouse botton 2.'))
29
        self.add(vbox)
30
        vbox.show()
31
        self.show()
32
        self.gui = gui
33

    
34
    def change(self, adjustment):
35
        if self.update:
36
            x, y, z = [float(a.value) for a in self.rotate]
37
            self.gui.axes = rotate('%fx,%fy,%fz' % (x, y, z))
38
            self.gui.set_coordinates()
39
        return True
40
        
41
    def update_angles(self, button):
42
        angles = irotate(self.gui.axes)
43
        self.update = False
44
        for r, a in zip(self.rotate, angles):
45
            r.value = a
46
        self.update = True