How to reduce the file size of large background images by over 93%

(peterhrynkow.com)

31 points | by labwire 1925 days ago

16 comments

  • godelski 1925 days ago
    "There's a problem, especially in X space. Let's ignore X, only deal with the simplest methods, pretend that this is innovative, and give it a click-baity title."

    Why is this on the front page?

    • labwire 1921 days ago
      I point out the limitations of this method explicitly. How is that “ignoring X”?
  • rinchik 1925 days ago
    I got excited for a moment.

    There is also a way to have a size reduction for somewhat intricate backgrounds: background-repeat.

    https://en.wikipedia.org/wiki/Wallpaper_group

  • devwastaken 1925 days ago
    If you have flatter colors, no complex gradients, using PNG-8 can significantly reduce size. Photoshop can do this.
  • chubbyrabbit 1925 days ago
    A very specific use case but a good thing to know. Click-bait title makes people here unhappy though.
  • gus_massa 1923 days ago
    About https://news.ycombinator.com/item?id=18931957 and https://news.ycombinator.com/item?id=18932740

    Don't repost too much, read the part of the FAQ about reposts https://news.ycombinator.com/newsfaq.html

    If you repost too much the mods may notice and ban your account, your site and other nasty stuff.

    Also, try to stick to the original title https://news.ycombinator.com/newsguidelines.html

    ---

    About this post: I think it would have been better to use another title like "How to use browser interpolation to reduce smooth mage size by 93%". The current title is misleading.

    • labwire 1923 days ago
      Thanks for letting me know about the rules. I’ve updated the blog post title as you suggested.
  • labwire 1924 days ago
    I’ve added another example to demonstrate how the technique can be used on blurry photographic backgrounds as well: https://peterhrynkow.com/performance/2019/01/13/blowing-up-i...
  • XaspR8d 1925 days ago
    There isn't any sort of spec to ask the browser to use specific scaling algorithms, right?

    I think the general idea is safe enough -- images of gradients are probably going to look fine upscaled in any algo that would actually get shipped. But there's no guarantee that tomorrow Mozilla won't decide their new mission statement is to spread the gospel of nearest neighbor.

  • corndoge 1925 days ago
    Spoilers: make them smaller
  • arielserafini 1925 days ago
    you could also achieve the same (or very close) result with CSS gradients alone.
  • sunebeck 1924 days ago
  • martin_a 1924 days ago
    Reminds me of the early 2000 years when I, as a teen, was fiddling around with 16x16 images for striped backgrounds etc.

    That said: Sorry if you only found this out in 2019.

  • vortico 1925 days ago
    Why would any website have a background image where this would work? Just use a solid color if you want to use gradients.
  • Adamantcheese 1925 days ago
    Another method that I've personally used I explained over a year ago; you can see my explanation here https://news.ycombinator.com/item?id=15704879
  • labwire 1923 days ago
    Thanks for all the comments. I’ve updated the title and some of the wording to address the feedback given here.
  • amanzi 1925 days ago
    The "technique" shown here is to convert a jpg to a png. As you would expect, this does not work for all images.
    • ebg13 1925 days ago
      No, the "technique" is to

      1. use only smooth gradients for your background (LOL)

      2. remove most of your pixels

      3. assume that the browser will interpolate for you (Also LOL)

      If this had been called "pictures of smooth gradients don't need to be high res if your viewer interpolates them sufficiently well" then it would be accurate and sound a lot less noobish.

      • gus_massa 1923 days ago
        I agree, but your comment would have been much better without the "LOL".

        about 3: most browsers have a good interpolation method for smooth images. It's a safe assumption if you have time to read all the documentation and you drop the support for IE6. (Perhaps IE6 can also interpolate correctly. I don't know and I'm not going to try to find the docs. IIRC I once had problems with the autostretching of the background image in IE6.)

      • mark-r 1925 days ago
        Are you familiar with any web browsers that would not do a "sufficiently well" job of interpolating? I wouldn't expect a browser to use anything less than bilinear, which is fine for the use case presented. The author freely admitted that the technique isn't universal for all images.
      • danbolt 1925 days ago
        I'm no web design expert, but I'm surprised gradients such as that aren't defined via CSS or some other programmatic means.
        • devonkim 1925 days ago
          CSS definitely supports gradients in theory but perhaps the way they work is not to the liking of designers / their audience / their clients

          https://www.w3schools.com/css/css3_gradients.asp

          • XaspR8d 1925 days ago
            CSS gradients have 2 notable annoyances:

            - Simple horizontal, vertical, or radial gradients can rarely capture the "organic" look that most designers want (the gradients of real materials and scenes are highly uneven so perfect symmetry has a distinctly artificial appearance).

            - I'm not sure if it's actually an aspect of the spec, but all implementations I've seen interpolate the colors in RGB or an RGB-like colorspace. This can have the effect of creating dramatic jumps or ridges. With a lot of trial and error (or color math) you can overcome this by using custom stop values, but it's much simpler and more in-line with a designer's toolset to be using colorspaces whose linear interpolations are more perceptually uniform.

            Of course there's also the "standard drawback" of modern webdev too: it's often easier to just throw assets at the problem. :/

            (Thoughts from a design-adjacent dev.)

            • systoll 1924 days ago
              That is part of the spec. CSS colour 4 allows colours to be defined in using different colourspaces, but the gradient spec continues to dictate linear interpolation of the RGB values.
        • ebg13 1925 days ago
          Eh, I'm not fussed about that. The example images used are smooth but still rather complex. It would be hard for your average bear to codify them programatically.
        • Mtinie 1925 days ago
          Usually they would be. I’m sure there is a rare exception for why you would want to create it as a raster image, but for the usual cases I run across CSS is far more flexible.

          Embedded gradient images for use in emails for clients without CSS gradient support, possibly.

          In this specific case I can see why layered CSS gradients would be non-trivial to assemble, but it’s a trade off.

          Example: https://stackoverflow.com/questions/14926189/creating-a-grad...

      • amanzi 1925 days ago
        Yeah, agree -- I over-simplified it.
    • Dylan16807 1925 days ago
      jpg to png is a minor factor. The main one is "if your image is astoundingly blurry, make it much much smaller".

      Which is great if you have an astoundingly blurry image, and useless if you don't.

    • NicoJuicy 1925 days ago
      Png's works best for logo's and other computer drawn "images". JPG is the "best" format for photos. if i need to pick between png or jpg, that's what i do.
      • mark-r 1925 days ago
        Not strictly true - JPG is best only if you need smaller images at the expense of image quality. I save photos as PNG all the time if I want to keep them losslessly.
      • cronix 1925 days ago
        Why are png's better for logos over SVG?
        • NicoJuicy 1924 days ago
          I mentioned between png and jpg to restrict options.

          In practice, I receive one of those from clients. Of course there are more options

  • ebg13 1925 days ago
    > Disclaimer: I know very little about image scaling

    This person also knows very little about web browsers. Warning: Do not follow their advice when making your website.

    > When the small image is enlarged, the browser uses an interpolation algorithm to fill in the missing image data.

    "the browser". Hah. As if there's just one.

    • kevsim 1924 days ago
      While a certain amount of snark may be justified I’m pretty sure we can assume the author is aware their is more than one browser. Are you aware of browsers that don’t interpolate as described?