use of de.mossgrabers.framework.daw.data.GridStep in project DrivenByMoss by git-moss.
the class CursorClipImpl method startEdit.
/**
* {@inheritDoc}
*/
@Override
public void startEdit(final List<GridStep> editSteps) {
// Is there a previous edit, which is not stopped yet?
this.stopEdit();
this.editSteps.addAll(editSteps);
for (final GridStep step : this.editSteps) this.delayedUpdate(step);
}
use of de.mossgrabers.framework.daw.data.GridStep in project DrivenByMoss by git-moss.
the class NoteMode method updateDisplay2.
/**
* {@inheritDoc}
*/
@Override
public void updateDisplay2(final IGraphicDisplay display) {
if (this.notes.isEmpty()) {
for (int i = 0; i < 8; i++) display.addOptionElement(i == 2 ? "Please select a note to edit..." : "", "", false, "", "", false, true);
return;
}
final GridStep noteInfo = this.notes.get(0);
final int channel = noteInfo.channel();
final int step = noteInfo.step();
final int note = noteInfo.note();
final IStepInfo stepInfo = this.clip.getStep(channel, step, note);
final IValueChanger valueChanger = this.model.getValueChanger();
if (this.page != Page.RECCURRENCE_PATTERN) {
final int size = this.notes.size();
final boolean isOneNote = size == 1;
final String stepBottomMenu = isOneNote ? "Step: " + (step + 1) : "Notes: " + size;
display.addParameterElementWithPlainMenu(MENU[0], this.page == Page.NOTE, stepBottomMenu, null, false, "Length", -1, this.formatLength(stepInfo.getDuration()), this.isKnobTouched[0], -1);
final boolean hasExpressions = this.host.supports(Capability.NOTE_EDIT_EXPRESSIONS);
final String topMenu = hasExpressions ? MENU[1] : " ";
final boolean isTopMenuOn = hasExpressions && this.page == Page.EXPRESSIONS;
final String bottomMenu = isOneNote ? Scales.formatNoteAndOctave(note, -3) : "*";
if (this.host.supports(Capability.NOTE_EDIT_MUTE)) {
final int value = stepInfo.isMuted() ? valueChanger.getUpperBound() : 0;
display.addParameterElementWithPlainMenu(topMenu, isTopMenuOn, bottomMenu, null, false, "Is Muted?", value, stepInfo.isMuted() ? "Yes" : "No", this.isKnobTouched[1], value);
} else
display.addParameterElementWithPlainMenu(topMenu, isTopMenuOn, bottomMenu, null, false, null, -1, null, false, -1);
}
switch(this.page) {
case NOTE:
final double noteVelocity = stepInfo.getVelocity();
final int parameterValue = valueChanger.fromNormalizedValue(noteVelocity);
display.addParameterElementWithPlainMenu(this.host.supports(Capability.NOTE_EDIT_REPEAT) ? MENU[2] : " ", false, null, null, false, "Velocity", parameterValue, StringUtils.formatPercentage(noteVelocity), this.isKnobTouched[2], parameterValue);
if (this.host.supports(Capability.NOTE_EDIT_VELOCITY_SPREAD)) {
final double noteVelocitySpread = stepInfo.getVelocitySpread();
final int parameterSpreadValue = valueChanger.fromNormalizedValue(noteVelocitySpread);
display.addParameterElementWithPlainMenu(MENU[3], false, null, null, false, "Vel-Spread", parameterSpreadValue, StringUtils.formatPercentage(noteVelocitySpread), this.isKnobTouched[3], parameterSpreadValue);
} else
display.addEmptyElement(true);
if (this.host.supports(Capability.NOTE_EDIT_RELEASE_VELOCITY)) {
final double noteReleaseVelocity = stepInfo.getReleaseVelocity();
final int parameterReleaseValue = valueChanger.fromNormalizedValue(noteReleaseVelocity);
display.addParameterElementWithPlainMenu(MENU[4], false, null, null, false, "R-Velocity", parameterReleaseValue, StringUtils.formatPercentage(noteReleaseVelocity), this.isKnobTouched[4], parameterReleaseValue);
} else
display.addEmptyElement(true);
if (this.host.supports(Capability.NOTE_EDIT_CHANCE)) {
final double chance = stepInfo.getChance();
final int chanceValue = valueChanger.fromNormalizedValue(chance);
display.addParameterElementWithPlainMenu(MENU[5], false, stepInfo.isChanceEnabled() ? "On" : "Off", null, false, "Chance", chanceValue, StringUtils.formatPercentage(chance), this.isKnobTouched[5], chanceValue);
} else
display.addEmptyElement(true);
if (this.host.supports(Capability.NOTE_EDIT_OCCURRENCE)) {
final NoteOccurrenceType occurrence = stepInfo.getOccurrence();
display.addParameterElementWithPlainMenu(MENU[6], false, stepInfo.isOccurrenceEnabled() ? "On" : "Off", null, false, "Occurrence", -1, StringUtils.optimizeName(occurrence.getName(), 9), this.isKnobTouched[6], -1);
} else
display.addEmptyElement(true);
if (this.host.supports(Capability.NOTE_EDIT_RECCURRENCE)) {
final int recurrence = stepInfo.getRecurrenceLength();
final String recurrenceStr = recurrence < 2 ? "Off" : Integer.toString(recurrence);
final int recurrenceVal = (recurrence - 1) * (this.model.getValueChanger().getUpperBound() - 1) / 7;
display.addParameterElementWithPlainMenu(MENU[7], false, stepInfo.isRecurrenceEnabled() ? "On" : "Off", null, false, "Recurrence", recurrenceVal, recurrenceStr, this.isKnobTouched[7], recurrenceVal);
} else
display.addEmptyElement(true);
break;
case EXPRESSIONS:
display.addParameterElementWithPlainMenu(MENU[2], false, null, null, false, null, -1, null, false, -1);
final double noteGain = stepInfo.getGain();
final int parameterGainValue = Math.min(1023, valueChanger.fromNormalizedValue(noteGain));
display.addParameterElementWithPlainMenu(MENU[3], false, null, null, false, "Gain", parameterGainValue, StringUtils.formatPercentage(noteGain), this.isKnobTouched[3], parameterGainValue);
final double notePan = stepInfo.getPan();
final int parameterPanValue = valueChanger.fromNormalizedValue((notePan + 1.0) / 2.0);
display.addParameterElementWithPlainMenu(MENU[4], false, null, null, false, "Pan", parameterPanValue, StringUtils.formatPercentage(notePan), this.isKnobTouched[4], parameterPanValue);
final double noteTranspose = stepInfo.getTranspose();
final int parameterTransposeValue = valueChanger.fromNormalizedValue((noteTranspose + 24.0) / 48.0);
display.addParameterElementWithPlainMenu(MENU[5], false, null, null, false, "Pitch", parameterTransposeValue, String.format("%.1f", Double.valueOf(noteTranspose)), this.isKnobTouched[5], parameterTransposeValue);
final double noteTimbre = stepInfo.getTimbre();
final int parameterTimbreValue = valueChanger.fromNormalizedValue((noteTimbre + 1.0) / 2.0);
display.addParameterElementWithPlainMenu(MENU[6], false, null, null, false, "Timbre", parameterTimbreValue, StringUtils.formatPercentage(noteTimbre), this.isKnobTouched[6], parameterTimbreValue);
final double notePressure = stepInfo.getPressure();
final int parameterPressureValue = valueChanger.fromNormalizedValue(notePressure);
display.addParameterElementWithPlainMenu(MENU[7], this.page == Page.RECCURRENCE_PATTERN, null, null, false, "Pressure", parameterPressureValue, StringUtils.formatPercentage(notePressure), this.isKnobTouched[7], parameterPressureValue);
break;
case REPEAT:
display.addParameterElementWithPlainMenu(MENU[2], true, null, null, false, null, -1, null, false, -1);
final int repeatCount = stepInfo.getRepeatCount();
final String repeatCountValue = stepInfo.getFormattedRepeatCount();
final int rc = (repeatCount + 127) * (this.model.getValueChanger().getUpperBound() - 1) / 254;
display.addParameterElementWithPlainMenu(MENU[3], false, stepInfo.isRepeatEnabled() ? "On" : "Off", null, false, "Count", rc, repeatCountValue, this.isKnobTouched[3], rc);
final double repeatCurve = stepInfo.getRepeatCurve();
final int repeatCurveValue = valueChanger.fromNormalizedValue((repeatCurve + 1.0) / 2.0);
display.addParameterElementWithPlainMenu(MENU[4], false, null, null, false, "Curve", repeatCurveValue, StringUtils.formatPercentage(repeatCurve), this.isKnobTouched[4], repeatCurveValue);
final double repeatVelocityCurve = stepInfo.getRepeatVelocityCurve();
final int repeatVelocityCurveValue = valueChanger.fromNormalizedValue((repeatVelocityCurve + 1.0) / 2.0);
display.addParameterElementWithPlainMenu(MENU[5], false, null, null, false, "Vel. Curve", repeatVelocityCurveValue, StringUtils.formatPercentage(repeatVelocityCurve), this.isKnobTouched[5], repeatVelocityCurveValue);
final double repeatVelocityEnd = stepInfo.getRepeatVelocityEnd();
final int repeatVelocityEndValue = valueChanger.fromNormalizedValue((repeatVelocityEnd + 1.0) / 2.0);
display.addParameterElementWithPlainMenu(MENU[6], false, null, null, false, "Vel. End", repeatVelocityEndValue, StringUtils.formatPercentage(repeatVelocityEnd), this.isKnobTouched[6], repeatVelocityEndValue);
display.addParameterElementWithPlainMenu(MENU[7], false, null, null, false, null, -1, null, false, -1);
break;
case RECCURRENCE_PATTERN:
final int recurrenceLength = stepInfo.getRecurrenceLength();
final int mask = stepInfo.getRecurrenceMask();
for (int i = 0; i < 8; i++) {
final boolean isOn = (mask & 1 << i) > 0;
ColorEx color = ColorEx.BLACK;
String label = "-";
if (i < recurrenceLength) {
color = isOn ? ColorEx.ORANGE : null;
label = isOn ? "On" : "Off";
}
if (i == 7) {
final int recurrence = stepInfo.getRecurrenceLength();
final String recurrenceStr = recurrence < 2 ? "Off" : Integer.toString(recurrence);
final int recurrenceVal = (recurrence - 1) * (this.model.getValueChanger().getUpperBound() - 1) / 7;
display.addParameterElementWithPlainMenu(MENU[i], i == 7, label, color, false, "Recurrence", recurrenceVal, recurrenceStr, this.isKnobTouched[7], recurrenceVal);
} else
display.addParameterElementWithPlainMenu(MENU[i], i == 7, label, color, false, null, -1, null, false, -1);
}
break;
}
}
use of de.mossgrabers.framework.daw.data.GridStep in project DrivenByMoss by git-moss.
the class NoteMode method onButton.
/**
* {@inheritDoc}
*/
@Override
public void onButton(final int row, final int index, final ButtonEvent event) {
if (event != ButtonEvent.UP)
return;
for (final GridStep noteInfo : this.notes) {
final int channel = noteInfo.channel();
final int step = noteInfo.step();
final int note = noteInfo.note();
final IStepInfo stepInfo = this.clip.getStep(channel, step, note);
switch(this.page) {
case NOTE:
switch(index) {
case 1:
if (this.host.supports(Capability.NOTE_EDIT_EXPRESSIONS))
this.page = Page.EXPRESSIONS;
break;
case 2:
if (this.host.supports(Capability.NOTE_EDIT_REPEAT))
this.page = Page.REPEAT;
break;
case 3:
if (this.host.supports(Capability.NOTE_EDIT_RECCURRENCE))
this.page = Page.RECCURRENCE_PATTERN;
break;
case 5:
if (this.host.supports(Capability.NOTE_EDIT_CHANCE))
this.clip.updateIsChanceEnabled(channel, step, note, !stepInfo.isChanceEnabled());
break;
case 6:
if (this.host.supports(Capability.NOTE_EDIT_OCCURRENCE))
this.clip.updateIsOccurrenceEnabled(channel, step, note, !stepInfo.isOccurrenceEnabled());
break;
case 7:
if (this.host.supports(Capability.NOTE_EDIT_RECCURRENCE))
this.clip.updateIsRecurrenceEnabled(channel, step, note, !stepInfo.isRecurrenceEnabled());
break;
default:
return;
}
break;
case EXPRESSIONS:
switch(index) {
case 0:
this.page = Page.NOTE;
break;
case 2:
this.page = Page.REPEAT;
break;
case 3:
this.page = Page.RECCURRENCE_PATTERN;
break;
default:
return;
}
break;
case REPEAT:
switch(index) {
case 0:
this.page = Page.NOTE;
break;
case 1:
this.page = Page.EXPRESSIONS;
break;
case 3:
this.page = Page.RECCURRENCE_PATTERN;
break;
case 4:
if (this.host.supports(Capability.NOTE_EDIT_REPEAT))
this.clip.updateIsRepeatEnabled(channel, step, note, !stepInfo.isRepeatEnabled());
break;
default:
return;
}
break;
case RECCURRENCE_PATTERN:
switch(index) {
case 0:
this.page = Page.NOTE;
break;
case 1:
this.page = Page.EXPRESSIONS;
break;
case 2:
this.page = Page.REPEAT;
break;
case 3:
this.page = Page.RECCURRENCE_PATTERN;
break;
default:
return;
}
break;
}
}
}
use of de.mossgrabers.framework.daw.data.GridStep in project DrivenByMoss by git-moss.
the class NoteMode method handleDelete.
private void handleDelete(final int index) {
this.surface.setTriggerConsumed(ButtonID.DELETE);
for (final GridStep noteInfo : this.notes) {
final int channel = noteInfo.channel();
final int step = noteInfo.step();
final int note = noteInfo.note();
switch(this.page) {
case NOTE:
switch(index) {
case 0:
this.clip.updateStepDuration(channel, step, note, 1.0);
break;
case 1:
this.clip.updateMuteState(channel, step, note, false);
break;
case 2:
this.clip.updateStepVelocity(channel, step, note, 1.0);
break;
case 3:
if (this.host.supports(Capability.NOTE_EDIT_VELOCITY_SPREAD))
this.clip.updateVelocitySpread(channel, step, note, 0);
break;
case 4:
if (this.host.supports(Capability.NOTE_EDIT_RELEASE_VELOCITY))
this.clip.updateStepReleaseVelocity(channel, step, note, 1.0);
break;
case 5:
if (this.host.supports(Capability.NOTE_EDIT_CHANCE))
this.clip.updateChance(channel, step, note, 1.0);
break;
case 6:
if (this.host.supports(Capability.NOTE_EDIT_OCCURRENCE))
this.clip.setOccurrence(channel, step, note, NoteOccurrenceType.ALWAYS);
break;
case 7:
if (this.host.supports(Capability.NOTE_EDIT_RECCURRENCE))
this.clip.updateRecurrenceLength(channel, step, note, 1);
break;
default:
return;
}
break;
case EXPRESSIONS:
switch(index) {
case 0:
this.clip.updateStepDuration(channel, step, note, 1.0);
break;
case 1:
this.clip.updateMuteState(channel, step, note, false);
break;
case 3:
if (this.host.supports(Capability.NOTE_EDIT_EXPRESSIONS))
this.clip.updateStepGain(channel, step, note, 0.5);
break;
case 4:
if (this.host.supports(Capability.NOTE_EDIT_EXPRESSIONS))
this.clip.updateStepPan(channel, step, note, 0);
break;
case 5:
if (this.host.supports(Capability.NOTE_EDIT_EXPRESSIONS))
this.clip.updateStepTranspose(channel, step, note, 0);
break;
case 6:
if (this.host.supports(Capability.NOTE_EDIT_EXPRESSIONS))
this.clip.updateStepTimbre(channel, step, note, 0);
break;
case 7:
if (this.host.supports(Capability.NOTE_EDIT_EXPRESSIONS))
this.clip.updateStepPressure(channel, step, note, 0);
break;
default:
return;
}
break;
case REPEAT:
switch(index) {
case 0:
this.clip.updateStepDuration(channel, step, note, 1.0);
break;
case 1:
this.clip.updateMuteState(channel, step, note, false);
break;
case 4:
if (this.host.supports(Capability.NOTE_EDIT_REPEAT))
this.clip.updateRepeatCount(channel, step, note, 0);
break;
case 5:
if (this.host.supports(Capability.NOTE_EDIT_REPEAT))
this.clip.updateRepeatCurve(channel, step, note, 0);
break;
case 6:
if (this.host.supports(Capability.NOTE_EDIT_REPEAT))
this.clip.updateRepeatVelocityCurve(channel, step, note, 0);
break;
case 7:
if (this.host.supports(Capability.NOTE_EDIT_REPEAT))
this.clip.updateRepeatVelocityEnd(channel, step, note, 0);
break;
default:
return;
}
break;
case RECCURRENCE_PATTERN:
if (index == 7 && this.host.supports(Capability.NOTE_EDIT_RECCURRENCE))
this.clip.updateRecurrenceLength(channel, step, note, 1);
break;
default:
return;
}
}
}
use of de.mossgrabers.framework.daw.data.GridStep in project DrivenByMoss by git-moss.
the class NoteMode method getKnobValue.
/**
* {@inheritDoc}
*/
@Override
public int getKnobValue(final int index) {
if (this.notes.isEmpty())
return 0;
final IValueChanger valueChanger = this.model.getValueChanger();
final GridStep noteInfo = this.notes.get(0);
final int channel = noteInfo.channel();
final int step = noteInfo.step();
final int note = noteInfo.note();
final IStepInfo stepInfo = this.clip.getStep(channel, step, note);
switch(this.page) {
case NOTE:
switch(index) {
case 2:
return valueChanger.fromNormalizedValue(stepInfo.getVelocity());
case 3:
if (this.host.supports(Capability.NOTE_EDIT_VELOCITY_SPREAD))
return valueChanger.fromNormalizedValue(stepInfo.getVelocitySpread());
break;
case 4:
if (this.host.supports(Capability.NOTE_EDIT_RELEASE_VELOCITY))
return valueChanger.fromNormalizedValue(stepInfo.getReleaseVelocity());
break;
case 5:
if (this.host.supports(Capability.NOTE_EDIT_CHANCE))
return valueChanger.fromNormalizedValue(stepInfo.getChance());
break;
case 6:
if (this.host.supports(Capability.NOTE_EDIT_OCCURRENCE))
return 0;
break;
case 7:
if (this.host.supports(Capability.NOTE_EDIT_RECCURRENCE))
return (stepInfo.getRecurrenceLength() - 1) * (this.model.getValueChanger().getUpperBound() - 1) / 7;
break;
default:
return 0;
}
break;
case EXPRESSIONS:
switch(index) {
case 3:
if (this.host.supports(Capability.NOTE_EDIT_EXPRESSIONS))
return Math.min(valueChanger.getUpperBound() - 1, valueChanger.fromNormalizedValue(stepInfo.getGain()));
break;
case 4:
if (this.host.supports(Capability.NOTE_EDIT_EXPRESSIONS))
return valueChanger.fromNormalizedValue((stepInfo.getPan() + 1.0) / 2.0);
break;
case 5:
if (this.host.supports(Capability.NOTE_EDIT_EXPRESSIONS))
return valueChanger.fromNormalizedValue((stepInfo.getTranspose() + 24.0) / 48.0);
break;
case 6:
if (this.host.supports(Capability.NOTE_EDIT_EXPRESSIONS))
return valueChanger.fromNormalizedValue((stepInfo.getTimbre() + 1.0) / 2.0);
break;
case 7:
if (this.host.supports(Capability.NOTE_EDIT_EXPRESSIONS))
return valueChanger.fromNormalizedValue(stepInfo.getPressure());
break;
default:
break;
}
break;
case REPEAT:
switch(index) {
case 4:
if (this.host.supports(Capability.NOTE_EDIT_REPEAT))
return (stepInfo.getRepeatCount() + 127) * (this.model.getValueChanger().getUpperBound() - 1) / 254;
break;
case 5:
if (this.host.supports(Capability.NOTE_EDIT_REPEAT))
return valueChanger.fromNormalizedValue((stepInfo.getRepeatCurve() + 1.0) / 2.0);
break;
case 6:
if (this.host.supports(Capability.NOTE_EDIT_REPEAT))
return valueChanger.fromNormalizedValue((stepInfo.getRepeatVelocityCurve() + 1.0) / 2.0);
break;
case 7:
if (this.host.supports(Capability.NOTE_EDIT_REPEAT))
return valueChanger.fromNormalizedValue((stepInfo.getRepeatVelocityEnd() + 1.0) / 2.0);
break;
default:
break;
}
break;
case RECCURRENCE_PATTERN:
// None
break;
}
return 0;
}
Aggregations