root / ase / gui / rotate.py @ 4
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 |