This script demonstrates how the current position within the mesh
can be displayed with some graphics (
).
#!/usr/bin/env python
import time, sys
import HasyUtils, Spectra
import PyTango
def main():
#
# x - the sweep motor
#
(nameX, startX, stopX, sweepTime, npX) = ("d1_mot66", 0., 0.2, 5., 300)
(nameY, startY, stopY, deltaY) = ("d1_mot67", 0.1, 0.2, 0.01)
npY = (stopY - startY)/deltaY + 1
npY *= 2
try:
o = HasyUtils.moveLoop( nameX, startX, stopX, sweepTime,
nameY, startY, stopY, deltaY)
except Exception, e:
print "Exception from moveLoop() constructor"
print repr( e)
sys.exit( 255)
scanMesh = HasyUtils.scanMesh( nameX = nameX, nameY = nameY,
comment = "%s: (%g, %g), %s: (%g, %g, %g)" %\
(nameX, startX, stopX, nameY, startY, stopY, deltaY),
startX = startX, stopX = stopX, npX = npX,
startY = startY, stopY = stopY, npY = npY)
try:
o.toStart()
except Exception, e:
print "Exception from ToStart"
print repr( e)
sys.exitr( 255)
while o.state() == PyTango.DevState.MOVING:
print "toStart: posX %g, posY %g" % ( o.proxyX.Position, o.proxyY.Position)
time.sleep(0.5)
o.run()
count = 0
while o.state() == PyTango.DevState.MOVING:
scanMesh.setX( count, o.proxyX.Position)
scanMesh.setY( count, o.proxyY.Position)
if count % 5 == 0:
scanMesh.display()
count += 1
time.sleep(0.01)
(sts, result) = Spectra.gra_yesno( "Enter Spectra")
if result == 1:
Spectra.gra_input()
if __name__ == "__main__":
main()