diff options
| author | Robert Jonsson <spamatica@gmail.com> | 2010-10-13 19:34:22 +0000 | 
|---|---|---|
| committer | Robert Jonsson <spamatica@gmail.com> | 2010-10-13 19:34:22 +0000 | 
| commit | 8a2c2824a59d7644e13bc52c9a0ecbd641f21f95 (patch) | |
| tree | 064ad3f2bf8daab0ad27b128abd86a9bbdb1e496 /muse2/share/pybridge/examples/repeatpart.py | |
| parent | a27706d9629e8b592cca4659f865b70adef24e6d (diff) | |
new branch muse2, first checkin
Diffstat (limited to 'muse2/share/pybridge/examples/repeatpart.py')
| -rw-r--r-- | muse2/share/pybridge/examples/repeatpart.py | 61 | 
1 files changed, 61 insertions, 0 deletions
| diff --git a/muse2/share/pybridge/examples/repeatpart.py b/muse2/share/pybridge/examples/repeatpart.py new file mode 100644 index 00000000..e2b8ff31 --- /dev/null +++ b/muse2/share/pybridge/examples/repeatpart.py @@ -0,0 +1,61 @@ +""" +//========================================================= +//  MusE +//  Linux Music Editor +//  (C) Copyright 2009 Mathias Gyllengahm (lunar_shuttle@users.sf.net) +//========================================================= +""" + +import Pyro.core +import sys +import time + +SLEEPIVAL=0.3 + +def advanceToNextSection(muse, newlpos, newrpos): +      print "Advancing..." +      currpos = muse.getRPos() +      curlpos = muse.getLPos() +      curpos = muse.getCPos() +      muse.setLoop(False) + +      while curpos < currpos: +            time.sleep(SLEEPIVAL) +            curpos = muse.getCPos() +      print "Leaving current section..." +      muse.setRPos(newrpos) +      curpos = muse.getCPos() + +      while curpos < newlpos: +            time.sleep(SLEEPIVAL) +            curpos = muse.getCPos() +      print "Entered new section" +      muse.setLPos(newlpos) +      muse.setLoop(True) +      return + +muse=Pyro.core.getProxyForURI('PYRONAME://:Default.muse') +muse.stopPlay() +parts = muse.getParts("Track 1") +muse.setLPos(parts[0]['tick']) +muse.setRPos(parts[0]['tick'] + parts[0]['len']) +muse.setCPos(0) +time.sleep(0.2) # Hmmm, don't like it but it seems necessary to pause a short while before starting play +muse.setLoop(True) +muse.startPlay() + +for i in range(1, len(parts)): +      part = parts[i] +      tick = part['tick'] +      len = part['len'] +      print "Press enter to advance to next section/part!" +      sys.stdin.read(1) +      advanceToNextSection(muse, tick, tick + len) + +print "This is the final section. Disabling loop and leaving..." +muse.setLoop(False) + +#print "Press enter to leave final section" +#sys.stdin.read(1) +#muse.setLoop(False) + | 
