multiple measures

master
Matt Huntington 5 years ago
parent e5b86f8cbc
commit ca853a15ad

@ -10,31 +10,36 @@ renderer.resize(1000, 1000);
// And get a drawing context: // And get a drawing context:
var context = renderer.getContext(); var context = renderer.getContext();
// Create a stave at position 10, 40 of width 400 on the canvas.
var stave = new VF.Stave(10, 40, 800); const drawNotes = (measureNum) => {
// Create a stave at position 10, 40 of width 400 on the canvas.
// Add a clef and time signature. var stave = new VF.Stave(10+(measureNum*400), 40, 400);
stave.addClef("treble").addTimeSignature("7/8");
// Add a clef and time signature.
// Connect it to the rendering context and draw! if(measureNum === 0){
stave.setContext(context).draw(); stave.addClef("treble").addTimeSignature("4/4");
}
var notes = [
new VF.StaveNote({clef: "treble", keys: ["c/4"], duration: "8" }), // Connect it to the rendering context and draw!
new VF.StaveNote({clef: "treble", keys: ["d/4"], duration: "8" }), stave.setContext(context).draw();
new VF.StaveNote({clef: "treble", keys: ["b/4"], duration: "8" }),
new VF.StaveNote({clef: "treble", keys: ["d/4"], duration: "8" }), var notes = [
new VF.StaveNote({clef: "treble", keys: ["d/4"], duration: "8" }), new VF.StaveNote({clef: "treble", keys: ["c/4"], duration: "4" }),
new VF.StaveNote({clef: "treble", keys: ["d/4"], duration: "8" }), new VF.StaveNote({clef: "treble", keys: ["d/4"], duration: "4" }),
new VF.StaveNote({clef: "treble", keys: ["d/4"], duration: "8" }), new VF.StaveNote({clef: "treble", keys: ["b/4"], duration: "4" }),
]; new VF.StaveNote({clef: "treble", keys: ["d/4"], duration: "4" }),
];
// Create a voice in 4/4 and add the notes from above
var voice = new VF.Voice({num_beats: 7, beat_value: 8}); // Create a voice in 4/4 and add the notes from above
voice.addTickables(notes); var voice = new VF.Voice({num_beats: 4, beat_value: 4});
voice.addTickables(notes);
// Format and justify the notes to 400 pixels.
var formatter = new VF.Formatter().joinVoices([voice]).format([voice], 400); // Format and justify the notes to 400 pixels.
var formatter = new VF.Formatter().joinVoices([voice]).format([voice], 400);
// Render voice
voice.draw(context, stave); // Render voice
voice.draw(context, stave);
}
drawNotes(0);
drawNotes(1);

Loading…
Cancel
Save