View Single Post
Old 6th January 2022, 14:31   #3
ForestCat
Junior Member
 
Join Date: Mar 2018
Posts: 6
I checked out Nestdrop, and saw that video early on in my search. I emailed Patrick about it, since there's no real docs/demo enumerating the full MIDI implementation. I got a brief reply, but no real info. I replied with the following, but never received an answer

********************************

Patrick,

Thanks for your reply. A few thoughts. With the goal always to be visuals that respond to music in a complementary and aesthetically pleasing way, I think the initial approach is to start with a small handful of things that provide the most 'bang for the buck", from the standpoint of coding effort and additional ui complexity. The problem with paramater(variable) control via midi (or even arbitrary qwerty key mappings, if that were implemented) as you say, is the huge number of variables, and the wildly varying relevance of any given variable across presets. ie, a variable that is enormously useful for visual jamming in one preset might have no effect in another. One way to deal with this would be to allow preset authors to specify the mappings within each preset file, perhaps within a metadata or special comment area that would not break the preset's compatibility with other milkdrop implementations, if possible. That approach requires ZERO change to the ui, other than perhaps some way to flag a user of duplicate mappings (Midnight version). It could remain a 'hidden' advanced feature, at least initially.

I'm sure you're familiar with the milkdrop mashup feature. One of the most visually radical ways to 'jam' with milkdrop in real time (in Winamp) is in VJ mode, with the video on a second monitor, while "mashing up" in real time, on the beat, in the VJ control window on the primary monitor. It doesn't take very long to find some really awesome combinations..

It would add complexity to the ui, but what about the ability to to create meta-presets (scenes, etc) in nestdrop, which allow 'mashup groups', ie user-selected pools of presets per bin per preset?

It could be implemented like your cue windows, 5 special 'mashup cue' windows representing the 5 'bins' in the winamp milkdrop menu, left-clicking a preset icon within a bin would have the same effect as cursor up-dn on the winamp milkdrop mashup menu

and then allow MIDI control, as follows:

The 5 bins each get a MIDI channel and note range, definable within an .ini/.cfg, a ui could be added later if you desire.
The size of the note range should probably match the capacity of the mashup cue windows mentioned above
For example, if you decide on 12 presets per bin cue window(matches an octave), we could initially put all the bins on the same channel, and 'zone' the notes:
Bin 1= MIDI Note 36-47
Bin 2= MIDI Note 48-59
Bin 3= MIDI Note 60-71
Bin 4= MIDI Note 72-83
Bin 5= MIDI Note 84-95

Which nicely matches a 5 octave MIDI keyboard, giving one a 'visual instrument' with an INSANE amount of realtime visual control/variety that is intuitive to play 'on the beat' or sequence, etc.


I don't know where nestdrop development is on your radar right now. I know these things tend to wax and wane. Like I said, I'd like to get involved. I have zero commercial interest, I make an honest living and I'm not looking to expand that into software sales. It's just for me. I'm a guy with a lot of music that I want to create compelling video from, I keep coming back to milkdrop from touchdesigner, processing, Max, etc, etc. I've been playing w/ the milkdrop source in Visual Studio. I don't want to waste precious time reinventing the wheel if someone(you) has already got the MIDI hooks into the milkdrop core. The majority of my coding has been embedded controller, atmel, Cypress, arduino, etc., creating touch screen controls for my MIDI guitar, pedalboards, etc. I helped shape the Amiga version of Dr. T's KCS (if you're old enough to remember that, lol). Had one of the very first copies available for the C-64, did an album on it which was released on Larry Fast's Audion label in the 80's. I've beta-tested for Kurzweil. I can be trusted with an NDA.
I have no problem purchasing the Midnight version if you'd provide access to the windows source code, with the written understanding that you retain all rights to any ideas that I'm able to implement.

I didn't want to blindly purchase the midnight edition, there's no demo, and the big question is whether the mashup function is still present somehow 'under the hood' in nestdrop midnight. That's critical to what I want to do. How much of the milkdrop 2.xx source/functionality exists in nestdrop midnight?

I've been struggling trying to shoehorn MIDI into the milkdrop source in Visual Studio. I tried the RTMIDI lib, was able to compile some stand-alone MIDI input parser stuff, but can't get it to compile in the milkdrop source.

Even if you have no interest in having me work on nestdrop, would you perhaps sell me a little of your time/code to get some type of MIDI input working in the milkdrop source? I'm assuming you've done that, or at least it would be trivial to translate the MIDI input from nestdrop to MS VC++

BTW, what dev environment are you using for windows?

Sorry for the long-winded mail, thanks so much for reading.

*******************************************************


So that's where I'm stuck, trying to find a way to read MIDI data the same way that keys are handled in the various case statements in the HandleRegularKey function, etc in plugin.cpp. In that case, it looks like the grunt work is done by the ms windows libraries, milkdrop only needs to look for a relevant WPARAM.

How can I do that with incoming MIDI data?

Thanks!
ForestCat is offline   Reply With Quote