Skip to content
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

(re-)use MuseScore's translations in notenames plugin #2339

Merged
merged 1 commit into from
Jan 11, 2016
Merged
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
263 changes: 132 additions & 131 deletions share/plugins/notenames.qml
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@
// Note Names Plugin
//
// Copyright (C) 2012 Werner Schweer
// Copyright (C) 2013, 2014 Joachim Schmitz
// Copyright (C) 2013 - 2016 Joachim Schmitz
// Copyright (C) 2014 Jörn Eichler
//
// This program is free software; you can redistribute it and/or modify
Expand All @@ -19,55 +19,55 @@ import MuseScore 1.0

MuseScore {
version: "2.0"
description: qsTr("This plugin names notes")
description: qsTr("This plugin names notes as per your language setting")
menuPath: "Plugins.Notes." + qsTr("Note Names") // this does not work, why?

function nameChord (notes, text) {
for (var i = 0; i < notes.length; i++) {
var sep = ","; // change to "\n" if you want them vertically
if ( i > 0 )
text.text = sep + text.text;
text.text = sep + text.text; // any but top note

if (typeof notes[i].tpc === "undefined") // just in case
if (typeof notes[i].tpc === "undefined") // like for grace notes ?!?
return
switch (notes[i].tpc) {
case -1: text.text = qsTr("Fbb") + text.text; break;
case 0: text.text = qsTr("Cbb") + text.text; break;
case 1: text.text = qsTr("Gbb") + text.text; break;
case 2: text.text = qsTr("Dbb") + text.text; break;
case 3: text.text = qsTr("Abb") + text.text; break;
case 4: text.text = qsTr("Ebb") + text.text; break;
case 5: text.text = qsTr("Bbb") + text.text; break;
case 6: text.text = qsTr("Fb") + text.text; break;
case 7: text.text = qsTr("Cb") + text.text; break;

case 8: text.text = qsTr("Gb") + text.text; break;
case 9: text.text = qsTr("Db") + text.text; break;
case 10: text.text = qsTr("Ab") + text.text; break;
case 11: text.text = qsTr("Eb") + text.text; break;
case 12: text.text = qsTr("Bb") + text.text; break;
case 13: text.text = qsTr("F") + text.text; break;
case 14: text.text = qsTr("C") + text.text; break;
case 15: text.text = qsTr("G") + text.text; break;
case 16: text.text = qsTr("D") + text.text; break;
case 17: text.text = qsTr("A") + text.text; break;
case 18: text.text = qsTr("E") + text.text; break;
case 19: text.text = qsTr("B") + text.text; break;

case 20: text.text = qsTr("F#") + text.text; break;
case 21: text.text = qsTr("C#") + text.text; break;
case 22: text.text = qsTr("G#") + text.text; break;
case 23: text.text = qsTr("D#") + text.text; break;
case 24: text.text = qsTr("A#") + text.text; break;
case 25: text.text = qsTr("E#") + text.text; break;
case 26: text.text = qsTr("B#") + text.text; break;
case 27: text.text = qsTr("F##") + text.text; break;
case 28: text.text = qsTr("C##") + text.text; break;
case 29: text.text = qsTr("G##") + text.text; break;
case 30: text.text = qsTr("D##") + text.text; break;
case 31: text.text = qsTr("A##") + text.text; break;
case 32: text.text = qsTr("E##") + text.text; break;
case 33: text.text = qsTr("B##") + text.text; break;
case -1: text.text = qsTranslate("InspectorAmbitus", "F♭♭") + text.text; break;
case 0: text.text = qsTranslate("InspectorAmbitus", "C♭♭") + text.text; break;
case 1: text.text = qsTranslate("InspectorAmbitus", "G♭♭") + text.text; break;
case 2: text.text = qsTranslate("InspectorAmbitus", "D♭♭") + text.text; break;
case 3: text.text = qsTranslate("InspectorAmbitus", "A♭♭") + text.text; break;
case 4: text.text = qsTranslate("InspectorAmbitus", "E♭♭") + text.text; break;
case 5: text.text = qsTranslate("InspectorAmbitus", "B♭♭") + text.text; break;
case 6: text.text = qsTranslate("InspectorAmbitus", "F♭") + text.text; break;
case 7: text.text = qsTranslate("InspectorAmbitus", "C♭") + text.text; break;

case 8: text.text = qsTranslate("InspectorAmbitus", "G♭") + text.text; break;
case 9: text.text = qsTranslate("InspectorAmbitus", "D♭") + text.text; break;
case 10: text.text = qsTranslate("InspectorAmbitus", "A♭") + text.text; break;
case 11: text.text = qsTranslate("InspectorAmbitus", "E♭") + text.text; break;
case 12: text.text = qsTranslate("InspectorAmbitus", "B♭") + text.text; break;
case 13: text.text = qsTranslate("InspectorAmbitus", "F") + text.text; break;
case 14: text.text = qsTranslate("InspectorAmbitus", "C") + text.text; break;
case 15: text.text = qsTranslate("InspectorAmbitus", "G") + text.text; break;
case 16: text.text = qsTranslate("InspectorAmbitus", "D") + text.text; break;
case 17: text.text = qsTranslate("InspectorAmbitus", "A") + text.text; break;
case 18: text.text = qsTranslate("InspectorAmbitus", "E") + text.text; break;
case 19: text.text = qsTranslate("InspectorAmbitus", "B") + text.text; break;

case 20: text.text = qsTranslate("InspectorAmbitus", "F♯") + text.text; break;
case 21: text.text = qsTranslate("InspectorAmbitus", "C♯") + text.text; break;
case 22: text.text = qsTranslate("InspectorAmbitus", "G♯") + text.text; break;
case 23: text.text = qsTranslate("InspectorAmbitus", "D♯") + text.text; break;
case 24: text.text = qsTranslate("InspectorAmbitus", "A♯") + text.text; break;
case 25: text.text = qsTranslate("InspectorAmbitus", "E♯") + text.text; break;
case 26: text.text = qsTranslate("InspectorAmbitus", "B♯") + text.text; break;
case 27: text.text = qsTranslate("InspectorAmbitus", "F♯♯") + text.text; break;
case 28: text.text = qsTranslate("InspectorAmbitus", "C♯♯") + text.text; break;
case 29: text.text = qsTranslate("InspectorAmbitus", "G♯♯") + text.text; break;
case 30: text.text = qsTranslate("InspectorAmbitus", "D♯♯") + text.text; break;
case 31: text.text = qsTranslate("InspectorAmbitus", "A♯♯") + text.text; break;
case 32: text.text = qsTranslate("InspectorAmbitus", "E♯♯") + text.text; break;
case 33: text.text = qsTranslate("InspectorAmbitus", "B♯♯") + text.text; break;
default: text.text = qsTr("?") + text.text; break;
} // end switch tpc

Expand All @@ -82,32 +82,32 @@ MuseScore {
if (false) {
switch (notes[i].userAccidental) {
case 0: break;
case 1: text.text = qsTr("#") + text.text; break;
case 2: text.text = qsTr("b") + text.text; break;
case 3: text.text = qsTr("##") + text.text; break;
case 4: text.text = qsTr("bb") + text.text; break;
case 5: text.text = qsTr("natural") + text.text; break;
case 6: text.text = qsTr("flat-slash") + text.text; break;
case 7: text.text = qsTr("flat-slash2") + text.text; break;
case 8: text.text = qsTr("mirrored-flat2") + text.text; break;
case 9: text.text = qsTr("mirrored-flat") + text.text; break;
case 10: text.text = qsTr("mirrored-flat-slash") + text.text; break;
case 11: text.text = qsTr("flat-flat-slash") + text.text; break;
case 12: text.text = qsTr("sharp-slash") + text.text; break;
case 13: text.text = qsTr("sharp-slash2") + text.text; break;
case 14: text.text = qsTr("sharp-slash3") + text.text; break;
case 15: text.text = qsTr("sharp-slash4") + text.text; break;
case 16: text.text = qsTr("sharp arrow up") + text.text; break;
case 17: text.text = qsTr("sharp arrow down") + text.text; break;
case 18: text.text = qsTr("sharp arrow both") + text.text; break;
case 19: text.text = qsTr("flat arrow up") + text.text; break;
case 20: text.text = qsTr("flat arrow down") + text.text; break;
case 21: text.text = qsTr("flat arrow both") + text.text; break;
case 22: text.text = qsTr("natural arrow down") + text.text; break;
case 23: text.text = qsTr("natural arrow up") + text.text; break;
case 24: text.text = qsTr("natural arrow both") + text.text; break;
case 25: text.text = qsTr("sori") + text.text; break;
case 26: text.text = qsTr("koron") + text.text; break;
case 1: text.text = qsTranslate("accidental", "Sharp") + text.text; break;
case 2: text.text = qsTranslate("accidental", "Flat") + text.text; break;
case 3: text.text = qsTranslate("accidental", "Double sharp") + text.text; break;
case 4: text.text = qsTranslate("accidental", "Double flat") + text.text; break;
case 5: text.text = qsTranslate("accidental", "Natural") + text.text; break;
case 6: text.text = qsTranslate("accidental", "Flat-slash") + text.text; break;
case 7: text.text = qsTranslate("accidental", "Flat-slash2") + text.text; break;
case 8: text.text = qsTranslate("accidental", "Mirrored-flat2") + text.text; break;
case 9: text.text = qsTranslate("accidental", "Mirrored-flat") + text.text; break;
case 10: text.text = qsTranslate("accidental", "Mirrored-flat-slash") + text.text; break;
case 11: text.text = qsTranslate("accidental", "Flat-flat-slash") + text.text; break;
case 12: text.text = qsTranslate("accidental", "Sharp-slash") + text.text; break;
case 13: text.text = qsTranslate("accidental", "Sharp-slash2") + text.text; break;
case 14: text.text = qsTranslate("accidental", "Sharp-slash3") + text.text; break;
case 15: text.text = qsTranslate("accidental", "Sharp-slash4") + text.text; break;
case 16: text.text = qsTranslate("accidental", "Sharp arrow up") + text.text; break;
case 17: text.text = qsTranslate("accidental", "Sharp arrow down") + text.text; break;
case 18: text.text = qsTranslate("accidental", "Sharp arrow both") + text.text; break;
case 19: text.text = qsTranslate("accidental", "Flat arrow up") + text.text; break;
case 20: text.text = qsTranslate("accidental", "Flat arrow down") + text.text; break;
case 21: text.text = qsTranslate("accidental", "Flat arrow both") + text.text; break;
case 22: text.text = qsTranslate("accidental", "Natural arrow down") + text.text; break;
case 23: text.text = qsTranslate("accidental", "Natural arrow up") + text.text; break;
case 24: text.text = qsTranslate("accidental", "Natural arrow both") + text.text; break;
case 25: text.text = qsTranslate("accidental", "Sori") + text.text; break;
case 26: text.text = qsTranslate("accidental", "Koron") + text.text; break;
default: text.text = qsTr("?") + text.text; break;
} // end switch userAccidental
} // end if courtesy- and microtonal accidentals
Expand All @@ -116,82 +116,83 @@ MuseScore {

onRun: {
if (typeof curScore === 'undefined')
Qt.quit();
Qt.quit();

var cursor = curScore.newCursor();
var startStaff;
var endStaff;
var endTick;
var fullScore = false;
cursor.rewind(1);
if (!cursor.segment) { // no selection
fullScore = true;
startStaff = 0; // start with 1st staff
endStaff = curScore.nstaves - 1; // and end with last
fullScore = true;
startStaff = 0; // start with 1st staff
endStaff = curScore.nstaves - 1; // and end with last
} else {
startStaff = cursor.staffIdx;
cursor.rewind(2);
if (cursor.tick == 0) {
// this happens when the selection includes
// the last measure of the score.
// rewind(2) goes behind the last segment (where
// there's none) and sets tick=0
endTick = curScore.lastSegment.tick + 1;
} else {
endTick = cursor.tick;
}
endStaff = cursor.staffIdx;
startStaff = cursor.staffIdx;
cursor.rewind(2);
if (cursor.tick == 0) {
// this happens when the selection includes
// the last measure of the score.
// rewind(2) goes behind the last segment (where
// there's none) and sets tick=0
endTick = curScore.lastSegment.tick + 1;
} else {
endTick = cursor.tick;
}
endStaff = cursor.staffIdx;
}
console.log(startStaff + " - " + endStaff + " - " + endTick)

for (var staff = startStaff; staff <= endStaff; staff++) {
for (var voice = 0; voice < 4; voice++) {
cursor.rewind(1); // beginning of selection
cursor.voice = voice;
cursor.staffIdx = staff;

if (fullScore) // no selection
cursor.rewind(0); // beginning of score

while (cursor.segment && (fullScore || cursor.tick < endTick)) {
if (cursor.element && cursor.element.type == Element.CHORD) {
var text = newElement(Element.STAFF_TEXT);

var graceChords = cursor.element.graceNotes;
for (var i = 0; i < graceChords.length; i++) {
// iterate through all grace chords
var notes = graceChords[i].notes;
nameChord(notes, text);
// there seems to be no way of knowing the exact horizontal pos.
// of a grace note, so we have to guess:
text.pos.x = -2.5 * (graceChords.length - i);
switch (voice) {
case 0: text.pos.y = 1; break;
case 1: text.pos.y = 10; break;
case 2: text.pos.y = -1; break;
case 3: text.pos.y = 12; break;
}

cursor.add(text);
// new text for next element
text = newElement(Element.STAFF_TEXT);
}

var notes = cursor.element.notes;
nameChord(notes, text);

switch (voice) {
case 0: text.pos.y = 1; break;
case 1: text.pos.y = 10; break;
case 2: text.pos.y = -1; break;
case 3: text.pos.y = 12; break;
}
if ((voice == 0) && (notes[0].pitch > 83))
text.pos.x = 1;
cursor.add(text);
} // end if CHORD
cursor.next();
} // end while segment
} // end for voice
for (var voice = 0; voice < 4; voice++) {
cursor.rewind(1); // beginning of selection
cursor.voice = voice;
cursor.staffIdx = staff;

if (fullScore) // no selection
cursor.rewind(0); // beginning of score

while (cursor.segment && (fullScore || cursor.tick < endTick)) {
if (cursor.element && cursor.element.type == Element.CHORD) {
var text = newElement(Element.STAFF_TEXT);

var graceChords = cursor.element.graceNotes;
for (var i = 0; i < graceChords.length; i++) {
// iterate through all grace chords
var notes = graceChords[i].notes;
nameChord(notes, text);
// there seems to be no way of knowing the exact horizontal pos.
// of a grace note, so we have to guess:
text.pos.x = -2.5 * (graceChords.length - i);
switch (voice) {
case 0: text.pos.y = 1; break;
case 1: text.pos.y = 10; break;
case 2: text.pos.y = -1; break;
case 3: text.pos.y = 12; break;
}

cursor.add(text);
// new text for next element
text = newElement(Element.STAFF_TEXT);
}

var notes = cursor.element.notes;
nameChord(notes, text);

switch (voice) {
case 0: text.pos.y = 1; break;
case 1: text.pos.y = 10; break;
case 2: text.pos.y = -1; break;
case 3: text.pos.y = 12; break;
}
if ((voice == 0) && (notes[0].pitch > 83))
text.pos.x = 1;
cursor.add(text);
} // end if CHORD
cursor.next();
} // end while segment
} // end for voice
} // end for staff
Qt.quit();
} // end onRun
Expand Down