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

support needed for vertical-align property with images #556

Closed
ngaurav opened this issue Feb 24, 2021 · 13 comments
Closed

support needed for vertical-align property with images #556

ngaurav opened this issue Feb 24, 2021 · 13 comments
Labels
duplicate This issue or pull request already exists

Comments

@ngaurav
Copy link
Contributor

ngaurav commented Feb 24, 2021

I am storing text with some latex code for math part. Using python markdown extensions that text can be converted into html, which is mostly text but the latex is rendered as SVG in tag. To match the baseline of image with the text, there is a vertical-align attribute. Flutter_html currently ignores inline vertical-align attributes for img tag. To suit my requirements, I have created a hacky fork of flutter_html = which uses a class called BaselineBox to define a baseline for its child (SvgContentElement class). If this sounds like a worthy feature for flutter_html, then please implement it. Here is a sample html node, which can be used as a test case.

Screen Shot 2021-02-24 at 11 53 52 PM

<p>If <img class="latex-inline math" style="vertical-align:-0.353876pt" alt="" id="4b09cb9bb985eb9" src=""> is divided by 5 what will be the remainder?</p>

@tneotia
Copy link
Collaborator

tneotia commented Feb 24, 2021

If you'd like you can submit a PR and @erickok will review it, since you already have created a solution. It definitely seems like a great feature! :)

@erickok
Copy link
Collaborator

erickok commented Feb 24, 2021

To support vertical-align styling beyond just the use case here, maybe we could use transform? I'd have to read up on what this css property does exactly on the web.

@ngaurav
Copy link
Contributor Author

ngaurav commented Feb 25, 2021

Transform works, but the issue is that when you shift the image by some pixels, the line height of the widget does not change. This leads to overlap of two lines as shown below
WhatsApp Image 2021-02-25 at 10 29 55 AM

@erickok
Copy link
Collaborator

erickok commented Feb 25, 2021

Oh yeah that's an issue then. Okay we have to take a good look. I saw your commits and they look promising, but I hope to find something beyond just support for this css property for just inline svg images.

@ngaurav
Copy link
Contributor Author

ngaurav commented Mar 8, 2021

I understand that it seems like a corner use-case. But, we can look at it like a general support for vertical-align inline style. It will work on all kinds of images (SVG, PNG) and also can be helpful when mixing fonts. Some people mix symbols with text on the same line, and they expect it to be aligned.
https://stackoverflow.com/questions/62371976/align-text-baseline-with-text-inside-a-column-using-flutter
https://stackoverflow.com/questions/56592377/align-icon-by-baseline-in-stack

And, some people just want to shift the text alignment.
https://stackoverflow.com/questions/56170779/base-align-text-and-dashed-line-in-flutter
https://iamvdo.me/en/blog/css-font-metrics-line-height-and-vertical-align

If image alignment is implemented, then whatever people can convert every complex html attribute into SVG and use it with this library.

@tneotia
Copy link
Collaborator

tneotia commented Mar 18, 2021

@ngaurav I tried to replicate your setup but its not working for me, the image still renders in the middle of the text. Any ideas?

@ngaurav
Copy link
Contributor Author

ngaurav commented Mar 18, 2021

@tneotia , For me it is working with BaselineBox class Refer to https://gitlab.com/nishant.gaurav/flutter_html/-/tree/dev.
This is a hack, where I am adding a depth attribute to SVGContentElement. But the text is getting rendered properly. Here is a sample Html
WhatsApp Image 2021-03-19 at 3 36 45 AM

"<p>What is the remainder when <img class='latex-inline math' style='vertical-align:-0.105206pt' alt='' id='c3130ab88ff1525' src=''> is divided by 10?</p>"

@tneotia
Copy link
Collaborator

tneotia commented Mar 19, 2021

@ngaurav I tried your branch (I had to update the dependencies bc of conflicts) and the SVG does not show up, is there code I am missing?

@ngaurav
Copy link
Contributor Author

ngaurav commented Mar 19, 2021

@tneotia Actually the SVG is showing up. I had used a color filter which was making SVGs white for dark backgrounds. I have updated the branch now. It should be visible.

@tneotia
Copy link
Collaborator

tneotia commented Mar 20, 2021

Yes it works now and I identified why my implementation wasn't working. Something interesting:

Using alignment: PlaceholderAlignment.aboveBaseline, aligns your SVG perfectly without needing any vertical align, but then manually setting the baseline appears to do nothing.

Only when using alignment: PlaceholderAlignment.baseline,, setting vertical-align will actually do something - but vertical-align 0 appears to align the top of the element with the baseline, rather than the bottom.

Now this brings up a dilemma - I can try and use alignment: PlaceholderAlignment.baseline,, but for that we would have to compensate for the height of the element so that the bottom of the element is aligned with the baseline.

Edit: Also intrinsics aren't available for PlaceholderAlignment.baseline, PlaceholderAlignment.aboveBaseline, or PlaceholderAlignment.belowBaseline, so this breaks any HTML with tables in it.

@ngaurav
Copy link
Contributor Author

ngaurav commented Mar 21, 2021

@tneotia alignment: PlaceholderAlignment.aboveBaseline will always align the entire widget above baseline. In the example given by me, the ideal rendering should paint everything above baseline. Therefore, it was appearing perfect. If you have fraction term to render, where the denominator is usually rendered below the baseline, then alignment: PlaceholderAlignment.aboveBaseline will not help.
And I understand the dilemma, that flutter asks us to specify the baseline from the top, and therefore we must know the intrinsic height. I do not have a good understanding of intrinsics. But I found this link which uses intrinsics – flutter/flutter#65895. Their code is very similar to the BaselineBox class in my branch of flutter_svg.

@ngaurav
Copy link
Contributor Author

ngaurav commented Mar 21, 2021

Another idea could be to try getting the baseline from child and then shifting it in BaselineBox Class:

  double computeDistanceToActualBaseline(TextBaseline baselineType) {
    return _baseline + child!.computeDistanceToActualBaseline(baselineType)! ;
  }

EDIT: This allow _baseline to just have the vertical-align, while in previous case _baseline will be sum of height and vertical-align.

@Sub6Resources Sub6Resources added the duplicate This issue or pull request already exists label May 17, 2023
@Sub6Resources
Copy link
Owner

Closing as duplicate of #481. Follow that issue for updates.

@Sub6Resources Sub6Resources closed this as not planned Won't fix, can't repro, duplicate, stale May 17, 2023
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
duplicate This issue or pull request already exists
Projects
None yet
Development

No branches or pull requests

4 participants