HTML5 elements and attributes support in Amazon Silk
Amazon Silk supports many of the HTML5 elements and attributes. Though not intended to be comprehensive, the list below describes supported elements and attributes and notes Amazon Silk-specific implementation details, if applicable.
Topics
Audio Element
The <audio> element makes it possible to embed audio files directly
      in a web page without using plug-ins. By nesting <source> elements within
      an <audio> element, you can reference multiple file types.
<h1>HTML5 Audio Element</h1> <audio controls> <source src="Media/audio_sample.ogg" type="audio/ogg"> <source src="Media/audio_sample.mp3" type="audio/mpeg"> Sorry. Your browser doesn't support the HTML5 audio element. </audio>
The sample code above produces the player control shown below:
          
          
         
      For more information, see the W3C
        audio element wiki
Canvas Element
You can use the <canvas> element to draw two-dimensional graphics on
      a web page. Use the <canvas> element to create a container for a graphic,
      and then render the graphic itself on the fly using JavaScript.
For more information, see the HTML Canvas 2D
        Context specification
contenteditable Attribute
Setting the contendeditable attribute to "true" makes a text element on your
      web page available for the user to edit. You can also use the localStorage object
      to save the user's changes, effectively turning your web page into a text editor. 
For more information, see Mozilla
        Developer Network: Content Editable
Input Types
In HTML5, you can use input types to make forms more responsive to mobile clients. By
      specifying in your markup the type of input required, you can trigger the mobile device to
      display an appropriate virtual keyboard. Amazon Silk supports this functionality. For example, if
      you set the type attribute to "email", Amazon Silk displays a virtual
      keyboard featuring the @ and .com keys, which make
      the keyboard more user-friendly for typing an email address.
<form> Email: <input type="email" name="email"><br> <input type="submit" value="Sign Up"> </form>
The Silk virtual keyboard is shown below:
          
          
         
      For more information, see Making Forms Fabulous with
        HTML5
Keygen Element
The <keygen> element specifies a form field for securely
      authenticating users. When the form containing the <keygen> element is
      submitted, a public/private key pair is generated. The key pair can be used as part of a
      certificate authentication system. 
For more information about the <keygen> element, see HTML/Elements/keygen
Meter Element
You can use the <meter> element to measure data within a given range.
      It specifies a fractional value or gauge. For example, you could use the
        <meter> element to gauge hard disk usage.
<p>Hard Disk Usage: <meter min="0" value="239" max="296">239 GB used out of 296 GB total</meter></p>
The sample code above produces the gauge below:
          
          
         
      For more information, see HTML/Elements/meter
Output Element
The <output> element represents the result of a calculation. Although
      the <output> element is associated with a form, it doesn't have to be a
      child of the form. You can collect input for a calculation in a form, and then use the
        <output> element to display the results of the calculation elsewhere in
      the document. In the following example, the <output> element displays the
      sum of the values entered into the two input fields:
<form oninput="pets.value=parseInt(dogs.value)+parseInt(cats.value)"> No. of dogs <input type="number" id="dogs" value="0"><br> No. of cats <input type="number" id="cats" value="0"><br> Total no. of pets: <output name="pets" for="dogs cats"></output> </form>
Here's how the markup looks in Silk, after a user enters values in the input fields:
          
          
         
      Note that the oninput event is not supported by Silk Gen 1. For more on the
        <output> element, see HTML/Elements/output
Progress Element
The <progress> element represents progress toward completion of some
      task, like a file download. 
      
      
      You can use the <progress> tag together with
      JavaScript to create a progress display.
<div>File downloading: <progress value="70" max="100">70%</progress></p></div> <div>Silk supports the HTML5 progress element.</div>
The sample code above produces the progress display shown below:
          
          
         
      For more information, see HTML/Elements/progress
SVG Element
Scalable Vector Graphics (SVG) is an XML-based format for describing two-dimensional web
      graphics. Amazon Silk supports SVG both inline via the <svg> tag and
      externally using the <img>, <object>, and
        <embed> tags. The example below creates an SVG rendering of a rectangle
      with a horizontal linear gradient. The image shows the result rendered by Silk.
<html> <body> <svg width="180" height="120"> <defs> <linearGradient id="gradient" x1="0%" y1="0%" x2="100%" y2="0%"> <stop offset="0%" style="stop-color:rgb(255,255,255);stop-opacity:1.0" /> <stop offset="100%" style="stop-color:rgb(0,0,255);stop-opacity:0.75" /> </linearGradient> </defs> <rect x="10" y="10" width="160" height="100" style="fill:url(#gradient)"> </svg> </body> </html>
          
          
         
      To learn more about SVG, visit the W3C SVG
        Working Group
Video Element
The <video> element makes it possible to embed video files directly in
      a web page without using plug-ins. By nesting <source> tags within a
        <video> element, you can reference multiple file types.
<h1>HTML5 Video Element</h1> <video width="320" height="240" controls> <source src="Media/video_sample.mp4" type="video/mp4"> <source src="Media/video_sample.ogv" type="video/ogg"> <source src="Media/video_sample.webm" type="video/webm"> Sorry. Your browser doesn't support the HTML5 video element. </video>
The sample code above produces the player control shown below:
          
          
         
      For more information, see the W3C
        video element wiki