VexFlow - Copyright (c) Mohit Muthanna 2010.
A BarNote is used to render bar lines (from barline.js). BarNotes can
be added to a voice and rendered in the middle of a stave. Since it has no
duration, it consumes no ticks, and is dealt with appropriately by the formatter.
See tests/barnote_tests.js for usage examples.
Vex.Flow.BarNote = (function() {
function BarNote() { this.init(); }To enable logging for this class. Set Vex.Flow.BarNote.DEBUG to true.
function L() { if (BarNote.DEBUG) Vex.L("Vex.Flow.BarNote", arguments); } Vex.Inherit(BarNote, Vex.Flow.Note, {
init: function() {
BarNote.superclass.init.call(this, {duration: "b"});
var TYPE = Vex.Flow.Barline.type;
this.metrics = {
widths: {}
};Defined this way to prevent lint errors.
this.metrics.widths[TYPE.SINGLE] = 8;
this.metrics.widths[TYPE.DOUBLE] = 12;
this.metrics.widths[TYPE.END] = 15;
this.metrics.widths[TYPE.REPEAT_BEGIN] = 14;
this.metrics.widths[TYPE.REPEAT_END] = 14;
this.metrics.widths[TYPE.REPEAT_BOTH] = 18;
this.metrics.widths[TYPE.NONE] = 0;Tell the formatter that bar notes have no duration.
this.ignore_ticks = true;
this.type = TYPE.SINGLE;Set width to width of relevant Barline.
this.setWidth(this.metrics.widths[this.type]);
},Get and set the type of Bar note. type must be one of Vex.Flow.Barline.type.
getType: function() { return this.type; },
setType: function(type) {
this.type = type;
this.setWidth(this.metrics.widths[this.type]);
return this;
},
getBoundingBox: function() {
return new Vex.Flow.BoundingBox(0, 0, 0, 0);
},
addToModifierContext: function() {
/* overridden to ignore */
return this;
},
preFormat: function() {
/* overridden to ignore */
this.setPreFormatted(true);
return this;
},Render note to stave.
draw: function() {
if (!this.stave) throw new Vex.RERR("NoStave", "Can't draw without a stave.");
L("Rendering bar line at: ", this.getAbsoluteX());
var barline = new Vex.Flow.Barline(this.type);
barline.setX(this.getAbsoluteX());
barline.draw(this.stave);
}
});
return BarNote;
}());