Skip to content

Commit

Permalink
Issue #411, add radio buttons to change the indexing of the top row o…
Browse files Browse the repository at this point in the history
…f the interval matrix in Analysis view.
  • Loading branch information
inthar-raven committed Nov 29, 2023
1 parent 6589dcb commit 44c2479
Show file tree
Hide file tree
Showing 3 changed files with 46 additions and 5 deletions.
12 changes: 11 additions & 1 deletion src/App.vue
Original file line number Diff line number Diff line change
Expand Up @@ -120,6 +120,7 @@ const centsFractionDigits = ref(3);
const decimalFractionDigits = ref(5);
const showVirtualQwerty = ref(false);
const midiOctaveOffset = ref(-1);
const intervalMatrixIndexing = ref(0);
// Special keyboard codes also from local storage.
const deactivationCode = ref("Backquote");
Expand Down Expand Up @@ -783,7 +784,11 @@ onMounted(() => {
if ("midiOctaveOffset" in storage) {
midiOctaveOffset.value = parseInt(storage.getItem("midiOctaveOffset")!);
}
if ("intervalMatrixIndexing" in storage) {
intervalMatrixIndexing.value = parseInt(
storage.getItem("intervalMatrixIndexing")!
);
}
// Fetch special key map
if ("deactivationCode" in storage) {
deactivationCode.value = storage.getItem("deactivationCode")!;
Expand Down Expand Up @@ -968,6 +973,9 @@ watch(showVirtualQwerty, (newValue) =>
watch(midiOctaveOffset, (newValue) =>
window.localStorage.setItem("midiOctaveOffset", newValue.toString())
);
watch(intervalMatrixIndexing, (newValue) =>
window.localStorage.setItem("intervalMatrixIndexing", newValue.toString())
);
// Store keymaps
watch(deactivationCode, (newValue) =>
window.localStorage.setItem("deactivationCode", newValue)
Expand Down Expand Up @@ -1069,6 +1077,7 @@ watch(degreeDownCode, (newValue) =>
:keyboardMapping="keyboardMapping"
:showVirtualQwerty="showVirtualQwerty"
:midiOctaveOffset="midiOctaveOffset"
:intervalMatrixIndexing="intervalMatrixIndexing"
@update:audioDelay="audioDelay = $event"
@update:mainVolume="mainVolume = $event"
@update:scaleName="scaleName = $event"
Expand All @@ -1095,6 +1104,7 @@ watch(degreeDownCode, (newValue) =>
@update:decimalFractionDigits="decimalFractionDigits = $event"
@update:showVirtualQwerty="showVirtualQwerty = $event"
@update:midiOctaveOffset="midiOctaveOffset = $event"
@update:intervalMatrixIndexing="intervalMatrixIndexing = $event"
@update:deactivationCode="deactivationCode = $event"
@update:equaveUpCode="equaveUpCode = $event"
@update:equaveDownCode="equaveDownCode = $event"
Expand Down
4 changes: 2 additions & 2 deletions src/analysis.ts
Original file line number Diff line number Diff line change
Expand Up @@ -105,10 +105,10 @@ export function utonalFundamental(frequencies: number[], maxDivisor = 23) {
// Interval matrix a.k.a the modes of a scale
export function intervalMatrix(scale: Scale) {
const result = [];
const degrees = [...Array(scale.size + 1).keys()];
const columns = [...Array(scale.size + 1).keys()];
for (let i = 0; i < scale.size; ++i) {
const mode = scale.rotate(i);
result.push(degrees.map((j) => mode.getInterval(j)));
result.push(columns.map((j) => mode.getInterval(j)));
}
return result;
}
35 changes: 33 additions & 2 deletions src/views/AnalysisView.vue
Original file line number Diff line number Diff line change
Expand Up @@ -16,8 +16,17 @@ const props = defineProps<{
scale: Scale;
virtualSynth: VirtualSynth;
colorScheme: "light" | "dark";
intervalMatrixIndexing: number;
}>();
const emit = defineEmits(["update:intervalMatrixIndexing"]);
const intervalMatrixIndexing = computed({
get: () => props.intervalMatrixIndexing,
set: (newValue: string) =>
emit("update:intervalMatrixIndexing", parseInt(newValue, 10)),
});
const cellFormat = ref<"best" | "cents" | "decimal">("best");
const trailLongevity = ref(70);
const maxOtonalRoot = ref(16);
Expand Down Expand Up @@ -100,9 +109,9 @@ const matrix = computed(() => {
<tr>
<th></th>
<th v-for="i of Math.min(scale.size, MAX_SCALE_SIZE)" :key="i">
{{ i }}
{{ i - 1 + intervalMatrixIndexing }}
</th>
<th>({{ scale.size + 1 }})</th>
<th>({{ scale.size + intervalMatrixIndexing }})</th>
</tr>
<tr v-for="(row, i) of matrix" :key="i">
<th>{{ formatMatrixCell(scale.getInterval(i)) }}</th>
Expand Down Expand Up @@ -143,6 +152,28 @@ const matrix = computed(() => {
<label for="format-decimal"> Decimal ratio </label>
</span>
</div>
<div class="control radio-group">
<label>Interval indexing</label>
<span>
<input
type="radio"
id="indexing-zero"
value="0"
v-model="intervalMatrixIndexing"
/>
<label for="indexing-zero"> 0-indexing (default) </label>
</span>

<span>
<input
type="radio"
id="indexing-one"
value="1"
v-model="intervalMatrixIndexing"
/>
<label for="indexing-one"> 1-indexing </label>
</span>
</div>
</div>
<div class="columns-container">
<div class="column">
Expand Down

0 comments on commit 44c2479

Please sign in to comment.