readme.txt 4.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. VexFlowPatch
  2. base vexflow version:
  3. 1.2.93
  4. note: this patch will likely create errors when used with a different vexflow version, like 3.x
  5. if using a different vexflow version, disable this prebuild patch script in package.json.
  6. These files are custom patches for the currently installed vexflow version.
  7. They are copied by the npm prebuild script to ../../node_modules/vexflow/src/ before a build.
  8. Each .js has comments like "// VexFlowPatch: [explanation]" to indicate what was changed.
  9. (a diff can be created from the base vexflow version)
  10. articulation.js (custom addition):
  11. respect modifier.y_shift (y_shift affects y position of rendering)
  12. beam.js (custom addition):
  13. add flat_beams, flat_beam_offset, flat_beam_offset_per_beam render_option (fixed in vexflow 4)
  14. able to add svg node id+class to beam (not yet in vexflow 4)
  15. clef.js (merged vexflow 4):
  16. open group to get SVG group+class for clef
  17. formatter.js (custom addition, unnecessary in vexflow 4):
  18. comment out unnecessary error thrown, which prevents the fix to
  19. layouting improvements with whole measure rests and e.g. 12/8 rhythm in #1187.
  20. gracenotegroup.js (custom addition, needs check if necessary in vexflow 4):
  21. check for gracenotegroup.spacing set, to allow e.g. spacing = 0 by default.
  22. (with previous default 4, spacing is way too large unnecessarily, in most cases)
  23. keysignature.js (merged vexflow 4):
  24. open group to get SVG group+class for key signature
  25. pedalmarking.js (custom addition):
  26. Add rendering options for pedals that break across systems.
  27. clef.js (custom addition):
  28. open group to get SVG group+class for clef
  29. stave.js (merged/fixed vexflow 4):
  30. prevent a bug where a modifier width is NaN, leading to a VexFlow error (fixed vexflow 4)
  31. stave.setSection(section, y, xOffset = 0, fontSize = 12):
  32. add xOffset, fontSize arguments (see stavesection.js) (merged vexflow 4.x)
  33. stavenote.js (custom addition):
  34. Fix stem/flag formatting. Instead of shifting notes by default, update the stem/flag rendering to render different voices aligned.
  35. Only offset if a note is the same voice, same note.
  36. (not yet in vexflow 4, PR 1263 open)
  37. able to add svg node id+class to stem (merged vexflow 4.x)
  38. Save and restore noteheads (e.g. slash noteheads) in reset()
  39. staverepetition.js (fixed vexflow 4):
  40. add TO_CODA enum to type() and draw()
  41. fix x-positioning for TO_CODA and DS_AL_CODA in drawSymbolText()
  42. fix y-shift
  43. stavesection.js (half-fixed vexflow 4.x, collision, box not removable):
  44. stavesection.draw():
  45. adjust rectangle positioning, make height depend on text height
  46. stavetie.js (merged vexflow 4.x):
  47. context opens group for stavetie, can get stavetie SVG element via getAttribute("el")
  48. stavevolta.js (merged Vexflow 3.x):
  49. Fix the length of voltas for first measures in a system
  50. (whose lengths were wrongly extended by the width of the clef, key signature, etc. (beginInstructions) in Vexflow 1.2.93)
  51. stem.js (fixed vexflow 4 (or earlier)):
  52. able to give an id+class to the stem node in SVG
  53. stemmablenote.js (custom addition, see stavenote.js):
  54. Add manual flag rendering variable so we can choose not to render flags if notes are sharing a stem.
  55. svgcontext.js (custom addition, probably not necessary for vexflow 4):
  56. able to add extra attributes (like svg node id) to a stroke (e.g. stem)
  57. tabnote.js (merged Vexflow 3.x):
  58. Add a context group for each tabnote, so that it can be found in the SVG DOM ("vf-tabnote")
  59. timesignature.js (fixed vexflow 4):
  60. open group to get SVG group+class for key signature
  61. tremolo.js (fixed vexflow 4):
  62. Add extra_stroke_scale, y_spacing_scale
  63. tuplet.js (vexflow 4: need to check if this option available):
  64. Add option tuplet.RenderTupletNumber
  65. Currently, we are using Vexflow 1.2.93, because of some formatter advantages
  66. compared to Vexflow 3.x versions, see this issue:
  67. https://github.com/opensheetmusicdisplay/opensheetmusicdisplay/issues/915
  68. Because of that, we need to patch in a few fixes that came after 1.2.93, as well as making custom additions for our needs.
  69. For vexflow 4 state of these changes, also see PR 1139 (vexflow 4 -> develop):
  70. https://github.com/opensheetmusicdisplay/opensheetmusicdisplay/pull/1139