Designing Custom Pictograms for the Mobile Web

A Matter of Trade-Offs

Pictograms – miniature graphical representations of states, actions and objects – made their way into the mobile Web over 15 years ago. Several normalized (UNICODE, WAP) and proprietary (Japanese emojis, Openwave) mechanisms are in place to enrich Web applications with pre-defined images.

The various approaches, with correspondence tables between icon dictionaries, are reviewed in another article. However, one cannot always rely upon these standards:

Programming techniques for the ad-hoc implementation of pictograms entail different compromises regarding the properties expected from the resulting icon resources – apart from their graphical quality:

In the following, we describe common methods and discuss their applicability. While the topic is treated in a resolutely mobile perspective, all techniques carry over directly to desktop Web development.

System Fonts

The only approach that fulfils all the aforementioned requirements consists of installing an adequate typeface implementing UNICODE pictographs on the terminal, and then configuring the client software to use it as the default font. The requisite manipulations imply transferring a font package (the TrueType format is practically always supported) directly to the end-user device; what is usually straightforward with linux or Windows can become quite involved on a mobile operating system:

OS Manual procedure summary
Android Overwrite system fonts in folder /system/fonts.
Requires a device management tool (ADB from the Android SDK).
Requires (possibly transient) root privileges.
Bada Custom fonts can be added, but the system typeface itself appears to be non-replaceable.
Requires a device management tool (Kies and sTune).
Blackberry 7.x Copy new fonts with a .font extension to folder /Device Memory/appdata/rim/fonts or /store/appdata/rim/fonts. Then change default font via the “Options – Screen and Keyboard” menu.
iOS Overwrite system fonts in folder /System/Library/Fonts/Cache. Application-specific fonts that do not replace default typefaces are made known to iOS by editing a configuration file.
Requires root privileges (jailbreaking).
Meego Overwrite system fonts in folder /usr/share/fonts/nokia/Nokia Pure/proportional.
Requires root privileges.
Nokia S40 Reflash the device with a modified firmware substituting system fonts.
Symbian Copy new fonts to folder /Resource/Fonts on the memory card, and rename them to match existing system fonts (which themselves should not be disturbed from the device built-in system memory).
Old versions of S60 only accept fonts in the format GDR; translation from TTF is achieved through the tool KVT Symbian Font Converter.
WebOS Add new fonts to folder /usr/share/fonts. Custom fonts overriding the default typeface must have a matching name.
Requires a device management tool (WebOSQuickInstall).
Requires root privileges (development mode).
Windows Application-specific fonts can be added to Windows Phone 7.x, but the system typeface itself is non-replaceable. On Windows Mobile 6.x, copy new fonts to folder Windows/Fonts before editing the registry.

Should the custom font be associated to a different writing logic (such as happens with many Asian languages), then keyboard layouts and rendering functions must be adjusted too, possibly affecting system libraries. A misconfiguration may well result in an unstable operating system, so all resources being altered should be backed up beforehand.

Because of its intricacies, specialized utilities have been published to facilitate font installation on popular devices (such as BytaFont for j ailbroken iPhones). Nonetheless, the overall approach is only reasonably feasible in a controlled environment where handsets are configured centrally before being distributed to end-users – such as in a corporation or a public administration.

Web Fonts

CSS includes a construct for downloading an external font to a user agent:

@font-face {
    font-family: 'IconicFill';
    src: url('http://site.ch/fonts/iconic_fill.eot');
    src: url('http://site.ch/fonts/iconic_fill.eot?#iefix') 
            format('embedded-opentype'),
        url('http://site.ch/fonts/iconic_fill.woff') 
            format('woff'),
        url('http://site.ch/fonts/iconic_fill.ttf') 
            format('truetype'),
        url('http://site.ch/fonts/iconic_fill.svg#iconicfill') 
            format('svg');
    font-weight: normal;
    font-style: normal
}
This clause instructs the browser to retrieve font Iconic Fill from the link matching a suitable format. Following the so-called “bulletproof syntax”, it includes a redundant declaration for files of type EOT and a URL pseudo-parameter to cater for limitations of Microsoft Internet Explorer; the identifier appended to the SVG declaration is indispensable. The font appears in a further CSS declaration:
.picto {
    font-family: 'IconicFill'
}

In the markup, one inserts the desired symbol with a numeric reference – or a letter or digit, if the font covers usual alphanumeric code points – and encloses it within an element of class picto:

<span class="picto">&#xE06E;</span><!-- phone call -->

Sometimes, HTML elements are systematically endowed with a pictographic marker, for instance when distinguishing different URL types. The following notation is then preferred – it eliminates clutter from the HTML markup, and enforces consistency by concentrating presentation characteristics in one CSS clause:

a[href^="tel:"]:before {
    /* Mobile phone symbol prepended to click-to-call links. */
    font-family: 'IconicFill';
    content: "\E06E "
}
input[type="file"]:after {
    /* Document symbol appended to file upload fields. */
    font-family: 'IconicFill';
    content: "\00E000"
}

<a href="tel:+41446313111">press centre</a>
Share file: <input type="file" name="upfile" />

HTML-5 capable devices may tailor individual elements through data attributes:

[data-picto]:before {
    font-family: 'IconicFill';
    content: attr(data-picto)
}

<!-- Magnifying glass symbol prepended to a section title. -->
<h3 data-picto="&#xE074;">Detailed description</h3>

Like other external resources, Web fonts may be evicted from the browser cache whenever the client software deems it appropriate, and utilization is restricted to the site that loaded them initially. Furthermore, mobile platforms impose restrictions on installable font packages (on Blackberry, for instance, they cannot exceed 90 kB). On the other hand, they exhibit two distinct advantages over custom system fonts:

Practical Web services for converting a font definition into several formats, with the associated CSS font-face declaration, can be found at font2web, fontface and fontsquirrel. Another free online font converter can be found here.

Images Stored Locally

The Web Local Storage mechanism of HTML-5 serves to manage key-value pairs kept persistently on the terminal. This makes it possible to avoid downloading graphical resources anew at every browsing session, as happens with Web fonts. The approach can be applied effectively to resources other than pictograms – such as static pictures that appear repeatedly in a Web site. It consists of storing images as BASE64-encoded strings locally, and, subsequently, retrieving them to fill in placeholders for pictograms in the HTML pages before these are rendered.

The landing pages of the mobile Web site include a Javascript function, activated by the window.onload event, that initializes the persistent store with all pictograms. We assume the existence of an ancillary routine hasLocalStorage that determines whether the browser supports the required capability.

function initPictoStorage () {
    if (hasLocalStorage ()) {
        // Check if the current version of the pictogram set is
        // already present to avoid useless re-installations.
        var curVersion = '…';
        if (curVersion != window.localStorage.getItem ('pictocurversion')) {
            // Retrieve pictogram set via AJAX/JSON. One could
            // instead declare it statically as an array here.
            var pictoHTTP = new XMLHttpRequest ();
            pictoHTTP.onreadystatechange = function () {
                if (this.readyState == 4) {
                    if (this.status == 200) {
                        // Store each pictogram locally with
                        // a key prefixed by "picto". Add or
                        // update the version as a last step.
                        // Give up immediately upon a problem.
                        // Instead of JSON.parse, a Javascript
                        // eval() call can be used.
                        var pictograms = JSON.parse (this.responseText);
                        pictograms.push ({"pid" : "curversion", 
                                          "pval" : curVersion});
                        for (var i = 0; i < pictograms.length; i++) {
                            try { 
                                window.localStorage.setItem ('picto' + 
                                                             pictograms[i].pid,
                                                             pictograms[i].pval);
                            } catch (e) { break; }
                        }
                    }
                    // Whatever happens, initialize images.
                    SetAllPicto ();
                }
            }
            // Select image package to download depending
            // on the pixel density of the display
            var pictoFile;
            if (window.devicePixelRatio !== undefined) {
                pictoFile = (window.devicePixelRatio >= 1.5
                                ? 'hdpictograms.json'
                                : 'pictograms.json');
            } else {
                pictoFile = 'pictograms.json';
            }
            pictoHTTP.open ('GET', 'http://site.ch/' + pictoFile, true);
            pictoHTTP.send ();
        }
    } else {
        // No local storage, so initialize to fall-back images.
        setAllPicto ();
    }
}

Images are declared in a JSON file with a property list binding pictogram names (“pid”) to their BASE64-coded bitmap (“pval”):

[ { "pid" : "phone", "pval" : "iVBORw0K … RK5CYII=" },
  { "pid" : "photo", "pval" : "iVBORw0K … TkSuQmCC" }, … ]  

Each pictogram is defined in the (X)HTML markup as an image, styled with a specific class picto and explicitly typed via a data-picto attribute, but with src left empty. For instance, one may attach a telephone icon to a click-to-call link as follows:

<a href="tel:+41446313111"><img class="picto" alt="call" 
    src="" data-picto="phone" />press centre</a>

Every page featuring pictograms defines a function that, when window.onload fires, walks through every img element, checks whether it belongs to class picto, and if so, fetches the appropriate BASE64 string and assigns it to the src attribute. If data cannot be found in the local store, a URL to an external bitmap is used instead.

function setAllPicto () {
    // Retrieve all images in the HTML page and set the src of
    // those identified as pictograms with a proper value.
    var localStorageOn = hasLocalStorage ();
    var allImages = document.getElementsByTagName ("img");
    for (var i = 0; i < allImages.length; i++) {
        var isPicto = allImages[i].className.match (/picto/);
        if (isPicto != null) {
            // Retrieve the right BASE64 string stored locally.
            var localPicto = null;
            var pictoName = allImages[i].getAttribute ("data-picto");
            if (localStorageOn) {
                localPicto = window.localStorage.getItem 
                                            ('picto' + pictoName);
            }
            if (localPicto != null) {
                // Initialize img element with BASE64 string. 
                allImages[i].setAttribute ("src",
                                           'data:image/png;base64,'
                                           + localPicto);
            } else {
                // The pictogram is not found locally, so fall
                // back is a normal URL to an external bitmap.
                allImages[i].setAttribute ("src", 
                             'http://site.ch/pictograms/'
                             + pictoName + '.png');
            }
        }
    }
}

Finally, a CSS declaration for class picto ensures that pictograms are scaled to match the dimension of the surrounding text, with possible spacing adjustments:

img.picto {
    margin-left: 2px;
    margin-right: 2px;
    border-style: none;
    outline-style: none;
    /* Size and alignment chosen to resemble characters. */
    height: 0.75em;
    width: 0.75em;
    vertical-align: baseline
}

Images cannot be embedded as seamlessly as text, but they entail one major benefit over font-based pictograms: the flexibility to design rich polychrome symbols. Sharing of pictograms put in local storage is of course limited to pages from the same host and domain, but a bigger drawback is that the technique is rendered inoperative whenever Javascript is switched off in the browser.

Background CSS Images

Absent the local Web storage facility, one can still rely upon BASE64 encoded images to deliver pictograms to terminals. Placing them inside a style sheet is preferable, since the CSS file can be cached and shared among several pages, whereas the direct inclusion of static strings in HTML results in code duplication and ultimately larger payloads to be transmitted over the air.

One CSS class is reserved for each pictogram, and the corresponding bitmap drawn as background of the empty textual space allocated for this purpose:

[class|="picto"]:before {
    /* Reserve exactly one em white space for each pictogram.
       Set position and scale in individual rules. */
    content: "\002003"
}
.picto-phone:before {
    /* Prepend the symbol of a telephone. */
    background: url(' … K5CYII=')
                no-repeat center center;
    background-size: 0.75em /* Fits nicely as a character */
}
.picto-photo:before {
    /* Prepend the symbol of a photographic camera. */
    background: url(' … kSuQmCC')
                no-repeat 50% 50%;
    background-size: 0.75em
}

High-density displays are taken into account by setting up separate versions of the style sheet for each pixel ratio of interest, and then instructing client software to download the relevant one through appropriate CSS media queries – possibly complemented by conditional statements to cater for Internet Explorer. In (X)HTML:

<!-- Default CSS rules for devices with normal pixel ratio. -->
<link rel="stylesheet" type="text/css" href="sitestyles.css" />
<!-- CSS rules for high-density screens, full media query.  -->
<link rel="stylesheet" type="text/css" href="hdsitestyles.css"
media="only screen and (-webkit-min-device-pixel-ratio: 1.5),
       only screen and (min--moz-device-pixel-ratio: 1.5),
       only screen and (-o-min-device-pixel-ratio: 3/2),
       only screen and (min-device-pixel-ratio: 1.5),
       only screen and (min-resolution: 144dpi),
       only screen and (min-resolution: 1.5dppx)" />

One inserts pictograms in the markup by stating the relevant CSS class name:

<span class="picto-photo">Photography</span> is allowed.
<a href="tel:+41446313111" alt="call" class="picto-phone">press centre</a>.

Developers will have no difficulty finding an abundance of on-line services converting data files to BASE64 strings, as well as a few standalone programs (notably datauri). More advanced utilities parse entire CSS style sheets, extract URL to external media, and replace them with embedded BASE64 data; a couple of examples are spritebaker (on-line Internet service) and cssembed (standalone command line tool).

Sprites

The possibly oldest materialization of Web sprites may not be as well-known as CSS background image sprites, but it optimizes graphical resources to a comparable degree. It is especially well-suited for elements that are all identical in size – a constraint unlikely to prove troublesome in the case of pictograms.

Assuming the sprite is composed of eleven images N pixels wide by N pixels tall, arranged consecutively without separation in one column, one sets up a kind of viewport matching the dimensions of a single character through which the relevant portion of the sprite is rendered:

.pictowrap {
    position: relative;    /* To shift the underlying image. */
    width: 1em;            /* Set container dimensions the   */
    height: 1em;           /* … same as surrounding text.    */
    overflow: hidden;      /* Only one sub-image is shown.   */
    display: inline-block  /* Image is embedded within text. */
}
[class|="picto"] {
    position: absolute;    /* To be able to shift the image  */
    left: 0;               /* … flush to left of container.  */
    width: 1em;            /* Scale image to fill container  */
    height: 11em;          /* … and keep height proportional.*/
    outline-style: none;
    border-style: none
}
.picto-doc {
    top: -2em              /* third image inside sprite      */
}
.picto-phone {
    top: -8em              /* ninth image inside sprite      */
}

The second rule relying upon an attribute selector can of course be folded into the directives for individual pictograms. Although in principle equivalent, a horizontal sprite is not recommended, as many a mobile browser chokes on images that do not fit naturally within the screen width. The final (X)HTML code includes a semantically meaningful alt attribute attached to the pictogram and looks like this:

<h3><span class="pictowrap"><img class="picto-doc" alt="file" 
        src="http://site.ch/sprites.png" /></span>Appendix</h3>

If one can afford the software brittleness induced by pixel-oriented declarations, then CSS background sprites may play a role – particularly when optimizing purely decorative assets such as graphical separators, repeating background textures, or when tailoring bullets in unordered lists with icons. Interestingly, these customization capabilities are also supported by old-fashioned built-in pictograms of the Openwave browser.

There are numerous on-line sprite generators, configurable interactively (alignment and padding of icons, colour table, image output format, etc). This site lists a selection of such utilities. SmartSprites is a more elaborate tool to produce CSS sprites and manage the accompanying style sheets. A tutorial on sprites can be found here.

Minimal Fall-Back

If the methods proposed so far turn out to be inapplicable – as it frequently occurs with low-end phones, older WAP handsets and PDAs running legacy software – the only recourse left is the default already presented in section 5: pictograms implemented as external images. Assuming style rules for class picto identical to those listed in the aforementioned section, one obtains a simple markup:

<a href="tel:+41446313111"><img class="picto" alt="call" 
    src="http://site.ch/pictograms/phone.gif" />press centre</a>

Unsurprisingly, this technique entails practically none of the performance benefits associated with built-in pictograms.

The matrix below assesses the compatibility of major mobile browsers against every solution described in the present article. The software versions under consideration encompass a broad range of device classes and generations. The table reveals that, while the SVG format is recommended for icons and pictograms because of the well-behaved properties of vector images under transformations, developers must be ready for a (still) relatively inconsistent support for this standard across browsers, and be wary of using full-fledged SVG instead of its “tiny” profile.< /p>

Browser Web fonts Web local storage CSS data URI Image sprites SVG <img> element
Android ≥ 2.2 yes ≥ 2.1 yes ≥ 1.5 yes ≥ 1.5 yes ≥ 3.0 yes
Blackberry ≥ 6.0 yes ≥ 6.0 yes ≥ 6.0 yes ≥ 4.6 yes ≥ 6.0 yes
Chrome ≥ 18.0 yes ≥ 18.0 yes ≥ 18.0 yes ≥ 18.0 yes ≥ 18.0 yes
IE Mobile ≥ 10.0 yes ≥ 9.0 yes ≥ 9.0 yes ≥ 9.0 yes ≥ 9.0 yes
Meego ≥ 8.5 yes ≥ 8.5 yes ≥ 8.5 yes ≥ 8.5 yes ≥ 8.5 yes
MIB ≤ 2.2.2 no ≤ 2.2.2 no ≤ 2.2.2 no ≤ 2.2.2 no ≤ 2.2.2 no
NetFront ≤ 4.2 no ≤ 4.2 no ≤ 4.2 no ≤ 4.2 no ≥ 3.33 partial
Nokia S40 ≤ dp 2 no ≥ dp 1.1 yes ≤ dp 2 no = S40 6th yes = S40 6th 2 partial
Obigo ≤ Q7.1 no ≤ Q7.1 no ≤ Q7.1 no ≥ Q7.1 yes ≥ Q7.13 partial
Opera Mini ≤ 7.1 no ≤ 7.1 no ≥ 4.0 yes ≥ 4.0 yes ≥ 4.0 yes
Opera Mobile ≥ 10.0 yes ≥ 11.0 yes ≥ 10.0 yes ≥ 10.0 yes ≥ 10.0 yes
Openwave ≤ 7.2 no ≤ 7.2 no ≤ 7.2 no ≤ 7.2 no ≥ 7.0 yes
Safari ≥ 5.05 yes ≥ 5.05 yes ≥ 5.05 yes ≥ 5.05 yes ≥ 5.05 yes
SEMC ≤ 4.0 no ≤ 4.0 no ≤ 4.0 no ≤ 4.0 no ≥ 4.03 partial
Symbian ≤ 8.3 no ≥ 8.3 yes ≥ 7.31 partial ≥ OSS3.0 yes ≤ 8.3 no
TSS ≤ 2.5 no ≤ 2.5 no ≤ 2.5 no ≤ 2.5 no ≤ 2.5 no
UC Browser ≤ 8.9 no ≤ 8.9 no ≤ 8.9 no ≥ 7.94 partial ≤ 8.9 no
  1. Works directly on block-level elements, not on pseudo-elements.
  2. Only available on devices running Opera Mini.
  3. SVG availability depends on model, implementation often severely limited.
  4. Works in paragraphs, not within headings.
  5. Older versions not tested.

Resources on the Internet

Instead of firing up Gimp or FontForge to design custom pictograms, developers can simply look to the wealth of (typo)graphical resources available on the Internet.

These two sites are the first stops for determining which typefaces implement a specific UNICODE block. Symbola is essentially restricted to ASCII, Greek and Cyrillic, but encompasses many more pictograms – including non-standard ones. Quivira offers better support for European and Asian scripts (e.g. Armenian, Georgian, Hebrew, Thai, Vietnamese), with a partial, but growing, set of pictograms. Both free typefaces implement mathematical signs as well as glyphs for musical notation and several ancient languages.

Relevant UNICODE block Quivira 3.8 Symbola 7.07 Remarks
Enclosed alphanumerics yes no Circled digits
Geometric shapes yes yes Triangles for “up”, “next”…
Miscellaneous symbols partial yes Weather, games, zodiac…
Dingbats partial yes Assorted pictograms
Misc. symbols and arrows yes yes Orientated arrows
Enclosed alphanum. supplement yes no Squared “free”, “new”…
Misc. symbols and pictographs partial yes Assorted pictograms
Emoticons yes yes Smileys
Transport and map no yes Vehicles, tourist info…

Since their corresponding TrueType files weigh from 1.3 to 2.2 MB, these typefaces are suitable solely as system fonts. One must recur to specialized font packages, amounting to just a few KB to a few tens of KB, for binding downloadable resources to mobile Web pages. Fortunately, there is an expanding supply of such fonts, both free and commercial ones, professionally designed and covering numerous symbols. Overlapping collections are presented at css-tricks, owltastic, simurai and iconsguide.

A plethora of icon sets, in bitmap or vector format, can be procured on the Internet. The choice is facilitated to some extent by repositories offering a query mechanism (by keyword, size, license, etc) such as icojoy and findicons. The frequent round-ups at smashingmagazine constitute a further source of information. We emphasize a couple of extreme cases:

The sheer number of pictographic resources, the diversity of application domains, and the variety of requirements make any attempt at a comparative evaluation of available font and icon sets a daunting endeavour. We present here a small sample illustrating the stylistic range exhibited by current packages, based on a handful of pictograms relevant for modern mobile Web applications:

Package type phone menu feed config photo Attribution
Farm Fresh Web icon phone menu feed config photo FatCow Web Hosting
Web0.2ama icon phone menu feed config photo Christian Burprich
Frankfurt icon phone menu feed config photo Patricia Clausnitzer
105 loops icon phone menu feed config photo Pranav Pramod
Iconic font, icon phone menu feed config photo P. J. Onori
Typicons font phone menu feed config photo Stephen Hutchings
Entypo font phone menu feed config photo Daniel Bruce
Font Awesome font phone menu feed config photo Dave Gandy

There is a greater design and colour variability with icons, whereas fonts provide flat, black and white glyphs, to be livened up with CSS.

The Web service at icomoon, running on HTML-5 capable browsers, is invaluable to fine-tuning pictographic resources:

One should of course study the relevant license for the permission to create and use derivative works from a font or icon package processed through IcoMoon.

Concluding Remarks

Beyond issues of portability, each mode of implementing custom pictograms produces subtly different representations. The screen dump below, taken from an Opera Mobile 12.0 session with an HTML-5 page exercising all four main techniques on the 105loops set, highlights their peculiarities regarding scale, alignment, and text formatting. In this test, Web fonts are black by default, whereas bitmap resources have been painted in various colours. Only those used in the “Web Local Storage” test are polychrome – but images in “Sprites”, “Data URI” and “SVG image” could have been too.

example

Mobile Web sites are geared towards delivering synthetic information on displays constrained in size, for immediate interactions in all situations of daily life. Pictograms stand out from the surrounding text, and thus quickly draw attention towards important content; they identify data elements, making it easier to skim a page for an item of interest; they supplement styling attributes such as colour and font when these become inapplicable (monochrome display, disabled CSS).

However, pictograms may impair accessibility when the client software can neither handle them directly, nor map them to another appropriate representation (such as a vocal enunciation of the associated concept). Thus, screen readers are often confused by icon typefaces overriding the standard semantics of their underlying code points – such as when letter O serves to depict a clock. Developers can keep Web pages containing pictograms accessible in the following ways:

Support for ISO pictographs is becoming common in newer smartphones, but equivalent effects can be achieved on less well-endowed devices thanks to the methods explained in this article. Hence, nothing more prevents developers from taking advantage of pictograms to improve their mobile Web sites.

Acknowledgements

Many thanks to Sriram Sridharan from ScientiaMobile Inc. for his help in testing Internet Explorer Mobile.

Reference

A version of this paper was published at mobiforge.com.

It is PDFdownloadable as a PDF document.

First published: 2013-02-11.