user:cmglee/Dynamic SVG for Wikimedia projects

File:Bid Wikimania Esino Lario 2016 slides 07 SMIL.svg|thumb|400px|Interactive map of [http://wikimania2016.wikimedia.org/wiki/Program_site_visit_9-10_May_2015 Wikimania 2016 venues] using SMIL and CSS

default [http://upload.wikimedia.org/wikipedia/commons/7/7c/Bid_Wikimania_Esino_Lario_2016_slides_07_SMIL.svg]

This article describes an initiative by user:cmglee to explore techniques to employ dynamic Scalable Vector Graphics to enhance content on Wikimedia projects.

Rationale

class="wikitable floatright" width="1"

|+ style="font-weight:normal;"|SVG feature compatibility in most common Web browsers in descending popularity from left to right, and version from top to bottom, as listed on caniuse.com as of 16 Jan 2016

{{magenta|S}} = SMIL not supported
{{red|C}} = CSS animation not supported

! Chrome !! Chrome for Android !! Internet Explorer !! Firefox !! IOS Safari !! Opera Mini !! Android Browser

 8 {{magenta|S}} {{red|C}}4.3
45 9 {{magenta|S}} {{red|C}}4.4
4610 {{magenta|S}}428.44.4.4
style="color:#000000; background:#ffff99;"

| 47

4711 {{magenta|S}}439.2{{magenta|S}} {{red|C}}46
48449.3
4945
5046

Though Wikimedia projects such as Wikipedia, Wikibooks and Wikiversity are excellent in describing concepts textually and graphically, some are better explained interactively, such as when comparing members of a set or showing components of a system. We have been traditionally limited to video clips and GIF animations but now that Scalable Vector Graphics (SVG) is becoming well-supported in web browsers (see table),http://caniuse.com/#feat=svghttp://caniuse.com/#search=css-animationhttp://caniuse.com/#feat=svg-smil the author believes that these Wikimedia projects stand to gain by exploring ways to enhance articles with dynamic SVG.

JavaScript or ECMAScript allow almost limitless interactivity, but uploads with it are barred, understandably for security reasons — on popular sites like Wikipedia, cross-site scripting issues are a concern. Fortunately, SVG provides two other techniques for interactivity and animation, each of which has its pros and cons:

  1. Synchronized Multimedia Integration Language (SMIL), and
  2. Cascading Style Sheets (CSS).

The author has explored applications, techniques and best practice for the last two years and contributed over 300 SVGs, some with animated and interactive, and aim to create demonstrations and tutorials to allow users to create their own dynamic content.

The following are some areas identified. As the author is learning as he goes along, some of his images, especially earlier work, violate his own guidelines, so the developer is requested to exercise caution when studying the examples provided.

Animation

SVG animations show how a system changes with time and are an alternative to video clips. Advantages are

  1. Has much smaller file size,
  2. Can be enlarged without getting blocky, and
  3. Potentially allows interaction besides pause and seek.

= Non-interactive animation =

The simplest type of animation starts running automatically and optionally repeats. Examples:

style="text-align:center;vertical-align:bottom;"

|

File:Circles2ellipseAnimated.svg|thumb|none|One-off animation using SMIL

default [https://upload.wikimedia.org/wikipedia/commons/a/a3/Circles2ellipseAnimated.svg]

|

File:Absolute_World_Tower_1_massing_model.svg|thumb|upright|none|Endless animation using CSS demonstrating pseudo-3D rotation

default [http://upload.wikimedia.org/wikipedia/commons/4/4c/Absolute_World_Tower_1_massing_model.svg]

|

File:Circulatory_system_SMIL.svg|thumb|none|Endless SMIL animation demonstrating change in transformation and CSS attributes

default [http://upload.wikimedia.org/wikipedia/commons/c/c2/Circulatory_system_SMIL.svg]

|

File:Toy_train_SMIL.svg|thumb|none|Endless SMIL demonstrating motion along a path and simulation of 3D

default [http://upload.wikimedia.org/wikipedia/commons/b/ba/Toy_train_SMIL.svg]

As the author wrote in the SVG animation article, the following code snippets demonstrate two techniques to create animated SVG on compatible browsers. The relevant parts are in bold green.

== SVG animation using SMIL ==

{{float right clear none|

File:SVG_animation_using_SMIL.svg|200px

default [http://upload.wikimedia.org/wikipedia/commons/b/b9/SVG_animation_using_SMIL.svg]

}}

<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">

<svg version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"

width="100%" height="100%" viewBox="-4 -4 8 8">

<title>SVG animation using SMIL</title>

<circle cx="0" cy="1" r="2" stroke="red" fill="none">

<animateTransform

attributeName="transform"

attributeType="XML"

type="rotate"

from="0"

to="360"

begin="0s"

dur="1s"

repeatCount="indefinite"/>

</circle>

</svg>

== SVG animation using CSS ==

{{float right clear none|

File:SVG_animation_using_CSS.svg|200px

default [http://upload.wikimedia.org/wikipedia/commons/8/87/SVG_animation_using_CSS.svg]

}}

<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">

<svg version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"

width="100%" height="100%" viewBox="-4 -4 8 8">

<title>SVG animation using CSS</title>

<style type="text/css">

@keyframes rot_kf { from { transform: rotate(0deg); }

to { transform: rotate(360deg); } }

@-moz-keyframes rot_kf { from { -moz-transform: rotate(0deg); }

to { -moz-transform: rotate(360deg); } }

@-webkit-keyframes rot_kf { from { -webkit-transform: rotate(0deg); }

to { -webkit-transform: rotate(360deg); } }

.rot { animation: rot_kf 1s linear infinite;

-moz-animation: rot_kf 1s linear infinite;

-webkit-animation: rot_kf 1s linear infinite; }

</style>

<circle class="rot" cx="0" cy="1" r="2" stroke="blue" fill="none"/>

</svg>

Note: the -moz and -webkit styles are pre-CSS3 browser-specific styles.

= Interactive animation =

Interactivity can be easily combined with animation. The Interactivity section describes interactivity in more detail. Example:

style="text-align:center;vertical-align:bottom;"

|

File:Moon_landing_sites.svg|thumb|none|CSS animation highlighting features of interest on hover and linking to Wikipedia on click

default [http://upload.wikimedia.org/wikipedia/commons/3/34/Moon_landing_sites.svg]

Interactivity

The real power of dynamic SVG comes from interactivity. At its simplest, tooltips can display supplementary information, or with cunning trickery, one can write a simple applet, such as these examples:

style="text-align:center;vertical-align:bottom;"

|

File:Subtraction_game_SMIL.svg|thumb|none|The 21 game with AI using SMIL

default [http://upload.wikimedia.org/wikipedia/commons/4/4d/Subtraction_game_SMIL.svg]

|

File:SMIL_missile_demo.svg|thumb|none|A simple action game implemented in SMIL

default [http://upload.wikimedia.org/wikipedia/commons/9/9b/SMIL_missile_demo.svg]

= Tooltips =

Neither CSS nor SMIL is needed — four methods have been identified:

  1. Title tag — the recommended method, supported on all Chrome, Firefox and Internet Explorer: add an attribute TOOLTIP TEXT inside an element, such as TOOLTIP TEXT to show "TOOLTIP TEXT" in a tooltip when the user hovers over the element. Newlines can be inserted using \n but Internet Explorer shows them as spaces.
  2. Anchor link, supported on all Chrome, Firefox and Internet Explorer: enclose the element in a hyperlink (described in the section below) to an non-existent anchor in the same document e.g. <a xlink:href="#MESSAGE"> … </a> — highest compatibility though the text is not displayed adjacent to the element, and includes the URL of the SVG.
  3. Embedded custom cursor, supported on Chrome and Firefox: Base64-encode a 32×32 image and include it in the cursor attribute of the element, e.g. cursor="url(),auto" — tedious to generate and not easily changed though allows an image to be displayed.
  4. CSS hover selector: add a transparent SVG element as a child of the element and a CSS :hover selector in its style to make it visible. pointer-events:none; prevents the invisible tooltip itself triggering the hover effect. The element can be any SVG element — not necessarily text. A drawback is that CSS is needed, but all Chrome, Firefox and Internet Explorer support it. Example stylesheet:

::

Examples:

style="text-align:center;vertical-align:bottom;"

|

File:Sexagenary_cycle_years.svg|thumb|none|Using multiline titles with Chinese characters and highlighting on hover

default [http://upload.wikimedia.org/wikipedia/commons/e/e0/Sexagenary_cycle_years.svg]

|

File:Pi_tau_digit_runs.svg|thumb|none|Using titles and anchor links to show digits' decimal place (position) on hover

default [http://upload.wikimedia.org/wikipedia/commons/a/ae/Pi_tau_digit_runs.svg]

|

File:Earth_heat_balance_Sankey_diagram.svg|thumb|none|Using custom cursors to show number of units on hover

default [http://upload.wikimedia.org/wikipedia/commons/2/29/Earth_heat_balance_Sankey_diagram.svg]

|

File:Comparison_gender_life_expectancy_CIA_factbook.svg|thumb|none|Using CSS and titles on hover

default [http://upload.wikimedia.org/wikipedia/commons/b/b2/Comparison_gender_life_expectancy_CIA_factbook.svg]

= Progressive disclosure =

Some infographics are better absorbed in small bites!

Changing an element's appearance when the user moves the mouse pointer over it can be done in CSS, but responding to clicks (other than on hyperlinks) requires SMIL, which is not supported on Internet Explorer.

In the :File:Comparison_of_pyramids.svg example above, the overlapping shapes can appear overwhelming. Highlighting just the pyramid hovered over lets the user see its shape much more clearly. :File:CIE1931xy_ColorChecker_SMIL.svg below takes it a step further: SMIL allows an object to change state when clicked, so that the user can select any combination of objects to compare. The objects toggled need not be the objects clicked. The :File:Milky_Way_multispectral_SMIL.svg example demonstrates mixing photographs taken at different wavelengths of light by clicking on thumbnails.

Complex graphs, too, can benefit from progressive disclosure. In :File:Doubling_time_vs_half_life.svg below, individual graphs can be isolated to aid readability.

style="text-align:center;vertical-align:bottom;"

|

File:CIE1931xy_ColorChecker_SMIL.svg|thumb|none|Hover over a colour swatch to highlight it; click it to select and deselect it (SMIL + CSS)

default [http://upload.wikimedia.org/wikipedia/commons/b/b4/CIE1931xy_ColorChecker_SMIL.svg]

|

File:Milky_Way_multispectral_SMIL.svg|thumb|none|Click a thumbnail in the SVG to add/remove it from the mix (SMIL)

default [http://upload.wikimedia.org/wikipedia/commons/1/1e/Milky_Way_multispectral_SMIL.svg]

|

File:Doubling_time_vs_half_life.svg|thumb|none|Hover over a graph to highlight it (CSS)

default [http://upload.wikimedia.org/wikipedia/commons/8/88/Doubling_time_vs_half_life.svg]

|

File:Tower_of_Hanoi_recursion_SMIL.svg|thumb|none|upright|Click to expand and collapse parts (SMIL)

default [http://upload.wikimedia.org/wikipedia/commons/2/20/Tower_of_Hanoi_recursion_SMIL.svg]

The following code combines CSS and SMIL for maximum compatibility and functionality, and demonstrates how two selectable objects can be created, the first initially unselected and the second preselected. The opacity values can be tweaked to taste.

...

Tooltip for object1

Tooltip for object2

File:6-set_Venn_diagram_SMIL.svg|thumb|Sample SVG with annotated code

default [http://upload.wikimedia.org/wikipedia/commons/5/56/6-set_Venn_diagram_SMIL.svg]

With reference to the code of the sample SVG on the right, the #main:hover style fades the image when elements in it are hovered over, providing greater contrast for selected elements. The nofade class is applied to elements which should not fade such as the background and user interface elements.

Each selectable object has up to four elements:

  1. A base part (suffixed "b") provides its unselected appearance and a trigger to click to select it
  2. An active part (suffixed "a") provides its selected appearance and a trigger to click to deselect it.
  3. An optional tooltip appears when the object is hovered over.
  4. An optional hyperlink loads a URL when clicked.

The base and active parts can be two instances of the same object (such as a triangle or bridge silhouette in the :File:6-set_Venn_diagram_SMIL.svg or :File:Comparison_of_notable_bridges_SMIL.svg examples), or separate objects (such as the glow and photograph mix in :File:Milky_Way_multispectral_SMIL.svg). For the former, the object can be defined separately and instanced using use tags.

The active part is initially hidden by default and is revealed when the base part is clicked. Appending ;0s to an object's set tag selects it by default, as in the example code for object2a above. When the revealed active part is clicked, it hides itself. The cursor is also appropriately changed to reflect the object's state in Firefox and Chrome.

As Internet Explorer does not support SMIL, a CSS hover effect is added to highlight the base part when the user hovers over it.

style="text-align:center;vertical-align:bottom;"

|

File:Demo_group_highlighting_SMIL.svg|thumb|left|Demonstration SVG using groups

default [http://upload.wikimedia.org/wikipedia/commons/e/e0/Demo_group_highlighting_SMIL.svg]

|

File:Bid Wikimania Esino Lario 2016 slides 07 SMIL.svg|thumb|Interactive map with groups of selectable objects

default [http://upload.wikimedia.org/wikipedia/commons/7/7c/Bid_Wikimania_Esino_Lario_2016_slides_07_SMIL.svg]

|

File:US_state_historical_population_FRED_SMIL.svg|thumb|Interactive semi-log plot of historical population of the 50 states of USA and the District of Columbia from 1900 to 2015

default [https://upload.wikimedia.org/wikipedia/commons/f/f3/US_state_historical_population_FRED_SMIL.svg]

It is possible to group selectable objects by category, as in this demo and interactive map; each group button highlights/selects all its members. The interactive map also shows how certain elements (such as the lines joining the map locations with its photo) can be made unresponsive to hover or click by adding pointer-events:none; to their styles to avoid flashing when the pointer briefly passes over them.

The SVG can be modified to deselect members on a second click, as in the above graph, but its use may be unintuitive: if the user clicks the group button to select the entire group then manually deselects each member, the group will still be selected, and clicking the button again appears to do nothing. It should decrement a counter and turn off the group button when every member has been deselected and vice versa, but the author does not know of a way to do this.

= Interactive timelines =

While animations are often enough to show changes in a system through time, it is sometimes useful to let the user move through it at his or her own pace, even in a non-linear fashion. The :File:Evolution_of_the_European_Union_SMIL.svg example below lets the user highlight countries by year of accession or departure. The simpler :File:BlueMarble_monthlies_SMIL.svg lets the user jump to specific frames of a sequence by hovering over the appropriate part of the graphic.

style="text-align:center;vertical-align:bottom;"

|

File:Evolution_of_the_European_Union_SMIL.svg|thumb|none|Hover over or click buttons on the timeline to shade and unshade countries (SMIL + CSS)

default [http://upload.wikimedia.org/wikipedia/commons/6/6c/Evolution_of_the_European_Union_SMIL.svg]

|

File:Chinese_new_year_dates_SMIL.svg|thumb|none|Hover over or click a year on the left to highlight its graph (SMIL + CSS)

default [http://upload.wikimedia.org/wikipedia/commons/9/96/Chinese_new_year_dates_SMIL.svg]

|

File:Ideal_projectile_motion_for_different_angles.svg|thumb|none|Hover over the legend to step through time (CSS)

default [http://upload.wikimedia.org/wikipedia/commons/6/61/Ideal_projectile_motion_for_different_angles.svg]

|

File:Non-Native_American_Nations_Control_over_N_America_1750-2008_SMIL.svg|thumb|none|Hover over the timeline to step through time (SMIL)

default [http://upload.wikimedia.org/wikipedia/commons/7/73/Non-Native_American_Nations_Control_over_N_America_1750-2008_SMIL.svg]

= Simple 3D viewer =

At a Cambridge Wikimedia meetup, a participant suggested that photographs of 3-dimensional artifacts could be displayed as part of a GLAM initiative. There are certainly QuickTime VR and Adobe Flash-based viewers, but these tend to be proprietary. The author has created two prototypes below: one of a rendered globe and the other a museum piece, which lets the user virtually rotate an object but lacks support for zoom and drag.

style="text-align:center;vertical-align:bottom;"

|

File:Anubis_Mask_from_Harrogate_3D_SMIL.svg|thumb|none|A large composite of multiple frames tracks the mouse pointer (SMIL)

default [http://upload.wikimedia.org/wikipedia/commons/4/40/Anubis_Mask_from_Harrogate_3D_SMIL.svg]

|

File:Earth_orthographic_projection_SMIL.svg|thumb|none|At the top and bottom rows, the respective pole's image is shown and rotated according to the pointer's position; elsewhere, a large composite of multiple frames tracks the mouse pointer (SMIL)

default [http://upload.wikimedia.org/wikipedia/commons/2/2e/Earth_orthographic_projection_SMIL.svg]

|

File:Hawaii_Island_topographic_map_SMIL.svg|thumb|none|Each contour line is rotated corresponding to the pointer's position, then moved upwards and vertically scaled (SMIL)

default [http://upload.wikimedia.org/wikipedia/commons/2/29/Hawaii_Island_topographic_map_SMIL.svg]

|

File:Comparison_oloid_sphericon_3D.svg|thumb|none|Each frame is a separate image which initially has zero opacity; when its trigger is hovered over, the opacity is set to 1 (CSS only, so works in IE)

default [http://upload.wikimedia.org/wikipedia/commons/1/1d/Comparison_oloid_sphericon_3D.svg]

= GIF animation to SVG converter =

The author has written the Python script below which uses ImageMagick to download a GIF animation, extract its frames as PNGs and compile Base64-encoded versions into an SVG with a row of thumbnails at the bottom.

class="wikitable collapsible collapsed" style="font-size:75%;width:100%;"

! Python 2 source code

  1. !/usr/bin/env python

import re, json

  1. http://stackoverflow.com/questions/3503879

import subprocess, sys

def system(command, is_verbose=False):

if (is_verbose): sys.stdout.write(command) ## write omits newline

stdout = subprocess.check_output(command, shell=True)

if (is_verbose): print(": " + stdout)

return stdout

import os.path ## to check if file exists

def mkdir_cache(is_refresh_cache=False, is_verbose=False, suffix='.cache/'):

basename = __file__[:__file__.rfind('.')]

dir_cache = basename + suffix

if (is_refresh_cache):

for (dir, dirs, filenames) in os.walk(dir_cache, topdown=False): os.rmdir(dir)

if (is_verbose): print("delete {dir_cache}".format(**locals()))

if (not os.path.exists(dir_cache)):

if (is_verbose): print("make {dir_cache}".format(**locals()))

os.makedirs(dir_cache)

elif (is_verbose): print("{dir_cache} already exists".format(**locals()))

return dir_cache

  1. http://www.techrepublic.com/article/parsing-data-from-the-web-in-python/

import urllib2, time ## urllib2 for web access, time for sleep

def read_webpage(url, path_cache='', is_refresh_cache=False, is_verbose=False):

dir_cache = mkdir_cache(is_refresh_cache=is_refresh_cache, is_verbose=is_verbose)

if (not path_cache): path_cache = dir_cache + urllib2.quote(url, safe='')

if (is_refresh_cache or (not os.path.isfile(path_cache))):

html = urllib2.urlopen(url).read()

file_html = open(path_cache, 'wb')

file_html.write(html)

if (is_verbose): print("fetch {url} into {path_cache}".format(**locals()))

time.sleep(1) ## avoid rate-limit-exceeded error

else:

file_html = open(path_cache)

html = file_html.read()

if (is_verbose): print("read from {path_cache}".format(**locals()))

file_html.close()

return html

  1. http://stackoverflow.com/questions/3715493

import base64

def base64_encode(path):

with open(path, 'rb') as file: return base64.b64encode(file.read())

def make_svg(url, increment, message_action):

if (message_action == '3D' ): message_action = 'to rotate the 3D model'

if (message_action == 'time'): message_action = 'to move through time'

## Get image URL if description page URL given

dir_cache = mkdir_cache()

filename = url[url.rfind('/')+1:]

if (filename.lower().find('file:') == 0):

filename = filename[filename.rfind(':') + 1:]

path_html = '{dir_cache}{filename}.htm'.format(**locals())

html = read_webpage(url, path_html, is_verbose=True)

url = re.search(r'http.*?//upload\.[^"]+', html).group(0)

## Fetch image if needed

basename = filename[:filename.rfind('.')]

path_gif = dir_cache + filename

path_basename = path_gif[:path_gif.rfind('.')]

read_webpage(url, path_gif, is_verbose=True)

## Extract GIF animation frames if needed

if (os.path.isfile('{dir_cache}{basename}-0.png'.format(**locals()))):

print("skip extracting GIF animation frames")

else:

print("extract GIF animation frames")

system('magick "{path_gif}" -coalesce "{path_basename}.png"'.format(**locals()), is_verbose=True)

## Base64-encode frames if needed

path_json = dir_cache + basename + '.json'

jsons = {}

n_image = 0

n_frame = 0

if (0):

# if (os.path.isfile(path_json)):

file_json = open(path_json, 'r')

jsons = json.loads(file_json.read())

n_frame = jsons['n_frame']

out_image = jsons['out_image']

width_image = jsons['width_image']

height_image = jsons['height_image']

else:

## Count frames

n_image = 0

while (os.path.isfile('{dir_cache}{basename}-{n_image}.png'.format(**locals()))): n_image += 1

## Base64-encode relevant frames

n_frame = int(n_image / abs(increment))

out_images = []

for i_frame in range(n_frame):

i_image = i_frame * increment + (0 if (increment > 0) else n_image + increment)

path_frame = '{dir_cache}{basename}-{i_image}.png'.format(**locals())

stdout = system('magick "{path_frame}" info:'.format(**locals()), is_verbose=True)

(width_image, height_image) = [int(dim) for dim in re.search(r'\d+x\d+', stdout).group(0).split('x')]

base64_encoded = base64_encode(path_frame)

out_images.append('''\

\

'''.format(**locals()))

out_image = '\n'.join(out_images)

jsons = {'out_image':out_image, 'width_image' :width_image,

'n_frame' :n_frame , 'height_image':height_image}

file_json = open(path_json, 'w')

try: ## use try/finally so that file is closed even if write fails

file_json.write(json.dumps(jsons, indent=1, separators=(',',':')))

finally:

file_json.close()

## Create SVG

out_mains = []

scale_thumbnail = round(1.0 / n_frame, 5)

height_trigger = int(height_image * (scale_thumbnail + 1) + 0.5)

width_trigger = round(width_image * scale_thumbnail, 2)

width_thumbnail = int(width_trigger + 0.9999)

for i_frame in range(n_frame):

x_trigger = round(i_frame * width_trigger, 2)

out_mains.append('''\

'''.format(**locals()))

out_main = '\n'.join(out_mains)

title = basename.replace('_', ' ')

stroke_width = max(width_image, height_image) / 200

font_size = width_image / 20

x_help = width_image / 2

y_help = height_image / 2

height_thumbnail = height_image * scale_thumbnail - stroke_width / 2

width_images = [width_image * multiple for multiple in range(99)]

## Compile everything into an .svg file

file_out = open(basename + '.svg', 'w')

try: ## use try/finally so that file is closed even if write fails

print("write SVG")

file_out.write('''

{title}

Interactive SVG by CMG Lee of the GIF animation at {url} . Move left and right over the SVG image {message_action}.

Move left and right

{message_action}

{out_image}

{out_main}

'''.format(**locals()))

finally:

file_out.close()

n_argv = len(sys.argv)

if (n_argv < 2):

print(("usage: {sys.argv[0]} [

" negative reverses order>] []")

.format(**locals()))

else:

make_svg( sys.argv[1],

int(sys.argv[2]) if (n_argv > 2) else 1,

sys.argv[3] if (n_argv > 3) else '3D')

Moving left and right over the SVG image rotates the 3D model. As it uses CSS (no SMIL), it supports Internet Explorer. Below are some fields of study that can benefit:

style="text-align:center;vertical-align:bottom;"

|

File:AdenosineTriphosphate.qutemol.svg|thumb|none|Chemistry

default [http://upload.wikimedia.org/wikipedia/commons/e/e0/AdenosineTriphosphate.qutemol.svg]

|

File:Everest_3D.svg|thumb|none|Geography

default [http://upload.wikimedia.org/wikipedia/commons/e/e8/Everest_3D.svg]

|

File:Diamond_structure_animation.svg|thumb|none|Mathematics/crystallography

default [http://upload.wikimedia.org/wikipedia/commons/5/5b/Diamond_structure_animation.svg]

|

File:ESA_Rosetta_OSIRIS_67P_SHAP2.svg|thumb|none|Astronomy

default [http://upload.wikimedia.org/wikipedia/commons/1/1f/ESA_Rosetta_OSIRIS_67P_SHAP2.svg]

File:Rotating_brain_colored.svg|thumb|none|Anatomy/biology

default [https://upload.wikimedia.org/wikipedia/commons/1/11/Rotating_brain_colored.svg]

|

File:SdKfz_250-3_I_(Neu)_(3D-animated).svg|thumb|none|Mechanical engineering/history

default [http://upload.wikimedia.org/wikipedia/commons/a/a2/SdKfz_250-3_I_%28Neu%29_%283D-animated%29.svg]

|

File:Cassini-Huygens animation.svg|thumb|none|Aerospace engineering/technology

default [https://upload.wikimedia.org/wikipedia/commons/3/37/Cassini-Huygens_animation.svg]

|

File:Tensegrity_simple_4.svg|thumb|none|Structural engineering/physics

default [http://upload.wikimedia.org/wikipedia/commons/0/04/Tensegrity_simple_4.svg]

Some categories containing GIF animations that can be converted are

User:Shyamal suggested using it to navigate through a timeline. Additionally, it can be used to control the position of an object in the scene. As examples, I've converted the following:

style="text-align:center;vertical-align:bottom;"

|

File:Colonisation2.svg|thumb|none|History

default [http://upload.wikimedia.org/wikipedia/commons/c/c9/Colonisation2.svg]

|

File:Solar_eclipse_animate_(2017-Aug-21).svg|thumb|none|Astrophysics

default [http://upload.wikimedia.org/wikipedia/commons/3/3c/Solar_eclipse_animate_%282017-Aug-21%29.svg]

|

File:Contra-zoom_aka_dolly_zoom_animation.svg|thumb|none|Physics/optics

default [http://upload.wikimedia.org/wikipedia/commons/2/2a/Contra-zoom_aka_dolly_zoom_animation.svg]

|

File:Beta_stirling_animation.svg|thumb|none|Mechanical engineering/thermodynamics

default [http://upload.wikimedia.org/wikipedia/commons/1/12/Beta_stirling_animation.svg]

Limitations

= Backward compatibility =

Thumbnails are often used to link to a media file, and so the SVG should be presentable when rendered as a thumbnail and on browsers which support SVG but not animations or interactivity. One method the author has used is to first create a static SVG, but leaving space or structuring the code for dynamic parts to be added later.

A link can be added to the thumbnail caption to inform the user that an interactive version is available, as in this example:

{{wide image|comparison_of_notable_bridges_SMIL.svg|600px|Comparison of the side elevations of some notable bridges at the same scale. [http://upload.wikimedia.org/wikipedia/commons/3/37/Comparison_of_notable_bridges_SMIL.svg (click for interactive version)]}}

As CSS is more widely supported than SMIL, CSS methods are preferred, where possible. For example, in :File:Comparison_of_notable_bridges_SMIL.svg above, CSS hover effects are used to highlight a bridge profile or label when the user moves the mouse-pointer over it. If his or her Web browser supports SMIL, the profile or label can also be clicked to keep it highlighted. This lets Internet Explorer users use the hover effect while letting Chrome users use both hover and click.

= Touchscreen support =

Most tablets and smartphones break the hover and click model as it is almost impossible (except by clicking and cancelling the "Open with" menu) to hover without also clicking. The :File:Comparison_of_notable_bridges_SMIL.svg example above puts the link to the bridges' Wikipedia articles in an icon button. As both hover and click highlight a bridge, the touchscreen user can operate the user interface without handicap.

= Editor support =

As the author handcrafts his SVG files (or write Python or Perl programs to generate them), they are currently not editable on editors such as Inkscape. The author will endeavour to provide support for at least Inkscape if this project takes off.

See also

  • [http://en.wikibooks.org/wiki/XML_-_Managing_Data_Exchange/SVG SVG tutorial at Wikibooks]
  • [http://de.wikibooks.org/wiki/SVG Extensive SVG tutorial in German at Wikibooks]
  • [http://en.wikiversity.org/wiki/Web_Design/CSS3_Animations CSS3 animations tutorial at Wikiversity]

References