[alsa-devel] problems howto send simple 'noteon' event with pyalsa...
Aldrin Martoq
amartoq at dcc.uchile.cl
Thu Mar 13 19:07:17 CET 2008
Hello,
On Thu, Mar 13, 2008 at 9:34 AM, Jaroslav Kysela <perex at perex.cz> wrote:
> On Thu, 13 Mar 2008, ki.ber.kom.uni.st wrote:
> > i was happy user of PySeq [1] and it was easy to send directly
> > 'noteon' event.. more or less in python interactoin session:
> > import pyseq
> >
> > seq = pyseq.PySeq()
> > seq.createOutPort()
> > event = snd_seq_event()
> > event.setSource(0)
> > event.setSubscribers()
> > event.setNoteOn(ch, note, velocity)
> > event.sendAsIs(seq)
> >
> > it seems that pyalsa will go along alsa development so i tried pyalsa.. but....
You can send NOTEON events without a queue, but you cannot send NOTE
events without a queue. (subtle difference: note_ON_)
The following code will work; 14:0 is "midi-through" in my system... I
run aseqdump -p 14:0 on another window:
seq = alsaseq.Sequencer()
event = alsaseq.SeqEvent(alsaseq.SEQ_EVENT_NOTEON)
event.set_data({'note.note' : 0x40, 'note.velocity' : 64})
event.dest = (14, 0)
seq.output_event(event)
seq.drain_output()
> > i tried this:
> > from pyalsa import alsaseq
> > seq = alsaseq.Sequencer()
> > seq.create_simple_port("myPort", alsaseq.SEQ_PORT_TYPE_APPLICATION,
> > alsaseq.SEQ_PORT_CAP_SUBS_READ | alsaseq.SEQ_PORT_CAP_READ |
> > alsaseq.SEQ_PORT_CAP_WRITE | alsaseq.SEQ_PORT_CAP_SUBS_WRITE)
AFAIK, You don't need a port if you are sending events directly.
Now, if you subscribe and connect ports, you don't need to assign them
into the event, because a new event is created with
snd_seq_ev_set_subs called..
You can check this and other stuff with the following code:
-ini-------------
def _find_attributes(typelist):
l = []
for t in typelist:
d = t.__dict__.items()
for k, v in d:
v = "%s" % v
if v.startswith("<attribute"):
l.append(k)
l.sort()
return l
def dump_event(port, name = 'seqevent'):
print "Dumping Event ---------->"
print "%s" % port
l = _find_attributes([alsaseq.SeqEvent])
for k in l:
print "%-30.30s %s" % (name + "." + k, port.__getattribute__(k))
return
seq = alsaseq.Sequencer()
event = alsaseq.SeqEvent(alsaseq.SEQ_EVENT_NOTEON)
event.set_data({'note.note' : 0x40, 'note.velocity' : 64})
dump_event(event)
seq.output_event(event)
seq.drain_output()
-------------end--
> > event = alsaseq.SeqEvent(alsaseq.SEQ_EVENT_NOTE)
> > event.set_data({'note.note' : 0x40, 'note.velocity' : 127,
> > 'note.duration' : 1, 'note.off_velocity' : 0})
note.duration and note.off_velocity make sense only for
SEQ_EVENT_NOTE, but you need a queue... so, use SEQ_EVENT_NOTEON and
SEQ_EVENT_NOTEOFF instead....
I'm planning to move event.set_data() to attributes, like
event.note_note, event.note_velocity ... Tell me what you think!
> > event.dest = (20, 0)
> > seq.output_event(event)
> > seq.drain_output()
> >
> > after drain it says:
> > "SequencerError: Failed to drain output: Invalid argument"
Well, that's what asoundlib says... weird, don't you think?
Alsa hackers: This is a good proof that alsa-lib message errors
really, really sucks... Is there any chance to change this? I mean, if
I volunteer to improve this could be accepted? Any hints for doing
this?
[...]
> > any ideas? do i have to use queues to be able to send 'noteon'.. for
> > my purposes it seems to me that that's overkill....
Remember: python is far away of real-time so if you get weirds timings
you may reconsider using a queue anyway!
HTH,
--
Aldrin Martoq
http://aldrinvideopodcast.podshow.com/
More information about the Alsa-devel
mailing list