The less-than-random ramblings of Scott Jackson, software architect.

No Such Comfort

The Nightmare of Favicons

Posted by scottj on April 19, 2017 in Uncategorized with No Comments

Would you like to read about the evolution of Favicons?

tl;dr? Here’s a tool that will solve (nearly) everything for you. They also have a tool on that page to check that everything is honky-dory with your favicons.

For my node prototypes, I create explicit static routes for each of the files it generates. Here’s an example.

module.exports = function (app, express) {
// must be hosted in the root directory for maximum compatibility
app.use('/android-chrome-192x192.png', express.static('public/favicon/android-chrome-192x192.png'));
app.use('/android-chrome-512x512.png', express.static('public/favicon/android-chrome-512x512.png'));
app.use('/apple-touch-icon.png', express.static('public/favicon/apple-touch-icon.png'));
app.use('/browserconfig.xml', express.static('public/favicon/browserconfig.xml'));
app.use('/favicon-16x16.png', express.static('public/favicon/favicon-16x16.png'));
app.use('/favicon-32x32.png', express.static('public/favicon/favicon-32x32.png'));
app.use('/favicon.ico', express.static('public/favicon/favicon.ico'));
app.use('/manifest.json', express.static('public/favicon/manifest.json'));
app.use('/mstile-70x70.png', express.static('public/favicon/mstile-70x70.png'));
app.use('/mstile-144x144.png', express.static('public/favicon/mstile-144x144.png'));
app.use('/mstile-150x150.png', express.static('public/favicon/mstile-150x150.png'));
app.use('/mstile-310x150.png', express.static('public/favicon/mstile-310x150.png'));
app.use('/mstile-310x310.png', express.static('public/favicon/mstile-310x310.png'));
app.use('/safari-pinned-tab.svg', express.static('public/favicon/safari-pinned-tab.svg'));

For node prototypes using pug as the templating engine, I also create an include to handle the meta tags.

link(rel='apple-touch-icon', sizes='180x180', href='/apple-touch-icon.png')
link(rel='icon', type='image/png', href='/favicon-32x32.png', sizes='32x32')
link(rel='icon', type='image/png', href='/favicon-16x16.png', sizes='16x16')
link(rel='manifest', href='/manifest.json')
link(rel='mask-icon', href='/safari-pinned-tab.svg', color='#ffc40d')
meta(name='theme-color', content='#ffc40d')

High DPI on CentOS 7.2

Posted by scottj on December 8, 2016 in Uncategorized with No Comments

In VirtualBox on a Retina Macbook Pro, you can turn on HiDPI support. Your copy of CentOS 7.2 will have some microscopic text! Surely Linux can support HiDPI displays, right?

Well, I’d class it as “experimental” at the moment, but there are some things you can do. First, from ArchWiki comes a command that does wonders for the logged in user:

gsettings set org.gnome.desktop.interface scaling-factor 2

This does not affect the initial log in screen when first starting the VM, however. I’m not sure how to effect that, so if you know, please feel free to add a comment!

Next, from PCWorld, comes a utility that may help:

yum install gnome-tweak-tool

The PCWorld instructions will tell you to set the Window Scaling to 2 using this tool. In my experience, this does scale windows and desktop icons, but doesn’t appear to scale the Gnome toolbars. Your mileage may vary, but it doesn’t seem to be necessary if you use the ArchWiki command instead.

The tool does have some other tweaks that may be useful though, including text rendering settings and swapping around control, option and command keys, if these fits your preference.

I have not found a way to adjust the icon grid. It seems a little off with the new settings. Any tips there would be appreciated.

Capricious Whim

“Einstein argued that there must be simplified explanations of nature, because God is not capricious or arbitrary. No such faith comforts the software engineer.” —Fred Brooks