-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdevice_Novation_Launchkey_Mini_MK3.py
221 lines (181 loc) · 9.67 KB
/
device_Novation_Launchkey_Mini_MK3.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
# name=Novation Launchkey Mini MK3 (by Frank Grimy) v1.4.1
# url=https://forum.image-line.com/viewtopic.php?f=1994&t=260133
# supportedDevices=MIDIIN2 (Launchkey Mini MK3 MID,Launchkey Mini MK3 DAW Port
# Import list
import midi, mixer, channels
from mxr.mirectangle import Rectangle
import pads, knobs, mixerlowpads, browse, handlers
import variables as var, constants as cons, drumpads as drum, stepsequencer as step, panvol as pv, scenedown as scdown
import uimessages as uimsg, scenedownlights as downlight, padknobmodes as pkm
import upperpadslights as uplights
import upperpadsactions as upact, crlowpads as crlp, transportbuttons as trns
from cust_gen import *
from fruity_gen import *
from cust_fxctrl import *
import fruity_fxctrl
from fruity_fxctrl import *
#import mxr.embdeq
from editors.shortcuts import *
from time import time
from deinit import QuitFL
from initialize import Startup
from windowfocus import WindowFocus
from sceneup import SceneUpMidi, UpColorsPush, UpColorsIdle
from longPress import Hold
#import plugins
from performance import *
import colPalette as col
from performance import perflights
def OnInit():
Startup.OnInit()
if var.isPerformance:
#perflights.setLights()
perflights.liveZone(1)
def OnDeInit():
QuitFL.OnDeInit()
def OnRefresh(HW_Dirty_LEDs):
fxDetect.pluginInfo().OnRefresh() # Sets var.focusedPlugin to the active effect in the mixer, including its coordinates.
perfmode.setPerfMode() # Detects if Performance mode is enabled.
#if var.isPerformance:
# perflights.setLights() # Performance mode lights.
#perflights.liveZone(1) # Performance mode live zone.
#print (var.perfPosition)
#if not var.isPerformance:
# mixerlowpads.LowerLights()
# UpColorsPush() # Up button colors.
# uplights.Padlights() # Upper pads + transport lighting.
# downlight.Downbutton()
# WindowFocus() # Detects the focused window in FL Studio.
# UpColorsIdle() # Colors for Scene-up button
# ### Lower pads colors for Mixer mode!
# mixerlowpads.LowerLights()
# ### Lower pads colors for Channel rack mode!
# crlp.LowerLights()
### Step-sequencer lights
step.SeqLights()
def OnIdle(): # Functionality that runs in the background. This lets the script to give feedback to the user in real time and in context.
var.currentTime = time() # Sets the current time for the script.
#perflights.liveZone(1)
Hold(0.250) # Detects if the Scene-up button is being held, during 250 milliseconds.
WindowFocus() # Detects the focused window in FL Studio.
var.isPlaying = transport.isPlaying() # Detects if FL Studio is playing.
if not var.isPerformance:
UpColorsPush()
uplights.Padlights() # Upper pads + transport lighting.
downlight.Downbutton()
UpColorsIdle() # Colors for Scene-up button
### Lower pads colors for Mixer mode!
mixerlowpads.LowerLights()
### Lower pads colors for Channel rack mode!
crlp.LowerLights()
### Step-sequencer lights
step.SeqLights()
### Playlist track mute state
#plctrl.MuteLights()
ShortLights() # Lights for shortcuts in Editor mode.
peakMonitor() # Peak meter monitor (Editor mode).
else:
perflights.setLights() # Performance mode lights.
def OnMidiMsg(event): # Functionality to integrate buttons, pads and knobs operations (CC). This data is passed to FL Studio, and it does stuff with it.
"""if event.data2:
pluginCoords = mixer.getActiveEffectIndex() # This prints the coordinates of the active effect in the mixer (tuple).
if pluginCoords:
print(plugins.getParamCount(pluginCoords[0], pluginCoords[1])) # This prints the name of the active effect in the mixer."""
#trns.TrBehavior(event.midiId, event.data1, event.data2) # Transport buttons behavior.
trns.TrBehavior(event) # Transport buttons behavior.
browse.Shift(event) # Shift button behavior.
if not var.isPerformance:
SceneUpMidi(event)
browse.Arrowkeys(event.midiId, event.data1, event.data2) # Arrow keys behavior (Shift + Arrow buttons).
pkm.KnobModes(event.midiId, event.data1, event.data2) # Knob modes (Shift + Device/Volume/Pan/Custom pads). Defines variable KNOBSTATUS and prints a hint in FL Studio.
pkm.PadModes(event.midiId, event.data1, event.data2) # Pad modes (Shift + Session/Drum/Custom pads). Defines variable PADSTATUS and prints a hint in FL Studio.
# Knob integrations for plugins.
## Generators
### Third-party plugins
for i in ("vital", "pigments3", "surge", "cardinal", "massive", "phaseplant"):
eval(i).Knobs(event.midiId, event.data1, event.data2)
### FL Studio native generator plugins
for i in ("flex",
"sytrus",
"harmor",
"midiout"):
eval(i).Knobs(event.midiId, event.data1, event.data2)
## Effects
### Third-party plugins
for i in ("pro_l2",
"khs_gain"):
eval(i).Knobs(event.midiId, event.data1, event.data2)
### FL Studio native effect plugins
for i in ("freq_shifter",
"love_philter",
"param_eq2",
"fruity_limiter",
"control_surface"):
if i in dir(fruity_fxctrl):
eval(i).Knobs(event.midiId, event.data1, event.data2)
#plctrl.MuteTracks(event.data1, event.data2) # Non-functional playlist mute tracks.
step.SeqLights()
def OnNoteOn(padhit): # Functionality to integrate pads operations (Note On). This data is passed to FL Studio, and it does stuff with it.
uplights.transportLights() # Transport lights.
if not var.isPerformance:
uplights.Padlights() # Upper pads
downlight.Downbutton()
if not var.PADSTATUS == "Drum": # If the pad mode is not "Drum", then the upper pads will provide macros and shortcuts.
upact.UpperPads(padhit.midiId, padhit.data1, padhit.data2) ### Upper pads behavior
step.Sequencer(padhit.midiId, padhit.data1, padhit.data2) ### Step-sequencer in low pads.
if padhit.midiId == midi.MIDI_NOTEON:
if "MIXER_READYFOR" in var.scmodes:
mxr = mixerlowpads.LowPads (padhit.data1, padhit.data2, var.scmodes.get("MIXER_READYFOR"))
mxr.LowerPadsControls() # Mixer mode lower pads behavior.
crlp.LowerPadsControls(padhit.data1, padhit.data2, var.scmodes.get("CHANRACK_READYFOR")) # Channel rack mode lower pads behavior.
# Pads in Drum mode.
if var.PADSTATUS == "Drum":
drumpads = drum.DrumData(padhit.data1, padhit.data2, pads.drum_pads)
drumpads.DrumLights()
Shortcuts(padhit.midiId, padhit.data1, padhit.data2) # Integrate messages to provide shortcuts in Editor mode.
padhit.handled = handlers.PadHandler(padhit.midiId, padhit.data1) # If a pad is integrated, then FL Studio will show a yellow icon.
if var.isPerformance:
perfbuttons.trigger(padhit) # Performance mode pads behavior.
def OnControlChange(scene):
if not var.isPerformance:
if not var.SHIFT_STATUS:
for x,y in cons.modes.items():
if var.SCENE_SEL == x:
x = scdown.SceneDown(scene.data1, scene.data2, y)
x.Selection()
if scene.data1 == cons.scenedown_DATA1 and scene.data2:
for x,y in cons.modes.items():
uimsg.SceneMsg(x,y)
### KNOB BEHAVIOR
if not var.SHIFT_STATUS:
if var.KNOBSTATUS != "Custom":
### Knobs behavior in Mixer mode.
if var.SCENE_SEL == "Mixer":
### Panning controls in mixer mode.
if var.KNOBSTATUS =="Pan":
mixermod = pv.PanVol(scene.data1, scene.data2, mixer.trackNumber(), mixer.trackCount(), var.SCENE_SEL, knobs.knobs)
mixermod.Pan()
### Volume controls in mixer mode.
elif var.KNOBSTATUS == "Volume":
mixermod = pv.PanVol(scene.data1, scene.data2, mixer.trackNumber(), mixer.trackCount(), var.SCENE_SEL, knobs.knobs)
mixermod.Vol()
### Knobs behavior in Channel rack mode.
elif var.SCENE_SEL=="Channel rack":
### Panning controls in Channel rack mode.
if var.KNOBSTATUS =="Pan":
channel = pv.PanVol(scene.data1, scene.data2, channels.selectedChannel(), channels.channelCount(), var.SCENE_SEL, knobs.knobs)
channel.Pan()
### Volume controls in Channel rack mode.
if var.KNOBSTATUS =="Volume":
channel = pv.PanVol(scene.data1, scene.data2, channels.selectedChannel(), channels.channelCount(), var.SCENE_SEL, knobs.knobs)
channel.Vol()
scene.handled = handlers.SceneHandler(scene.midiId, scene.data1) # If a CC is integrated, then FL Studio will show a yellow icon.
#sceneup.UpBehavior(scene.midiId, scene.data1, scene.data2) # Up button behavior.
#sceneup.UpColorsPush(scene.midiId, scene.data1) # Up button colors.
# Mixer rectangle indicator.
if var.SCENE_SEL == "Mixer":
if scene.data1 and scene.data2:
Rectangle()
if var.isPerformance:
perfbuttons.displayPos(scene)
perflights.setLights()