-
Notifications
You must be signed in to change notification settings - Fork 139
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Transpose function #16
Comments
Yes. Transpose is just a special version of Bank, so it's probably better to use Transposer for notes, and Bank for everything else.
I don't really understand your question, but all elements have |
Bank should work for what I want to do
I will do some testing
Thanks again
Get Outlook for Android<https://aka.ms/ghei36>
…________________________________
From: tttapa <notifications@github.com>
Sent: Wednesday, February 20, 2019 9:28:38 PM
To: tttapa/Control-Surface
Cc: masydoblig; Author
Subject: Re: [tttapa/Control-Surface] Transpose function (#16)
Does the transpose function work on rotary encoder addresses?
Yes. Transpose is just a special version of Bank, so it's probably better to use Transposer for notes, and Bank for everything else.
This way i can activate/deactivate the encoder button top and adjust the lh or rh panning function in a dual pan setup?
I don't really understand you question, but all elements have enable and disable methods.
—
You are receiving this because you authored the thread.
Reply to this email directly, view it on GitHub<#16 (comment)>, or mute the thread<https://github.com/notifications/unsubscribe-auth/Alaaoa-Up7BcxxLzj--9oB2Pw2Wr57-Yks5vPSNWgaJpZM4bEoP6>.
|
Hi Pete i am trying to give the mackie control a try, but i cannot get the fader to work it is outputting the cc change on channel 1 address 7 but when it is mapped as a mackie control i get no fader movement in cubase can you check my code below to make sure it is correct with the current release, i have no idea what is going on #include <Encoder.h> // Instantiate a MIDI over USB interface. // Create a new instance of the class CCRotaryEncoder enc = { void setup() { void loop() { |
i know it seems stupid |
Fader movement in MCU uses Pitch Bend events, so you need a |
That was driving me nuts
Thanks dude
Get Outlook for Android<https://aka.ms/ghei36>
…________________________________
From: tttapa <notifications@github.com>
Sent: Thursday, February 21, 2019 9:56:48 PM
To: tttapa/Control-Surface
Cc: masydoblig; Author
Subject: Re: [tttapa/Control-Surface] Transpose function (#16)
Fader movement in MCU uses Pitch Bend events, so you need a PBPotentiometer.
—
You are receiving this because you authored the thread.
Reply to this email directly, view it on GitHub<#16 (comment)>, or mute the thread<https://github.com/notifications/unsubscribe-auth/AlaaocroNo78SDYTu04JIgR0lJsPujHPks5vPntwgaJpZM4bEoP6>.
|
Hi Peter Just trying to get a bankable LEDs shift register working Bank<2> bank(1); // Create a new bank with 1 tracks per bank
IncrementDecrementSelector<2> bankselector(bank, {8, 9});
ShiftRegisterOut<8> sr2(dataPin2, clockPin2, latchPin2, MSBFIRST);
Bankable::MIDINoteLED leds[] = {
bank,
{{
{sr2.pin(0), note(E, 2)}, CHANNEL_1}},
{sr2.pin(1), {note(F, 2), CHANNEL_1}},
{sr2.pin(2), {note(Gb, 2), CHANNEL_1}},
{sr2.pin(3), {note(G, 2), CHANNEL_1}},
{sr2.pin(4), {note(Ab, 2), CHANNEL_1}},
{sr2.pin(5), {note(A, 2), CHANNEL_1}},
{sr2.pin(6), {note(Bb, 2), CHANNEL_1}},
{sr2.pin(7), {note(B, 2), CHANNEL_1}},
}},
}; |
Update to ee43f15 and try this: #include <Control_Surface.h>
USBMIDI_Interface midi;
Bank<2> bank(1); // Create a new bank with 1 tracks per bank
IncrementDecrementSelector<2> bankselector(bank, {8, 9});
// There's no need to use different clock and data pins for each shift register,
// Either daisy chain them (i.e. use one 16-bit instance instead of two 8-bit instances)
// or share the data and clock pins, using just a different latch pin for each register.
// Daisy chaining them is preferred, see https://tttapa.github.io/Control-Surface/Doc/Doxygen/d3/d82/Ex_81_8Shift-Register-LED-Effects_8ino-example.html
// It's also much more efficient and faster if you use the SPI bus for the shift
// registers (8 MHz), and it also saves some pins.
SPIShiftRegisterOut<8> sr2(SS, MSBFIRST);
using namespace MIDI_Notes;
Bankable::MIDINoteLED<2> leds[] = {
{{bank, BankType::CHANGE_CHANNEL}, sr2.pin(0), {note(E, 2), CHANNEL_1}},
{{bank, BankType::CHANGE_CHANNEL}, sr2.pin(1), {note(F, 2), CHANNEL_1}},
{{bank, BankType::CHANGE_CHANNEL}, sr2.pin(2), {note(Gb, 2), CHANNEL_1}},
{{bank, BankType::CHANGE_CHANNEL}, sr2.pin(3), {note(G, 2), CHANNEL_1}},
{{bank, BankType::CHANGE_CHANNEL}, sr2.pin(4), {note(Ab, 2), CHANNEL_1}},
{{bank, BankType::CHANGE_CHANNEL}, sr2.pin(5), {note(A, 2), CHANNEL_1}},
{{bank, BankType::CHANGE_CHANNEL}, sr2.pin(6), {note(Bb, 2), CHANNEL_1}},
{{bank, BankType::CHANGE_CHANNEL}, sr2.pin(7), {note(B, 2), CHANNEL_1}},
};
void setup() {
Control_Surface.begin();
}
void loop() {
Control_Surface.loop();
} |
Hi Pete Yep it works really well I saw somewhere a bank indicator led function (to let you know which bank it is on) Nice work dude, yet again you are the man code i have loaded at the moment below: #include <Encoder.h>
#include <Control_Surface.h>
// Instantiate a MIDI over USB interface.
USBMIDI_Interface midi;
const pin_t dataPin2 = 23; // Pin connected to DS of 74HC595 yellow wire
const pin_t clockPin2 = 25; // Pin connected to SH_CP of 74HC595 green wire
const pin_t latchPin2 = 27; // Pin connected to ST_CP of 74HC595 blue wire
// Create a new shift register output connected to pins 12, 13 and 10,
// shift the data out with the most significant bit first.
// There are 8 outputs in total.
SPIShiftRegisterOut<12> sr(SS, MSBFIRST);
ShiftRegisterOut<8> sr2(dataPin2, clockPin2, latchPin2, MSBFIRST);
uint8_t track = 1;
Channel channel = CHANNEL_1;
// Note: a VU meter of 12 LEDs will give the best effect, because
// in the MCU protocol, there are 12 values
// from cubase needs to be set as aftertouch on correct channel and set max value to 12 or 24
MCU::VULEDs<12> vu = {
{track, channel},
{{
sr.pin(0),
sr.pin(1),
sr.pin(2),
sr.pin(3),
sr.pin(4),
sr.pin(5),
sr.pin(6),
sr.pin(7),
sr.pin(8),
sr.pin(9),
sr.pin(10),
sr.pin(11),
}},
MCU::VU::NO_DECAY, // decay time in milliseconds or MCU::VU::NO_DECAY
};
CCPotentiometer potentiometer(A0, {0x07, CHANNEL_1}); // working
Bank<2> bank(16); // Create a new bank with 16 tracks per bank
IncrementDecrementSelector<2> bankselector(bank, {8, 9}); // does loop back to original setting from one button
Bankable::CCRotaryEncoder encoder_B = {bank, {2, 3}, 0x0A, 2, 4}; // bank 1 is normal panner, bank 2 is stereo combine panner rh.
using namespace MIDI_Notes;
Bankable::NoteButtonMatrix<4, 4> keypad = {
bank,
{22, 24, 26, 28},
{30, 32, 34, 36}, // Column pins (input-pullup)
// All notes
{{
{
note(C, -1), // MUTE BUTTON
note(Db, -1), // SOLO BUTTON
note(D, -1), //
note(Eb, -1),
},
{
note(E, -1), // READ BUTTON
note(F, -1), // WRITE BUTTON
note(Gb, -1),
note(G, -1),
},
{
note(Ab, -1), // MONITOR BUTTON
note(A, -1), // RECORD BUTTON
note(Bb, -1),
note(B, -1),
},
{
note(C, 0), //INSERT BYPASS
note(Db, 0), //SENDS BYPASS
note(D, 0),
note(D, 0),
},
}},
};
Bankable::MIDINoteLED<2> leds[] = {
{{bank, BankType::CHANGE_ADDRESS}, sr2.pin(0), {note(E, 2), CHANNEL_1}}, // RECORD LED
{{bank, BankType::CHANGE_ADDRESS}, sr2.pin(1), {note(F, 2), CHANNEL_1}}, // WRITE LED
{{bank, BankType::CHANGE_ADDRESS}, sr2.pin(2), {note(Gb, 2), CHANNEL_1}}, // SOLO LED
{{bank, BankType::CHANGE_ADDRESS}, sr2.pin(3), {note(G, 2), CHANNEL_1}}, // MUTE LED
{{bank, BankType::CHANGE_ADDRESS}, sr2.pin(4), {note(Ab, 2), CHANNEL_1}}, // READ LED
{{bank, BankType::CHANGE_ADDRESS}, sr2.pin(5), {note(A, 2), CHANNEL_1}}, // MONITOR LED
{{bank, BankType::CHANGE_ADDRESS}, sr2.pin(6), {note(Bb, 2), CHANNEL_1}}, // INSERT BYPASS LED
{{bank, BankType::CHANGE_ADDRESS}, sr2.pin(7), {note(B, 2), CHANNEL_1}}, // SEND BYPASS LED
};
void setup() {
// Initialize everything
Control_Surface.begin();
}
void loop() {
// Update the Control Surface (check whether the potentiometer's
// input has changed since last time, if so, send the new value over MIDI).
Control_Surface.loop();
} |
You can use |
Ah that was it cheers mate I will add it to the code
It will show me which fader modules are in the stereo combined panner mode
Thanks again you are a champion
Get Outlook for Android<https://aka.ms/ghei36>
…________________________________
From: tttapa <notifications@github.com>
Sent: Sunday, February 24, 2019 8:59:39 PM
To: tttapa/Control-Surface
Cc: masydoblig; Author
Subject: Re: [tttapa/Control-Surface] Transpose function (#16)
I saw somewhere a bank indicator led function (to let you know which bank it is on)
but i cant seem to find it in the docs
if you could point me in the right direction that would be much appreciated
You can use IncrementSelectorLEDs<https://tttapa.github.io/Control-Surface/Doc/Doxygen/dc/df8/classIncrementSelectorLEDs.html>. (There's IncrementDecrementSelectorLEDs as well, but it's not really useful if you only have 2 banks.)
—
You are receiving this because you authored the thread.
Reply to this email directly, view it on GitHub<#16 (comment)>, or mute the thread<https://github.com/notifications/unsubscribe-auth/AlaaoVIUgyhkK3oum4I54-ZzZBdyYgXHks5vQmKLgaJpZM4bEoP6>.
|
I noticed that the transposer example, lets only the user choose the +or- semitones limit , but the sketch coud also have the "steps" variable, in it, in the case he wants to transpose a whole octave at each +or- transposer button press. |
Hi Pete
Does the transpose function work on rotary encoder addresses?
To change the panning from the address i set to another address
This way i can activate/deactivate the encoder button top and adjust the lh or rh panning function in a dual pan setup?
Cheers
The text was updated successfully, but these errors were encountered: