-
Notifications
You must be signed in to change notification settings - Fork 667
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
Improve Curve API #1607
Comments
I've been thinking this for a long time, and even started on it a couple of times but didn't follow through (in fact, I think this may be an issue somewhere, if you look through the list). I think we should create a different curve object, instead of trying to patch the existing one. Because part of what is broken is the API.
|
FWIW, I documented some existing curve behavior in stringsync/vexml#201 (comment) and stringsync/vexml#201 (comment). Thanks for the discussion so far @AaronDavidNewman, I think we're pretty much in agreement. Just a few comments and clarifications:
Yes, I think this is the better approach, since you won't have to worry about regressing the existing implementation and juggling old and new option compatibilities/interactions.
Right, but my point is if you're using TypeScript, you have to construct it in a manner that's not compatible with new Curve(startNote, undefined as any, curveOptions);
new Curve(undefined as any, stopNote, curveOptions); or in my case since new Curve(startNote as any, stopNote as any, curveOptions);
I like this approach. It reinforces that the caller is responsible for defining control points that works in the graphical context. When I made this issue, I didn't think about the UI editing use case but it makes sense. It looks like musicXML also supports bezier curve data, so there will be a place for control point data to live. |
I think having a slur that ends at the end the line doesn't mean the slur doesn't have an end note. There is still a 'last note of the slur', and it may not be in the same measure. Like if you wanted to slur from the endpoints shown below (for some reason). You would render it as 2 different slurs, the first one would end at the end of measure 11, so there should to be some way to indicate that. The second slur would be from the beginning of the bar to the last note in the slur in measure 14. So I think 'terminate start on stave', 'terminate end on stave' would be a options for the slur. (if the phrase went on for the whole line, it could be both, but that's an extreme case). Most vexflow logic can safely assume everything happens in the same stave, but for slurs that is definitely not the case. I haven't completely thought this part out, but I think you might want to pass in all the notes in between. Then the logic can calculate the control points from the notes that are there, based on stem directions and Y positions. You could pass in any number of notes, the first/last X position would be the start, end (or we could require that the notes be passed in order). Passing in an array also handles the case of a slur that is from the first/last note in the line to the end of the line. An array can contain a single note, and you would set the 'terminate on start/end note' modifier. |
In stringsync/vexml#201, I'm using
vexflow
to draw slurs encoded in MusicXML. I have a few asks for theCurve
API.Fix the types. Curve objects can be partial, but the constructor forces you to specify
Note
instead ofNote | undefined
.Allow me to specify the curve opening direction. Otherwise, I have to mimic the calculation that
vexflow
does to figure out the direction of the opening, and my implementation will know too much about how vexflow works. Maybe a property inCurveOptions
likeopeningDirection?: 'up' | 'down' | undefined
.Make
vexflow
dynamically calculatecps
when not provided one inCurveOptions
. Currently, it will just use the defaultcps
that theCurve
constructor sets. As I was migrating slurs fromStaveTie
, I thought it would be a similar experience whereCurve
would just mostly work. However, I had no idea howcps
were control points that influenced the shape of the curve until I opened up theCurve
implementation and studied it. It probably would be a good experience forvexflow
users to not have to calculate control points.The text was updated successfully, but these errors were encountered: