-
Notifications
You must be signed in to change notification settings - Fork 104
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
Add a few RGB-aware set & blend methods to the blitters #1680
base: master
Are you sure you want to change the base?
Conversation
Initial inspiration. koreader/koreader#9024 (comment) |
Unrelated, but all of a sudden after pushing to forks I am unable to recompile. Any pointers would be helpful since I haven't touched 3rd-party deps.
|
Make sure your submodules are up-to-date and point to the right place (both base's and base itself), then try a |
Fixed the above. A fresh clone also had issues so I figured out it was something with the machine and not the koreader repo.
It looks like installing a system package added those variables by default.
Unsetting the above fixed everything and now I can compile again. I'll work on resolving your comments. |
New revision should have support for other screentypes and for real color blending (stacking multiple highlights makes the color get stronger and stronger). |
Newest revision supports color pdf highlights. If new |
c610c9a
to
df9fb03
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I've pushed some minor simplifications, but have NOT tested them, I've just checked that it built (and was generating similar machine code before actual logic deviations were implemented ;p).
Reviewed 1 of 3 files at r2, 3 of 3 files at r3, 1 of 1 files at r4, all commit messages.
Reviewable status:complete! all files reviewed, all discussions resolved (waiting on @smasher816)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Reviewed 1 of 1 files at r5, all commit messages.
Reviewable status:complete! all files reviewed, all discussions resolved (waiting on @smasher816)
Is this ok? (I mean: ready to merge?) |
Needs testing ;). |
And re-implement RGB32 fast path
(Jokes aside, we tend to prefer that syntatcit sugar (and string methods) as opposed to calling string.fn(obj) explicitly).
It'll get funkier with colors, but, oh, well.
@poire-z: Because I'm super lazy, If you have a random test file with colored text on hand, that could come in handy. Thanks ;). |
I know :) |
Replace BB_blend_rect_color w/ BB_blend_RGB_multiply_rect
We need it from inside a Document class, and having it split between ReaderHighlights and BB is weird anyway
methods... (Into lightenRect & darkenRect, respectively). c.f, 2cb2e40
with the Lua blitter...
Leave the colorFromName fallback alone, for funsies
Requires a few bendRGB32 shims for Color <= 8A, as the usual blend methods assume Color8 input.
Which is the one we actually care about, as we don't actually have any colorblitFromRGB32 callers ;).
To deal with highlights on sw nightmode...
Implement a grayscale and a color one, like other setters Instead of implementing a full array of per-color type blend methods
And round the component values to 16 shades per component.
We often need a copy anyway, so take the opportunity to make this safer ;)
This allows us to fairly easily make gray behave as our legacy grayscale highlights, honoring the user's opacity value.
Add new BB_fill_rect_color and BB_blend_rect_color functions taking a ColorRGB32.
Use a new is_rgb flag in Color structs for lua wrapper to decide which BB_ function to call.
If a ColorRGB32 is passed to fillRect/lightenRect then the new path will be taken. Otherwise original Color8A/uint8_t code is called.
No changes should occur for existing code paths. Callers must be patched to provide RGB colors if desired.
Lua blitbuffer implementation has not been changed.
This change is![Reviewable](https://camo.githubusercontent.com/23b05f5fb48215c989e92cc44cf6512512d083132bd3daf689867c8d9d386888/68747470733a2f2f72657669657761626c652e696f2f7265766965775f627574746f6e2e737667)