[HN Gopher] SVG favicons have some cool benefits
___________________________________________________________________
SVG favicons have some cool benefits
Author : feross
Score : 107 points
Date : 2021-07-07 16:32 UTC (6 hours ago)
(HTM) web link (austingil.com)
(TXT) w3m dump (austingil.com)
| lokl wrote:
| Related: If you're looking for a favicon generator, check out
| https://realfavicongenerator.net (I am not affiliated, just a
| satisfied user).
| unilynx wrote:
| I wonder if the Gmail people could use this to give their app a
| non-blurry Favicon. It looks really poor when task switching
| between apps
| legulere wrote:
| I find the most interesting part how < and especially " don't
| need to be escaped inside the href attribute. How does the HTML
| parser know when the attribute stops?
| svieira wrote:
| I don't think it's actually valid - the examples just aren't
| base64-encoding in order to make it possible to read them
| easily.
|
| Edit: Yeah, you at least need to change the `"` to `'` in the
| inline SVG before it will parse correctly (tested in Firefox)
| chrismorgan wrote:
| People keep on talking about (prefers-color-scheme: dark), but it
| isn't what they want it to be--never has been, and probably never
| will be (though I will admit that prefers-color-scheme _could_
| theoretically be special-cased for favicon rendering).
|
| For example, in Firefox, I use the dark theme for the UI, but
| that's completely unrelated to the content, and prefers-color-
| scheme matches the content, not the chrome. Content I keep
| normal, light.
|
| It's quite possible (not uncommon, even) for the active tab to
| have a light background and inactive tabs to have a darker
| background. (A decade ago, this is what would happen by default
| on the default Windows XP theme, though it was the XP blue rather
| than anything _dark_ dark.)
|
| Or Chromium: like Firefox, it has themes; but beyond that,
| incognito window chrome gets a dark background.
|
| Admittedly, (prefers-color-scheme: dark) matching makes it almost
| certain that you're rendering against a dark background of some
| form, but it _not_ matching tells you absolutely nothing about
| the background.
|
| The fact of the matter is that your favicon could be rendered
| against absolutely any colour, and you need to make sure your
| icon will work on very light colours and very dark colours, and
| not be _too_ bad on anything in between.
| krono wrote:
| Yes GitHub does it too. The icon can't update itself so it's
| stuck on the color it was when you last visited the site.
|
| Example: https://i.imgur.com/PTPJ3Fm.png
| mjsir911 wrote:
| > For example, in Firefox, I use the dark theme for the UI, but
| that's completely unrelated to the content, and prefers-color-
| scheme matches the content, not the chrome. Content I keep
| normal, light.
|
| Of note is https://bugzilla.mozilla.org/show_bug.cgi?id=1529323
| which is requesting to change this behaviour to align prefers-
| color-scheme to the UI theme if there is no overriding
| behaviour.
|
| I prefer this because now rather than setting dark mode to each
| site I go to, they can be signalled this already. There's no
| user friendly way to set firefox's prefer-color-scheme: dark if
| the OS does not have the capabilities to do that.
| chrismorgan wrote:
| Yeah, I've been waiting for that to inevitably happen so that
| I can revert it. Speaking overly broadly, dark mode
| everything is normally an at-least-slightly bad idea, but
| there's good cause for aesthetic (low-contrast) dark mode of
| chrome in order to get it mostly out of the way, so that you
| can focus on the content. This is essentially what most
| graphics programs default to nowadays, and the same reasoning
| can be applied to browsers. (Though it only really works if
| your windows are maximised, otherwise dark between two lights
| could become a distraction.) No one says "you have a dark
| desktop background, you must want everything on your system
| to be dark". Comment 47's "When using the "Dark" theme,
| "prefers-color-scheme" should be dark, because that's what
| the user requested." is simply not right. Choosing a dark
| browser theme is honestly quite a weak hint about whether you
| want _content_ to be dark. The conflation of this that recent
| forays into OS-wide dark modes has encouraged is not good.
| dlbucci wrote:
| I agree they are great, especially for simple icons that work as
| SVG. Support for SVG favicons, however, keeps me from using them:
| https://caniuse.com/link-icon-svg
| clone1018 wrote:
| When you look at it compared to actual browser usage, you end
| up with 89.62% support, which is not bad at all. WebP & CSS
| Grid are at about 95%.
| chrismorgan wrote:
| Oh wow, Safari _still_ doesn't do regular SVG favicons? Huh.
| Somehow I thought that got sorted out a couple of years back in
| 12 or something.
| makeworld wrote:
| No need to use SVGs for an emoji favicon. Just put the emoji and
| a space at the beginning of your <title>.
| MattIPv4 wrote:
| Was wondering if you could use this to run a version of your site
| in the favicon directly using `foreignObject`, but it looks like
| Chromium browsers at least render the SVGs in static mode [1][2].
| Maybe it'll work in others though?
|
| [1] https://www.chromestatus.com/feature/5180316371124224
|
| [2] https://svgwg.org/svg2-draft/conform.html#secure-static-mode
| chrismorgan wrote:
| Secure static mode doesn't block foreignObject. Script
| execution, external references, declarative animation and
| interactivity, but not foreign content. Indeed, such processing
| modes are propagated to such foreign content:
| https://svgwg.org/svg2-draft/conform.html#referencing-modes.
|
| See https://news.ycombinator.com/item?id=26922244#26923436 for
| an example. It works in Chromium.
| dmit wrote:
| _Awkward ad intermission_
|
| Tired of all the "404 Not Found: /favicon.ico" log messages from
| your local test server? Fret no more! Just add this minor
| incantation to your HTML and you're set! <link
| rel="icon" href="data:," />
| soheil wrote:
| why not just touch favicon.ico
|
| so it gets cached and forget about it?
| blacksmith_tb wrote:
| Seems like the author is ahead of you, inlining the svg in your
| head tag should fix that too?
| teddyh wrote:
| I prefer this: <link rel="icon"
| href="
| gAAACAAAAAgCAMAAABEpIrGAAAAG1BMVEU5PT85PT///7X22GDtiUvVOkKxOF5q
| Mk////9bF0DJAAAAAXRSTlMAQObYZgAAAD5JREFUeNq906UBwEAUwNBy95+4cOA
| +09OxWSKsCE2wAQKCRhrsiMrgQFQGJ6IyuBCVwQ1YG1+wTHgQdpbTC3XuCmFsTK
| U6AAAAAElFTkSuQmCC>
| soheil wrote:
| There won't be any overhead once the file is cached. Your
| method requires the favicon to keep getting downloaded on
| every page load.
| TheRealPomax wrote:
| 2: Why? Are there even any systems left on the planet that
| aren't past EOL but don't have emoji fonts preinstalled at the
| OS level?
| reaperducer wrote:
| Maybe because you can't guarantee that even if an OS has
| emoji support that it supports the latest version of emojis.
|
| I run into this every time my wife updates her phone. She
| sends me text messages with "Lookit the cool new emojis!" But
| since I haven't updated mine, they came through as missing
| icon glyphs.
| shadowfaxRodeo wrote:
| I think google renders them in a raster format. Whatever they
| use to do that doesn't support emojis.
|
| It could be by design, by rendering any text in the svg icon
| google is making a design decision for you. They're choosing
| a font, or a specific emoji type. Maybe they want to avoid
| the problems that would ensue.
___________________________________________________________________
(page generated 2021-07-07 23:01 UTC)