VocalEasel/mma/MMA/patDrum.py

140 lines
3.3 KiB
Python
Raw Permalink Normal View History

2006-11-10 08:07:56 +00:00
# patDrum.py
"""
2007-04-29 06:47:40 +00:00
This module is an integeral part of the program
2006-11-10 08:07:56 +00:00
MMA - Musical Midi Accompaniment.
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
2007-04-29 06:47:40 +00:00
Bob van der Poel <bob@mellowood.ca>
2006-11-10 08:07:56 +00:00
"""
2009-05-17 22:34:44 +00:00
import MMA.notelen
2006-11-10 08:07:56 +00:00
import MMA.translate
2009-05-17 22:34:44 +00:00
import gbl
from MMA.common import *
from MMA.pat import PC
2006-11-10 08:07:56 +00:00
class Drum(PC):
2007-04-29 06:47:40 +00:00
""" Pattern class for a drum track. """
vtype = 'DRUM'
def __init__(self, ln):
""" init for drum track. """
2011-07-26 22:49:39 +00:00
self.toneList = [38]
PC.__init__(self, ln) # This order is important!
2007-04-29 06:47:40 +00:00
self.setChannel('10')
if not gbl.mtrks[self.channel].trackname:
gbl.mtrks[self.channel].addTrkName(0, 'Drum')
2011-07-26 22:49:39 +00:00
def saveGroove(self, gname):
""" Save special/local variables for groove. """
PC.saveGroove(self, gname) # do this 1st. Creates storage.
self.grooves[gname]['TONES'] = self.toneList[:]
2007-04-29 06:47:40 +00:00
2011-07-26 22:49:39 +00:00
def restoreGroove(self, gname):
""" Restore special/local/variables for groove. """
self.toneList = self.grooves[gname]['TONES']
PC.restoreGroove(self, gname)
def setSeqSize(self):
""" Expand existing pattern list. """
self.toneList = seqBump(self.toneList)
PC.setSeqSize(self)
def clearSequence(self):
""" Set some initial values. Called from init and clear seq. """
PC.clearSequence(self)
self.toneList = seqBump([38])
2007-04-29 06:47:40 +00:00
def setTone(self, ln):
""" Set a tone list. Only valid for DRUMs.
ln[] is not nesc. the right length.
"""
2009-05-17 22:34:44 +00:00
ln = lnExpand(ln, '%s Tone' % self.name)
2007-04-29 06:47:40 +00:00
tmp = []
for n in ln:
tmp.append(MMA.translate.dtable.get(n))
self.toneList = seqBump( tmp )
def restart(self):
self.ssvoice = -1
def getPgroup(self, ev):
""" Get group for a drum pattern.
Fields - start, length, volume
"""
if len(ev) != 3:
error("There must be at exactly 3 items in each "
"group of a drum define, not <%s>" % ' '.join(ev) )
a = struct()
a.offset = self.setBarOffset(ev[0])
2009-05-17 22:34:44 +00:00
a.duration = MMA.notelen.getNoteLen(ev[1])
2007-04-29 06:47:40 +00:00
a.vol = stoi(ev[2], "Type error in Drum volume")
return a
def trackBar(self, pattern, ctable):
""" Do a drum bar.
Called from self.bar()
"""
sc = self.seq
for p in pattern:
tb = self.getChordInPos(p.offset, ctable)
if tb.drumZ:
continue
self.sendNote(
p.offset,
self.getDur(p.duration),
self.toneList[sc],
self.adjustVolume(p.vol, p.offset) )