capture-website
capture-website copied to clipboard
Full page screenshot
Can we improve the rendering of full-page screenshot i.e. tackling fixed elements as well as lazy-loading of elements at a particular scroll or maybe infinite scrolling too.
IssueHunt Summary
Backers (Total: $60.00)
-
issuehunt ($60.00)
Submitted pull Requests
Become a backer now!
Or submit a pull request to get the deposits!
Tips
- Checkout the Issuehunt explorer to discover more funded issues.
- Need some help from other developers? Add your repositories on IssueHunt to raise funds.
tackling fixed elements
Any suggestions on how to tackle this?
maybe infinite scrolling too.
This is already planned.
- For FIXED elements,
a) Open the page in a particular viewport width(W) and height(H) and then capture the screenshot of the viewport only. b) Scroll the page horizontally(W+W) and take the screenshots until fully scrolled horizontally. c) Now scroll vertically(H+H) and take the screenshot. d) Repeat steps (b) and (c) e) Now smartly stitch the images in such a way it looks like a full-page screenshot. f) For tackling FIXED elements, after taking the very first screenshot, remove them from page otherwise they will repeat in every screenshot and will cause noise.
- For INFINITE scroll
a) Scroll the page to the bottom b) Check if height is increased because of lazy-included elements at the bottom c) Repeat (a) and (b) until height is not increasing or the MAX_SCREENSHOT_HEIGHT is reached. d) Now apply the same strategy as mentioned above
Hope this might help.
Let me know if I could help in this. It would be great to work with you someday.
@issuehunt has funded $60.00 to this issue. See it on IssueHunt
I’m unsure what known bugs (if any) there might be with full-page rendering, but I just tried this out on my website and noticed the bottom was cut off. I don’t think I’m doing anything particularly weird that could account for it being cut off…
Here is the generated screenshot (hiding behind details element because it’s big):
data:image/s3,"s3://crabby-images/c751e/c751e16c2c083d1aadc1955a1e5799b991b7cb52" alt=""
And this shows the missing portion from the bottom:
data:image/s3,"s3://crabby-images/f4d42/f4d42ac59b1d4f2be2349b60b0fcedf5f598f0c8" alt="screen shot 2019-02-19 at 9 44 45 am"
Hi @brandonweiss . I think that problem is caused by some heights with vh
units.
Under the hood, Chromium extends the viewport to fit body height (https://bugs.chromium.org/p/chromium/issues/detail?id=763421).
This is explained here https://github.com/GoogleChrome/puppeteer/issues/703
@sindresorhus please consider this workaround for fullPage screenshots: https://github.com/GoogleChrome/puppeteer/issues/703#issuecomment-366041479
@Takeno Interesting! Thanks for the links!
If there's a way to hack vh/vmin
units to a certain viewport height (𝑦), the viewport can be set to the page height on load (𝑦)
Any updates? :)
@SilencerWeb https://blog.sindresorhus.com/issue-bumping-e3b9740e2a0
Hi @brandonweiss . I think that problem is caused by some heights with
vh
units. Under the hood, Chromium extends the viewport to fit body height (https://bugs.chromium.org/p/chromium/issues/detail?id=763421). This is explained here puppeteer/puppeteer#703@sindresorhus please consider this workaround for fullPage screenshots: puppeteer/puppeteer#703 (comment)
Still need this implemented? I am considering implementing both solutions in https://github.com/sindresorhus/capture-website/issues/1#issuecomment-462073349 once done with current PR for fullPage
.