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

feat: Canvas & SVG renderers will no longer will invert characters #239

Draft
wants to merge 9 commits into
base: master
Choose a base branch
from

Conversation

jamsch
Copy link
Contributor

@jamsch jamsch commented May 30, 2021

This is in anticipation of a major version update to the hanzi-writer-data & hanzi-writer-data-jp packages to fix a core issue with path layouts being vertically flipped. After this change, the only assumption left (in regards to character data) will be that the character's bounding box is 1024x1024.

The fix that will be applied to the characters is listed in this repository:

https://github.com/jamsch/hanzi-writer-char-fixer

BREAKING CHANGE: Users will need to update their hanzi-writer-data & hanzi-writer-data-jp character packages

This is in anticipation of an update to the hanzi-writer-data & hanzi-writer-data-jp packages to fix a core issue with path layouts being horizontally flipped.

BREAKING CHANGE: Users will need to update their hanzi-writer-data & hanzi-writer-data-jp character packages
@codecov-commenter
Copy link

codecov-commenter commented May 30, 2021

Codecov Report

Base: 96.31% // Head: 96.55% // Increases project coverage by +0.24% 🎉

Coverage data is based on head (4bc8a47) compared to base (c0c08b0).
Patch coverage: 96.25% of modified lines in pull request are covered.

Additional details and impacted files
@@            Coverage Diff             @@
##           master     #239      +/-   ##
==========================================
+ Coverage   96.31%   96.55%   +0.24%     
==========================================
  Files          32       31       -1     
  Lines        1139     1161      +22     
  Branches      207      215       +8     
==========================================
+ Hits         1097     1121      +24     
+ Misses         38       36       -2     
  Partials        4        4              
Impacted Files Coverage Δ
src/characterActions.ts 100.00% <ø> (ø)
src/utils.ts 95.00% <91.66%> (-2.19%) ⬇️
src/models/Character.ts 97.22% <97.05%> (-2.78%) ⬇️
src/HanziWriter.ts 95.60% <100.00%> (+1.68%) ⬆️
src/Mutation.ts 96.62% <100.00%> (-0.08%) ⬇️
src/Positioner.ts 100.00% <100.00%> (ø)
src/Quiz.ts 97.26% <100.00%> (+1.36%) ⬆️
src/geometry.ts 100.00% <100.00%> (ø)
src/renderers/canvas/HanziWriterRenderer.ts 100.00% <100.00%> (+3.33%) ⬆️
src/renderers/canvas/canvasUtils.ts 100.00% <100.00%> (ø)
... and 3 more

Help us with your feedback. Take ten seconds to tell us how you rate us. Have a feature suggestion? Share it here.

☔ View full report at Codecov.
📢 Do you have feedback about the report comment? Let us know in this issue.

@chanind
Copy link
Owner

chanind commented May 30, 2021

What's the bug this is solving? The data is flipped because that's the format that makemeahanzi uses, although I'm not sure why it uses that format. The positioner corrects the flip and scales the contents to fit the window so the character should appear correctly on the screen. Is the character not rendering correctly in some scenarios?

@jamsch
Copy link
Contributor Author

jamsch commented May 30, 2021

Not so much a bug fix, but the intention is to make it easier for users to add in their own custom characters without requiring them to write an algo to vertically flip the paths & medians (which has personally been a source of pain for adding in missing Kana and other writing systems). It should also make it easier to export the character data to SVG to be used outside the library (e.g. on React Native) without requiring scaling transforms.

This change comes from a project that now utilizes these normalized characters. It certainly will warrant a major version update to prevent users from loading in the old characters. I'll be happy to close this though if you don't feel that this is part of the scope of this repo.

@chanind
Copy link
Owner

chanind commented Jun 1, 2021

What do you think about making the data parsing part of the code replaceable? So, instead of it being hardcoded to the makemeahanzi format, you could pass in a character parsing function as an option that would take in the character JSON in whatever format it's in and return a format that hanzi-writer can work with. By default it would use a parsing function for makemeahanzi, but you'd be able to make your own data format and just pass a formatting option so it would work. That way we wouldn't need to make a breaking change, while still allowing for flexibility in how the character data is structured.

@jamsch
Copy link
Contributor Author

jamsch commented Jun 8, 2021

@chanind Yep, makes sense. Will add to this PR with your suggested changes soon.

If I'm understanding you correctly, we'd implement a default character parser/transformer (as we're assuming this is used for hanzi-writer-data / hanzi-writer-data-jp character sets) that flips the Y transform and offsets the Y medians so that it can be rendered normally on the Canvas/SVG renderers (as already done in this PR). For users that already have normalized characters they wouldn't need to go through this step unless their character spec differs from a 1024x1024 bounding box.

@chanind
Copy link
Owner

chanind commented Jun 8, 2021

Yeah I think that's reasonable. For cases where the data is already in the 1024x1024 and pre-flipped format, you'd still need to pass something into the processCharData option, or whatever we want to call that param, that keep it from doing any transforms. Maybe something like processCharData: data => data as an identity function? Or maybe we could create a shorthand like processCharData: 'plain' or something? By default it would assume the data is in makemeahanzi format, and the default processCharData function would act accordingly

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants