Skip to content

HTTPS clone URL

Subversion checkout URL

You can clone with HTTPS or Subversion.

Download ZIP
Browse files

Merge pull request #14 from astanley/master

code cleanup and updates to README files
  • Loading branch information...
commit dae7c524f5535411509a3a60bf6246ca3950fd36 2 parents edc71b3 + 2a0ffe2
Ken Wallis authored
Showing with 499 additions and 263 deletions.
  1. +9 −8 Aura/README.md
  2. +7 −14 kitchenSink/README.md
  3. +1 −1  kitchenSink/config.xml
  4. +8 −1 kitchenSink/css/styles.css
  5. +4 −4 kitchenSink/html/apis/audioplayer.html
  6. +4 −4 kitchenSink/html/apis/microphone.html
  7. +1 −1  kitchenSink/html/apis/utils.html
  8. BIN  kitchenSink/html/browser/Thumbs.db
  9. +6 −7 kitchenSink/html/browser/data.xml
  10. +4 −4 kitchenSink/html/browser/flashplayer.html
  11. +18 −12 kitchenSink/html/browser/formfields.html
  12. +7 −7 kitchenSink/html/browser/gps.html
  13. +2 −1  kitchenSink/html/browser/keyevents.html
  14. +0 −16 kitchenSink/html/browser/orientation.html
  15. +2 −2 kitchenSink/html/browser/protocols.html
  16. +6 −6 kitchenSink/html/browser/schemes.html
  17. +0 −1  kitchenSink/html/browser/touch.html
  18. +54 −0 kitchenSink/html/browser/typedarrays.html
  19. +4 −4 kitchenSink/html/browser/useragent.html
  20. +3 −3 kitchenSink/html/browser/viewport/densitydpi.html
  21. +1 −1  kitchenSink/html/browser/viewport/noscale.html
  22. +1 −1  kitchenSink/html/browser/viewport/scale2.html
  23. +1 −1  kitchenSink/html/browser/viewport/scalemax.html
  24. +1 −1  kitchenSink/html/browser/viewport/scalemin.html
  25. BIN  kitchenSink/html/css3/Thumbs.db
  26. +7 −2 kitchenSink/html/css3/animation.html
  27. +3 −3 kitchenSink/html/css3/animations.html
  28. +9 −7 kitchenSink/html/css3/mediaquery.html
  29. +12 −7 kitchenSink/html/css3/sprite.html
  30. +23 −23 kitchenSink/html/css3/transformations.html
  31. +2 −1  kitchenSink/html/debug/firebuglite.html
  32. +6 −11 kitchenSink/html/debug/ripple.html
  33. +3 −3 kitchenSink/html/debug/webinspector.html
  34. +9 −1 kitchenSink/html/html5/file.html
  35. +30 −11 kitchenSink/html/html5/inputtypes.html
  36. +2 −2 kitchenSink/html/html5/offline.html
  37. +1 −1  kitchenSink/html/html5/video.html
  38. +2 −2 kitchenSink/html/html5/websockets.html
  39. +24 −20 kitchenSink/html/html5/workers.html
  40. +14 −10 kitchenSink/html/usecase/progress.html
  41. BIN  kitchenSink/img/screenshots/enable_ripple.jpg
  42. BIN  kitchenSink/img/screenshots/use_ripple.jpg
  43. +52 −51 kitchenSink/index.html
  44. +148 −0 kitchenSink/js/browser/typedarrays.js
  45. +8 −8 payment/README.md
17 Aura/README.md
View
@@ -30,16 +30,17 @@ The sample code for this application is Open Source under the [Apache 2.0 Licens
To build the Aura sample application:
-1. Click on the **Downloads** button at the top right of this screen.
-2. Select **Download.zip** and save the downloaded file to your local machine.
-3. Create a new folder on your local machine named **Aura** (e.g. **c:\webworks\Aura**).
-4. Open the downloaded ZIP file from step 2 and **extract the contents from inside the top level folder** to your new **Aura** folder. This ensures that the necessary application assets, such as **config.xml**, are correctly located at the top level of the **Aura** folder (e.g. **c:\webworks\Aura\config.xml**).
-5. Using an achiving utility (e.g. WinZip or 7-zip), package the contents of your **c:\webworks\Aura** folder into a ZIP archive named **Aura.zip**. This archive should have the application assets (not a folder containing the application assets) at its top level.
-6. Using the **[BlackBerry WebWorks SDK for Tablet OS](http://us.blackberry.com/developers/tablet/webworks.jsp)**, package the **Aura.zip** archive into a BlackBerry Tablet OS application using the following command line: **bbwp c:\webworks\Aura\Aura.zip**
+1. Click on the **Downloads** tab above.
+2. Select **Download as zip** (Windows) or **Download as tar.gz** (Mac) and save the downloaded file to your local machine.
+3. Create a new folder on your local machine named **Aura** e.g. **C:\Documents and Settings\User\WebWorks\Aura** (Windows) or **~/WebWorks/Aura** (Mac).
+4. Open the downloaded ZIP file from step 2 and extract the contents **from inside the zipped Aura folder** to your local **Aura** folder from step 3. This ensures that the necessary application assets, such as **config.xml**, are correctly located at the top level of the local **Aura** folder (e.g. **~/WebWorks/Aura/config.xml**).
+5. Using the **[Ripple Mobile Emulator](http://developer.blackberry.com/html5/download)** and the **[BlackBerry WebWorks SDK for Tablet OS](http://developer.blackberry.com/html5/download)**, package the contents of your local **Aura** folder into a BlackBerry application. Enter the project root settings field as the local folder created in step 3, and the archive name settings field as **Aura**.
+
## More Info
-* [BlackBerry WebWorks SDK for Tablet OS](http://us.blackberry.com/developers/tablet/webworks.jsp) - Getting Started guides, SDK downloads, code signing keys.
-* [BlackBerry WebWorks Development Guides] (http://docs.blackberry.com/en/developers/deliverables/30182/)
+
+* [BlackBerry HTML5 WebWorks](https://bdsc.webapps.blackberry.com/html5/) - Downloads, Getting Started guides, samples, code signing keys.
+* [BlackBerry WebWorks Development Guides] (https://bdsc.webapps.blackberry.com/html5/documentation)
* [BlackBerry WebWorks Community Forums](http://supportforums.blackberry.com/t5/Web-and-WebWorks-Development/bd-p/browser_dev)
* [BlackBerry Open Source WebWorks Contributions Forums](http://supportforums.blackberry.com/t5/BlackBerry-WebWorks/bd-p/ww_con)
21 kitchenSink/README.md
View
@@ -10,18 +10,15 @@ The sample code for this application is Open Source under the [Apache 2.0 Licens
* [BlackBerry WebWorks SDK for Tablet OS](http://us.blackberry.com/developers/tablet/webworks.jsp)
* [BlackBerry WebWorks SDK for Smartphones](http://us.blackberry.com/developers/browserdev/widgetsdk.jsp)
-
**Author(s)**
* [Adam Stanley](https://github.com/astanley)
-
**Dependencies**
1. See the **Resource_Copyright_Info.txt** file for a complete listing of copyright info, and references for images and resources used in this application.
2. [json2.js](http://www.JSON.org/js.html) JSON parser is available under Public Domain.
-
**Known Issues**
1. Application Event API (Tablet OS) - background/foreground events not working (onSwipeDown is, but onBackground and onForeground are not responding).
@@ -41,24 +38,20 @@ The sample code for this application is Open Source under the [Apache 2.0 Licens
To build the kitchenSink sample application:
-1. Click on the **Downloads** button at the top right of this screen.
-2. Select **Download.zip** and save the downloaded file to your local machine.
-3. Create a new folder on your local machine named **kitchenSink** (e.g. **c:\webworks\kitchenSink**).
-4. Open the downloaded ZIP file from step 2 and **extract the contents from inside the top level folder** to your new **kitchenSink** folder. This ensures that the necessary application assets, such as **config.xml**, are correctly located at the top level of the **kitchenSink** folder (e.g. **c:\webworks\kitchenSink\config.xml**).
-5. Using an achiving utility (e.g. WinZip or 7-zip), package the contents of your **c:\webworks\kitchenSink** folder into a ZIP archive named **kitchenSink.zip**. This archive should have the application assets (not a folder containing the application assets) at its top level.
-6. Using the **[BlackBerry WebWorks SDK for Tablet OS](http://us.blackberry.com/developers/tablet/webworks.jsp)**, package the **kitchenSink.zip** archive into a BlackBerry Tablet OS application using the following command line: **bbwp c:\webworks\kitchenSink\kitchenSink.zip**
+1. Click on the **Downloads** tab above.
+2. Select **Download as zip** (Windows) or **Download as tar.gz** (Mac) and save the downloaded file to your local machine.
+3. Create a new folder on your local machine named **kitchenSink** e.g. **C:\Documents and Settings\User\WebWorks\kitchenSink** (Windows) or **~/WebWorks/kitchenSink** (Mac).
+4. Open the downloaded ZIP file from step 2 and extract the contents **from inside the zipped kitchenSink folder** to your local **kitchenSink** folder from step 3. This ensures that the necessary application assets, such as **config.xml**, are correctly located at the top level of the local **kitchenSink** folder (e.g. **~/WebWorks/kitchenSink/config.xml**).
+5. Using the **[Ripple Mobile Emulator](http://developer.blackberry.com/html5/download)** and either the **[BlackBerry WebWorks SDK for Smartphone](http://developer.blackberry.com/html5/download)** or the **[BlackBerry WebWorks SDK for Tablet OS](http://developer.blackberry.com/html5/download)**, package the contents of your local **kitchenSink** folder into a BlackBerry application. Enter the project root settings field as the local folder created in step 3, and the archive name settings field as **kitchenSink**.
## More Info
-* [BlackBerry WebWorks SDK for Tablet OS](http://us.blackberry.com/developers/tablet/webworks.jsp) - Getting Started guides, SDK downloads, code signing keys.
-* [BlackBerry WebWorks SDK for Smartphones](http://us.blackberry.com/developers/browserdev/widgetsdk.jsp) - Getting Started guides, SDK downloads, code signing keys.
-* [BlackBerry WebWorks SDK for Tablets - Development Guides] (http://docs.blackberry.com/en/developers/deliverables/30182/)
-* [BlackBerry WebWorks SDK for Smartphones - Development Guides] (http://docs.blackberry.com/en/developers/subcategories/?userType=21&category=BlackBerry+WebWorks+for+Smartphones)
+* [BlackBerry HTML5 WebWorks](https://bdsc.webapps.blackberry.com/html5/) - Downloads, Getting Started guides, samples, code signing keys.
+* [BlackBerry WebWorks Development Guides] (https://bdsc.webapps.blackberry.com/html5/documentation)
* [BlackBerry WebWorks Community Forums](http://supportforums.blackberry.com/t5/Web-and-WebWorks-Development/bd-p/browser_dev)
* [BlackBerry Open Source WebWorks Contributions Forums](http://supportforums.blackberry.com/t5/BlackBerry-WebWorks/bd-p/ww_con)
-
## Contributing Changes
Please see the [README](https://github.com/blackberry/WebWorks-Samples) of the WebWorks-Samples repository for instructions on how to add new Samples or make modifications to existing Samples.
2  kitchenSink/config.xml
View
@@ -16,7 +16,7 @@
-->
<widget xmlns="http://www.w3.org/ns/widgets"
xmlns:rim="http://www.blackberry.com/ns/widgets"
- version="1.0.0.2" id="Kitchen Sink WebWorks" xml:lang="en">
+ version="1.0.0.2" id="KitchenSink" xml:lang="en">
<!--
Configuration document developer guides
9 kitchenSink/css/styles.css
View
@@ -304,4 +304,11 @@ background: linear-gradient(top, #cfe7fa 0%,#6393c1 100%); /* W3C */
#legend ul
{
list-style: none;
-}
+}
+
+.tdmid {
+ vertical-align: middle;
+}
+.tdtop {
+ vertical-align: top;
+}
8 kitchenSink/html/apis/audioplayer.html
View
@@ -38,14 +38,14 @@
<button onclick="pauseAudio()">Pause Audio</button>
<button onclick="stopAudio()">Stop Audio</button>
</p>
- <p>
- <div id="playerUpdates"></div>
- </p>
+
+ <div id="playerUpdates"></div>
+
<p>
<button onclick="changeVolume(1)">Increase Volume</button>
<button onclick="changeVolume(-1)">Decrease Volume</button>
- <div id="currentVolume"></div>
</p>
+ <div id="currentVolume"></div>
</div>
8 kitchenSink/html/apis/microphone.html
View
@@ -46,10 +46,10 @@
&lt;/rim:permissions&gt;
</code>
</p>
- <p>
- <div id="recordingProgress" class="updateMsg">Recording ...</div>
- <div id="recordingPaused" class="updateMsg">*** PAUSED ***</div>
- </p>
+
+ <div id="recordingProgress" class="updateMsg">Recording ...</div>
+ <div id="recordingPaused" class="updateMsg">*** PAUSED ***</div>
+
<p>
<button id="btnStart" onclick="record()">Start Recording</button>
<button id="btnPause" disabled="disabled" onclick="pause()">Pause</button>
2  kitchenSink/html/apis/utils.html
View
@@ -34,7 +34,7 @@
<div class="demo" id="details">
<button id="btnURL" onclick="parseURL()">Parse URL</button>
- <input type="text" id="txtURL" value="http://www.bla.com:8080/index.html?COUNTER=3&FOO=BAR" size="50"/>
+ <input type="text" id="txtURL" value="http://www.bla.com:8080/index.html?COUNTER=3&amp;FOO=BAR" size="50"/>
<div id="urlDetails"></div>
<br/>
<br/>
BIN  kitchenSink/html/browser/Thumbs.db
View
Binary file not shown
13 kitchenSink/html/browser/data.xml
View
@@ -1,11 +1,10 @@
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE properties SYSTEM "http://java.sun.com/dtd/properties.dtd">
<properties>
-<entry key="enhanced_web_css">css/template.css</entry>
-<entry key="application_url">../../moblet/build/generic/tmb/en/The_Mobile_Bank.jad</entry>
-<entry key="enhanced_web_supported">false</entry>
-<entry key="application_supported">false</entry>
-<entry key="enhanced_web_enabled">false</entry>
-<entry key="check_deposit_enabled">false</entry>
-<entry key="mf_device_identifier">generic</entry>
+<entry key="what_is_the_answer">its 42</entry>
+<entry key="foo">bar</entry>
+<entry key="abc">def</entry>
+<entry key="123">456</entry>
+<entry key="do_something">okay</entry>
+<entry key="jump">How high?</entry>
</properties>
8 kitchenSink/html/browser/flashplayer.html
View
@@ -37,10 +37,10 @@
<p>
<b>Example:</b> Take your existing Flash game/workflow/video/presentation, wrap it in a WebWorks application, deploy it to BlackBerry App World.
</p>
- <object width="640" height="385" style="border: dotted 1px black">
- <param name="movie" value="http://www.youtube.com/v/eAaez_4m9mQ?fs=1&amp;hl=en_US"></param>
- <param name="allowscriptaccess" value="always"></param>
- <embed src="http://www.youtube.com/v/eAaez_4m9mQ?fs=1&amp;hl=en_US" type="application/x-shockwave-flash" allowscriptaccess="always" width="640" height="385"></embed>
+ <object width="640" height="385" style="border: dotted 1px black" type="application/x-shockwave-flash" data="http://www.youtube.com/v/eAaez_4m9mQ?fs=1&amp;hl=en_US">
+ <param name="movie" value="http://www.youtube.com/v/eAaez_4m9mQ?fs=1&amp;hl=en_US"/>
+ <param name="allowscriptaccess" value="always"/>
+ <embed src="http://www.youtube.com/v/eAaez_4m9mQ?fs=1&amp;hl=en_US" type="application/x-shockwave-flash" allowscriptaccess="always" width="640" height="385"/>
</object>
<p>
BlackBerry PlayBook - Preview<br/>
30 kitchenSink/html/browser/formfields.html
View
@@ -24,6 +24,11 @@
<title> Web Engine features: Form input fields </title>
<script src="../../js/browser/forminputs.js" type="text/javascript"></script>
+ <style type="text/css">
+ td {
+ padding: 5px;
+ }
+ </style>
</head>
<body>
@@ -35,7 +40,7 @@
Some new form elements were introduced as part of <a href="http://dev.w3.org/html5/html-author/#forms">HTML5</a> standard (e.g. meter, progress).
</p>
- <table cellspacing="5" cellpadding="5">
+ <table>
<tr>
<td>Text:</td>
<td> <input id="txtText" type="text" size="20" value="Hello World"/> </td>
@@ -44,7 +49,7 @@
</tr>
<tr>
<td>Password:</td>
- <td><input id="txtPassword"type="password" size="20" value="Hello World"/> </td>
+ <td><input id="txtPassword" type="password" size="20" value="Hello World"/> </td>
<td>Progress:</td>
<td> <progress id="prgProgress" max="100"><span>0</span>%</progress> </td>
@@ -53,11 +58,11 @@
<td>Radio:</td>
<td><input id="rbYes" name="rbGroup" type="radio" value="Y"/> Yes <input id="rbNo" name="rbGroup" type="radio" value="N"/> No </td>
<td>Range:</td>
- <td><input type="range" id="txtRange" min="-100" max="100" value="0" step="10" value=""/></td>
+ <td><input type="range" id="txtRange" min="-100" max="100" value="0" step="10"/></td>
</tr>
<tr>
<td>Checkbox:</td>
- <td><input id="cbCheckBox" type="checkbox" checked/> Left <input id="cbCheckBox" type="checkbox"/> Right </td>
+ <td><input id="cbCheckBoxL" type="checkbox" checked/> Left <input id="cbCheckBoxR" type="checkbox"/> Right </td>
<td>Button:</td>
<td><button id="btnSubmit" onclick="validate()">Submit</button></td>
</tr>
@@ -69,13 +74,13 @@
</tr>
<tr>
<td>Hidden:</td>
- <td><input id="txtHidden"type="hidden" value="Useful for storing temporary values"/> </td>
+ <td><input id="txtHidden" type="hidden" value="Useful for storing temporary values"/> </td>
<td>File:</td>
- <td><input id="txtFile"type="file"/> </td>
+ <td><input id="txtFile" type="file"/> </td>
</tr>
<tr>
<td>Output:</td>
- <td> <input name="txtValue1" type="number" size="4" maxlength="4" step="1" value="5"> + <input name="txtValue2" type="number" size="4" maxlength="4" step="1" value="4"> <br/>
+ <td> <input name="txtValue1" type="number" step="1" value="5"> + <br/> <input name="txtValue2" type="number" step="1" value="4"> <br/>
= <output onforminput="value = txtValue1.valueAsNumber + txtValue2.valueAsNumber"></output> </td>
<td></td>
<td></td>
@@ -91,17 +96,18 @@
The line-wrap behavior of textarea input fields can be controlled via CSS.
</p>
<p>
- <b>wrap=hard</b><br/>
+ <b>wrap=hard</b> - text is wrapped when submitted in a form (cols must be specified)<br/>
<textarea id="txtWrapHard" cols="20" rows="5" wrap="hard">As you can see many times word wrapping is often the desired look for your textareas. Since it makes everything nice and easy to read.</textarea>
</p>
<p>
- <b>wrap=off</b><br/>
- <textarea id="txtWrapOff" cols="20" rows="5" wrap="off">As you can see many times word wrapping is often the desired look for your textareas. Since it makes everything nice and easy to read.</textarea>
+ <b>wrap=soft</b> - text is not wrapped when submitted in a form (default)<br/>
+ <textarea id="txtWrapSoft" cols="20" rows="5" wrap="soft">As you can see many times word wrapping is often the desired look for your textareas. Since it makes everything nice and easy to read.</textarea>
</p>
<p>
- <b>wrap=off (rows before cols)</b><br/>
- <textarea id="txtWrapOff2" rows="5" cols="20" wrap="off">As you can see many times word wrapping is often the desired look for your textareas. Since it makes everything nice and easy to read.</textarea>
+ <b>wrap=off</b><br/>
+ <textarea id="txtWrapOff" cols="20" rows="5" wrap="off">As you can see many times word wrapping is often the desired look for your textareas. Since it makes everything nice and easy to read.</textarea>
</p>
+
</div>
14 kitchenSink/html/browser/gps.html
View
@@ -41,10 +41,10 @@
</p>
<div class="buttonField">
- <input type="button" id="btnCell" value="Default" onClick="locationUpdated()"/> <br/>
- <input type="button" id="btnCell" value="CellSite" onClick="getCellSite()"/> <br/>
- <input type="button" id="btnCell" value="Assisted" onClick="getAssisted()"/> <br/>
- <input type="button" id="btnCell" value="Autonomous" onClick="getAutonomous()"/> <br/>
+ <input type="button" id="btnDefault" value="Default" onClick="locationUpdated()"/> <br/>
+ <input type="button" id="btnCell" value="CellSite" onClick="getCellSite()"/> <br/>
+ <input type="button" id="btnAssisted" value="Assisted" onClick="getAssisted()"/> <br/>
+ <input type="button" id="btnAutonomous" value="Autonomous" onClick="getAutonomous()"/> <br/>
</div>
<p id="currentLocation"></p>
</div>
@@ -59,10 +59,10 @@
<p>
<b>Note</b>: The following carriers have disable device-side GPS functionality (location services can be purchased from carrier instead):
- <ul>
- <li>Verizon - blocks assisted GPS, leave Autonomous GPS open (need to signup to their developer program in order to get any fixes on their devices)</li>
- </ul>
</p>
+ <ul>
+ <li>Verizon - blocks assisted GPS, leave Autonomous GPS open (need to signup to their developer program in order to get any fixes on their devices)</li>
+ </ul>
</div>
3  kitchenSink/html/browser/keyevents.html
View
@@ -42,8 +42,9 @@
</p>
<p>
<button onclick="clearLogInfo()">Clear Messages</button>
- <div id="logger"></div>
</p>
+ <div id="logger"></div>
+
</div>
</body>
16 kitchenSink/html/browser/orientation.html
View
@@ -37,21 +37,5 @@
</p>
<div id="currentOrientation">n/a</div>
</div>
-
- <h2>Details</h2>
- <div class="demo">
-
-
- <p>
- <img src="../../img/axes.jpg"/>
- </p>
-
- <ol>
- <li> The X axis runs from left through the right of the device. </li>
- <li> The Y axis runs from top through the bottom of the device.</li>
- <li> The Z axis runs from front through the back of the device.</li>
- </ol>
-
- </div>
</body>
4 kitchenSink/html/browser/protocols.html
View
@@ -48,14 +48,14 @@
<h2>local:///</h2>
<div class="demo">
- <p> Image: <img src="local:///img/basketball.png" style="border: solid 2px black; height: 32px; width: 32px;"/> Link : <a href="local:///img/basketball.png">local:///img/basketball.png</a> </p>
+ <p> Image: <img src="local:///img/basketball.png" alt="basketball image" style="border: solid 2px black; height: 32px; width: 32px;"/> Link : <a href="local:///img/basketball.png">local:///img/basketball.png</a> </p>
<p> Test = subfolder within application </p>
<p> Note: The location of this page is local:///browser/protocols.html </p>
</div>
<h2> <i>None</i> </h2>
<div class="demo">
- <p> Image: <img src="../../img/basketball.png" style="border: solid 2px black; height: 32px; width: 32px;"/> Link : <a href="basketball.png">basketball.png</a> </p>
+ <p> Image: <img src="../../img/basketball.png" alt="basketball image" style="border: solid 2px black; height: 32px; width: 32px;"/> Link : <a href="basketball.png">basketball.png</a> </p>
<p>By not providing a protocol, the path to the current page is used.</p>
</div>
12 kitchenSink/html/browser/schemes.html
View
@@ -39,7 +39,7 @@
<h2>mailto:</h2>
<div class="demo">
- <p> <a href="mailto:test@test.com?subject=test&body=Hello%20World">mailto:test@test.com</a> </p>
+ <p> <a href="mailto:test@test.com?subject=test&amp;body=Hello%20World">mailto:test@test.com</a> </p>
<p> mailto:test@test.com </p>
</div>
@@ -85,15 +85,15 @@
<p> The following images were encoded using <a href="http://www.motobit.com/util/base64-decoder-encoder.asp">http://www.motobit.com/util/base64-decoder-encoder.asp</a> </p>
<p>
- <img id="img1" onload="onLoaded(this.id)"/> <button onclick="showImg('img1','')">Show Image 1</button>
+ <img id="img1" onload="onLoaded(this.id)" alt="webworks icon"/> <button onclick="showImg('img1','')">Show Image 1</button>
<br/>
- <img id="img2" onload="onLoaded(this.id)"/> <button onclick="showImg('img2','')">Show Image 2</button>
+ <img id="img2" onload="onLoaded(this.id)" alt="purple image"/> <button onclick="showImg('img2','')">Show Image 2</button>
<br/>
- <img id="img3" onload="onLoaded(this.id)"/> <button onclick="showImg('img3','')">Show Image 3</button>
+ <img id="img3" onload="onLoaded(this.id)" alt="shopping cart icon"/> <button onclick="showImg('img3','')">Show Image 3</button>
<br/>
- <img id="img4" onload="onLoaded(this.id)"/> <button onclick="showImg('img4','')">Show Image 4</button>
+ <img id="img4" onload="onLoaded(this.id)" alt="Hawaii photo"/> <button onclick="showImg('img4','')">Show Image 4</button>
<br/>
- <img id="img5" onload="onLoaded(this.id)"/> <button onclick="showImg('img5','')">Show Image 5</button>
+ <img id="img5" onload="onLoaded(this.id)" alt="Adam Stanley"/> <button onclick="showImg('img5','')">Show Image 5</button>
<br/>
</p>
1  kitchenSink/html/browser/touch.html
View
@@ -25,7 +25,6 @@
<title> Web Engine features: Touch events </title>
<link href="../../css/browser/touch.css" rel="stylesheet" type="text/css">
<script src="../../js/browser/touch.js" type="text/javascript"></script>
- <meta id="touch-event-mode" content="native"/>
</head>
<body>
54 kitchenSink/html/browser/typedarrays.html
View
@@ -0,0 +1,54 @@
+<!DOCTYPE html>
+<!--
+ * Copyright 2011 Research In Motion Limited.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+-->
+<html>
+<head>
+
+ <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
+ <meta name="viewport" content="width=device-width,target-densitydpi=device-dpi,user-scalable=no,initial-scale=1.0">
+ <link href="../../css/styles.css" rel="stylesheet" type="text/css">
+ <script src="../../js/standard.js" type="text/javascript" ></script>
+
+ <title> Web Engine features: Typed JavaScript Arrays </title>
+ <script src="../../js/browser/typedarrays.js" type="text/javascript"></script>
+
+</head>
+<body>
+
+ <h1>Typed JavaScript Arrays</h1>
+
+ <h2>Demo</h2>
+ <div class="demo">
+ <p>
+ This page demonstrates how the current browser supports typed JavaScript arrays. These constructs were introduced to the ECMAScript spect with the support of WebGL. They exist as a fixed block of binary data, and have much faster access times than regular arrays.
+ </p>
+
+ <h3>Float32Array</h3>
+ <div id="float32array">Processing ...</div>
+
+ <h3>Int8Array</h3>
+ <div id="int8array">Processing ...</div>
+
+ <h3>Uint8Array</h3>
+ <div id="uint8array">Processing ...</div>
+
+ <h3>Array</h3>
+ <div id="array">Processing ...</div>
+
+ </div>
+
+</body>
+</html>
8 kitchenSink/html/browser/useragent.html
View
@@ -37,10 +37,10 @@
<p>
Knowledge Base article: <a href="" onclick="openUrl('http://supportforums.blackberry.com/t5/Web-and-WebWorks-Development/How-to-detect-the-BlackBerry-Browser/ta-p/559862')">How to detect the BlackBerry Browser</a>.
</p>
- <p>
- <h4>User Agent value:</h4>
- <div id="userAgent"></div>
- </p>
+
+ <h4>User Agent value:</h4>
+ <div id="userAgent"></div>
+
</div>
</body>
6 kitchenSink/html/browser/viewport/densitydpi.html
View
@@ -33,17 +33,17 @@
<div class="demo bottom">
<p>
<b>100 x 100</b> <br/>
- <img src="../../../img/gallery/iris-beautiful-purple-flower_w725_h544.jpg" width="100" height="100"/>
+ <img src="../../../img/gallery/iris-beautiful-purple-flower_w725_h544.jpg" width="100" height="100" alt="iris flower image"/>
</p>
<p>
<b>262 x 257</b> <br/>
- <img src="../../../img/gallery/iris-beautiful-purple-flower_w725_h544.jpg" width="262" height="257"/>
+ <img src="../../../img/gallery/iris-beautiful-purple-flower_w725_h544.jpg" width="262" height="257" alt="iris flower image"/>
</p>
<p>
<b>500 x 500</b> <br/>
- <img src="../../../img/gallery/iris-beautiful-purple-flower_w725_h544.jpg" width="500" height="500"/>
+ <img src="../../../img/gallery/iris-beautiful-purple-flower_w725_h544.jpg" width="500" height="500" alt="iris flower image"/>
</p>
</div>
2  kitchenSink/html/browser/viewport/noscale.html
View
@@ -48,7 +48,7 @@
</p>
<h3>The following element is 664 x 494 wide:</h3>
- <canvas width="664" height="494" style="background-color: black;"/>
+ <canvas width="664" height="494" style="background-color: black;"></canvas>
</div>
</body>
2  kitchenSink/html/browser/viewport/scale2.html
View
@@ -51,7 +51,7 @@
</p>
<h3>The following element is 664 x 494 wide:</h3>
- <canvas width="664" height="494" style="background-color: black;"/>
+ <canvas width="664" height="494" style="background-color: black;"></canvas>
</div>
</body>
2  kitchenSink/html/browser/viewport/scalemax.html
View
@@ -47,7 +47,7 @@
Pellentesque sem eros, tincidunt ac viverra sit amet, tristique at risus. Proin ipsum tortor, hendrerit eu mollis sed, imperdiet ullamcorper augue. Phasellus eget massa mauris, in bibendum odio. Nulla facilisi. Sed adipiscing leo nec justo semper ac facilisis enim egestas. Etiam luctus porta ultrices. Donec molestie tincidunt urna, vitae convallis neque tincidunt vel. Cras consequat lorem in ipsum accumsan gravida. Praesent urna tellus, sodales eu feugiat eget, ultricies sit amet lorem. Quisque hendrerit rhoncus accumsan. Vestibulum molestie, turpis ac consequat consectetur, tortor magna feugiat nulla, eu vulputate ipsum nisi at libero. Nulla placerat eleifend libero. Vestibulum egestas fermentum fermentum. Etiam non lacus risus, vel convallis nunc.
</p>
<h3>The following element is 664 x 494 wide:</h3>
- <canvas width="664" height="494" style="background-color: black;"/>
+ <canvas width="664" height="494" style="background-color: black;"></canvas>
</div>
</body>
2  kitchenSink/html/browser/viewport/scalemin.html
View
@@ -48,7 +48,7 @@
<div>
<h3>The following element is 664 x 494 wide:</h3>
- <canvas width="664" height="494" style="background-color: black;"/>
+ <canvas width="664" height="494" style="background-color: black;"></canvas>
</div>
</div>
BIN  kitchenSink/html/css3/Thumbs.db
View
Binary file not shown
9 kitchenSink/html/css3/animation.html
View
@@ -25,7 +25,12 @@
<title>CSS3 Animation</title>
<link href="../../css/css3/animation.css" rel="stylesheet" type="text/css">
<script src="../../js/css3/animation.js" type="text/javascript"></script>
-
+ <style type="text/css">
+ table {
+ border-spacing: 10px;
+ }
+ </style>
+
</head>
<body>
@@ -33,7 +38,7 @@
<div class="demo">
- <table cellspacing="10">
+ <table>
<tr>
<td id="box1" class="box1" onclick="applyStyle('box1','scale')"> Scale </td>
6 kitchenSink/html/css3/animations.html
View
@@ -45,7 +45,7 @@
-webkit-animation-iteration-count: infinite;<br/>
}
</code>
- <img id="meteor" onclick="applyCSS('meteor','doleftright')" src="../../img/basketball.png">
+ <img id="meteor" onclick="applyCSS('meteor','doleftright')" src="../../img/basketball.png" alt="basketball image">
</div>
<h2>2. Animation: Box </h2>
@@ -66,7 +66,7 @@
-webkit-animation-delay:1s;<br/>
}
</code>
- <img id="ballbox" onclick="applyCSS('ballbox','dobox')" src="../../img/basketball.png">
+ <img id="ballbox" onclick="applyCSS('ballbox','dobox')" src="../../img/basketball.png" alt="basketball image">
</div>
<h2>3. Animation: Bounce </h2>
@@ -88,7 +88,7 @@
-webkit-animation-delay:0;<br/>
}
</code>
- <img id="ball" onclick="applyCSS('ball','dobounce')" src="../../img/basketball.png">
+ <img id="ball" onclick="applyCSS('ball','dobounce')" src="../../img/basketball.png" alt="basketball image">
</div>
</body>
16 kitchenSink/html/css3/mediaquery.html
View
@@ -32,11 +32,12 @@
<h2>What is a media query?</h2>
<div class="demo">
- <p>
- CSS3 media queries are used to define CSS styles that are applied to content ONLY when a given screen orientation/size condition is satisfied.
- </p>
- <p>
- If you are using a browser that supports media queries, this page demonstrates the following:
+ <p>
+ CSS3 media queries are used to define CSS styles that are applied to content ONLY when a given screen orientation/size condition is satisfied.
+ </p>
+ <p>
+ If you are using a browser that supports media queries, this page demonstrates the following:
+ </p>
<ol>
<li>
Rotate* the screen to a landscape orientation.
@@ -51,8 +52,9 @@
</ul>
</li>
</ol>
- * If you are using a desktop browser, you can simply resize the browser window.
- </p>
+ <p>
+ * If you are using a desktop browser, you can simply resize the browser window.
+ </p>
</div>
19 kitchenSink/html/css3/sprite.html
View
@@ -24,7 +24,12 @@
<title> CSS: Sprites </title>
<link href="../../css/usecase/sprite.css" rel="stylesheet" type="text/css">
-
+ <style type="text/css">
+ td {
+ padding: 5px;
+ }
+ </style>
+
</head>
<body>
@@ -41,10 +46,10 @@
Say you have an application that displays 4 separate images. Each of the following images requires the Web rendering engine to perform a separate HTTP request to download them:
</p>
<p>
- <img src="../../img/sprite_purple.jpg"/>
- <img src="../../img/sprite_green.jpg"/>
- <img src="../../img/sprite_red.jpg"/>
- <img src="../../img/sprite_blue.jpg"/>
+ <img src="../../img/sprite_purple.jpg" alt="purple image"/>
+ <img src="../../img/sprite_green.jpg" alt="green image"/>
+ <img src="../../img/sprite_red.jpg" alt="red image"/>
+ <img src="../../img/sprite_blue.jpg" alt="blue image"/>
</p>
</div>
@@ -54,11 +59,11 @@
<p>
All of the image assets for your application can be combined into a single image. The following is a single image that contains 4 separate colors:
</p>
- <img src="../../img/sprite.png" width="200" height="200"/>
+ <img src="../../img/sprite.png" width="200" height="200" alt="sprite image"/>
<p>
Using CSS the above image can be divided into pieces and each piece can be used as its own image. The result is one HTTP request for all visual assets instead of four:
</p>
- <table cellspacing="5" cellpadding="0" border="0">
+ <table>
<tr>
<td class="sprite blue">
blue
46 kitchenSink/html/css3/transformations.html
View
@@ -37,7 +37,7 @@
Click or hold touch on on any of the following images to observe a 3D transformation.
</p>
<p>
- For more examples of 2D and 3D transformations, see <a href="gallery.html">rotating image gallery</a> or <a href="" onclick="openUrl('http://www.webkit.org/blog-files/3d-transforms/morphing-cubes.html')"> Morphing Cubes, or <a href="" onclick="openUrl('http://www.joelambert.co.uk/flux/transgallery.html')">see Flux Slider</a> or <a href="" onclick="openUrl('http://webdesignerwall.com/trends/47-amazing-css3-animation-demos')">Web Designer Wall</a>.
+ For more examples of 2D and 3D transformations, see <a href="gallery.html">rotating image gallery</a> or <a href="" onclick="openUrl('http://www.webkit.org/blog-files/3d-transforms/morphing-cubes.html')"> Morphing Cubes</a>, or <a href="" onclick="openUrl('http://www.joelambert.co.uk/flux/transgallery.html')">see Flux Slider</a> or <a href="" onclick="openUrl('http://webdesignerwall.com/trends/47-amazing-css3-animation-demos')">Web Designer Wall</a>.
</p>
</div>
@@ -47,7 +47,7 @@
<h3>2D Translate</h3>
<div class="imgContainer">
- <img src="../../img/paradise_sm.jpg" class="translate2d"/> <br/> Translate
+ <img src="../../img/paradise_sm.jpg" alt="Hawaii photo" class="translate2d"/> <br/> Translate
</div>
</div>
@@ -56,19 +56,19 @@
<h3>3D Translate</h3>
<div class="imgContainer">
- <img src="../../img/paradise_sm.jpg" class="translate3d"/> <br/> Translate3d
+ <img src="../../img/paradise_sm.jpg" alt="Hawaii photo" class="translate3d"/> <br/> Translate3d
</div>
<div class="imgContainer">
- <img src="../../img/paradise_sm.jpg" class="translateX"/> <br/> TranslateX
+ <img src="../../img/paradise_sm.jpg" alt="Hawaii photo" class="translateX"/> <br/> TranslateX
</div>
<div class="imgContainer">
- <img src="../../img/paradise_sm.jpg" class="translateY"/> <br/> TranslateY
+ <img src="../../img/paradise_sm.jpg" alt="Hawaii photo" class="translateY"/> <br/> TranslateY
</div>
<div class="imgContainer">
- <img src="../../img/paradise_sm.jpg" class="translateZ"/> <br/> TranslateZ
+ <img src="../../img/paradise_sm.jpg" alt="Hawaii photo" class="translateZ"/> <br/> TranslateZ
</div>
</div>
@@ -82,7 +82,7 @@
<h3>2D Rotate</h3>
<div class="imgContainer">
- <img src="../../img/paradise_sm.jpg" class="rotate2d"/> <br/> Rotate
+ <img src="../../img/paradise_sm.jpg" alt="Hawaii photo" class="rotate2d"/> <br/> Rotate
</div>
</div>
@@ -91,19 +91,19 @@
<h3>3D Rotate</h3>
<div class="imgContainer">
- <img src="../../img/paradise_sm.jpg" class="rotate3d"/> <br/> Rotate3d
+ <img src="../../img/paradise_sm.jpg" alt="Hawaii photo" class="rotate3d"/> <br/> Rotate3d
</div>
<div class="imgContainer">
- <img src="../../img/paradise_sm.jpg" class="rotateX"/> <br/> RotateX
+ <img src="../../img/paradise_sm.jpg" alt="Hawaii photo" class="rotateX"/> <br/> RotateX
</div>
<div class="imgContainer">
- <img src="../../img/paradise_sm.jpg" class="rotateY"/> <br/> RotateY
+ <img src="../../img/paradise_sm.jpg" alt="Hawaii photo" class="rotateY"/> <br/> RotateY
</div>
<div class="imgContainer">
- <img src="../../img/paradise_sm.jpg" class="rotateZ"/> <br/> RotateZ
+ <img src="../../img/paradise_sm.jpg" alt="Hawaii photo" class="rotateZ"/> <br/> RotateZ
</div>
</div>
@@ -118,7 +118,7 @@
<h3>2D Scale</h3>
<div class="imgContainer">
- <img src="../../img/paradise_sm.jpg" class="scale2d"/> <br/> Scale
+ <img src="../../img/paradise_sm.jpg" alt="Hawaii photo" class="scale2d"/> <br/> Scale
</div>
</div>
@@ -127,19 +127,19 @@
<h3>3D Scale</h3>
<div class="imgContainer">
- <img src="../../img/paradise_sm.jpg" class="scale3d"/> <br/> Scale 3D
+ <img src="../../img/paradise_sm.jpg" alt="Hawaii photo" class="scale3d"/> <br/> Scale 3D
</div>
<div class="imgContainer">
- <img src="../../img/paradise_sm.jpg" class="scaleX"/> <br/> ScaleX
+ <img src="../../img/paradise_sm.jpg" alt="Hawaii photo" class="scaleX"/> <br/> ScaleX
</div>
<div class="imgContainer">
- <img src="../../img/paradise_sm.jpg" class="scaleY"/> <br/> ScaleY
+ <img src="../../img/paradise_sm.jpg" alt="Hawaii photo" class="scaleY"/> <br/> ScaleY
</div>
<div class="imgContainer">
- <img src="../../img/paradise_sm.jpg" class="scaleZ"/> <br/> ScaleZ
+ <img src="../../img/paradise_sm.jpg" alt="Hawaii photo" class="scaleZ"/> <br/> ScaleZ
</div>
</div>
@@ -154,15 +154,15 @@
<h3>2D Skew</h3>
<div class="imgContainer">
- <img src="../../img/paradise_sm.jpg" class="skew2dX"/> <br/> Skew (-45deg X-axis)
+ <img src="../../img/paradise_sm.jpg" alt="Hawaii photo" class="skew2dX"/> <br/> Skew (-45deg X-axis)
</div>
<div class="imgContainer">
- <img src="../../img/paradise_sm.jpg" class="skew2dY"/> <br/> Skew (30deg Y-axis)
+ <img src="../../img/paradise_sm.jpg" alt="Hawaii photo" class="skew2dY"/> <br/> Skew (30deg Y-axis)
</div>
<div class="imgContainer">
- <img src="../../img/paradise_sm.jpg" class="skew2dXY"/> <br/> Skew (-45deg X-axis, 30deg Y-axis)
+ <img src="../../img/paradise_sm.jpg" alt="Hawaii photo" class="skew2dXY"/> <br/> Skew (-45deg X-axis, 30deg Y-axis)
</div>
</div>
@@ -193,11 +193,11 @@
<div class="groupContainer">
<h3>3D Perspective</h3>
<div class="imgContainer perspectiveSmall">
- <img src="../../img/paradise_sm.jpg"/> <br/> Perspective (150)
+ <img src="../../img/paradise_sm.jpg" alt="Hawaii photo"/> <br/> Perspective (150)
</div>
<div class="imgContainer perspectiveLarge">
- <img src="../../img/paradise_sm.jpg"/> <br/> Perspective (500)
+ <img src="../../img/paradise_sm.jpg" alt="Hawaii photo"/> <br/> Perspective (500)
</div>
</div>
@@ -211,7 +211,7 @@
<h3>2D Matrix</h3>
<div class="imgContainer">
- <img src="../../img/paradise_sm.jpg" class="matrix"/> <br/> Matrix: <br/> rotate 30 degrees<br/> translate 25, 50
+ <img src="../../img/paradise_sm.jpg" alt="Hawaii photo" class="matrix"/> <br/> Matrix: <br/> rotate 30 degrees<br/> translate 25, 50
</div>
</div>
@@ -219,7 +219,7 @@
<div class="groupContainer">
<h3>3D Matrix</h3>
<div class="imgContainer">
- <img src="../../img/paradise_sm.jpg" class="matrix3d"/> <br/> Matrix 3D <br/> rotate 30 degrees<br/> translate 25, 50
+ <img src="../../img/paradise_sm.jpg" alt="Hawaii photo" class="matrix3d"/> <br/> Matrix 3D <br/> rotate 30 degrees<br/> translate 25, 50
</div>
</div>
3  kitchenSink/html/debug/firebuglite.html
View
@@ -23,7 +23,8 @@
<script src="../../js/standard.js" type="text/javascript" ></script>
<title>Debugging: Firebug Lite</title>
- <script type="text/javascript" src="https://getfirebug.com/firebug-lite.js">
+ <script type="text/javascript" src="https://getfirebug.com/firebug-lite.js"></script>
+ <script type="text/javascript">
{
startOpened: true,
showIconWhenHidden: true
17 kitchenSink/html/debug/ripple.html
View
@@ -31,35 +31,30 @@
<h2>Demo</h2>
<div class="demo">
- <p><a href="http://ripple.tinyhippos.com/">Ripple</a> is a multi-platform mobile environment emulator that runs in a web browser and is custom-tailored to HTML5 mobile application testing. Ripple aims to reduce the challenges being faced by mobile developers caused by today's platform fragmentation in the marketplace.</p>
+ <p><a href="http://developer.blackberry.com/html5/">Ripple</a> is a multi-platform mobile environment emulator that is custom-tailored for HTML5 mobile application testing. Ripple aims to reduce the challenges being faced by mobile developers caused by today's platform fragmentation in the marketplace.</p>
<p>
Here is how you use Ripple:
</p>
<ol>
- <li>Using the Chrome desktop browser, <a href="http://ripple.tinyhippos.com/download">install the Ripple extension</a></li>
- <li>Load the URL of the Web content you wish to profile and debug in the Chrome browser.</li>
- <li>Right click on the Web content and select Emulator &#8594; Enable.</li>
- <li>When prompted, click on the "WebWorks" button.</li>
+ <li>Download and install the <a href="http://developer.blackberry.com/html5/download/">Ripple mobile emulator</a></li>
+ <li>Launch Ripple. When prompted, choose the "WebWorks" platform</li>
+ <li>Load the URL of the Web content you wish to profile and debug (remote content or local web server).</li>
</ol>
</div>
<h2>Demo</h2>
<div class="demo">
- <p>
- <b>Enable Ripple:</b><br/>
- <img src="../../img/screenshots/enable_ripple.jpg"/>
- </p>
<p>
<b>Choose WebWorks:</b><br/>
- <img src="../../img/screenshots/ripple_webworks.jpg"/>
+ <img src="../../img/screenshots/ripple_webworks.jpg" alt="Using Ripple screenshot"/>
</p>
<p>
<b>Use Ripple:</b><br/>
- <img src="../../img/screenshots/use_ripple.jpg"/>
+ <img src="../../img/screenshots/use_ripple.jpg" alt="Using Ripple screenshot"/>
</p>
</div>
6 kitchenSink/html/debug/webinspector.html
View
@@ -44,7 +44,7 @@
<li>Open a desktop browser and navigate to the URL "http://&lt;IP address&gt;:1337"</li>
</ol>
<p>
- Blog article: <a href="" onclick="openUrl('http://devblog.blackberry.com/2011/06/debugging-blackberry-web-apps/')"> Debugging BlackBerry web applications using Web Inspector <a/>.
+ Blog article: <a href="" onclick="openUrl('http://devblog.blackberry.com/2011/06/debugging-blackberry-web-apps/')"> Debugging BlackBerry web applications using Web Inspector </a>.
</p>
</div>
@@ -54,12 +54,12 @@
<p>
<b>Web Inspector Enabled:</b><br/><br/>
When you first connect to Web Inspector from a desktop browser, you will see a title screen showing the current page loaded in the WebWorks application.<br/><br/>
- <img src="../../img/screenshots/webinspector_enabled.png"/>
+ <img src="../../img/screenshots/webinspector_enabled.png" alt="Web Inspector enabled screenshot"/>
</p>
<p>
<b>Using Web Inspector:</b><br/><br/>
You can then click on the title, and begin debugging and profiling that page using the variety of developer utilities provided by Web Inspector:<br/><br/>
- <img src="../../img/screenshots/webinspector_using.png"/>
+ <img src="../../img/screenshots/webinspector_using.png" alt="Using Web Inspector screenshot"/>
</p>
</div>
10 kitchenSink/html/html5/file.html
View
@@ -24,6 +24,14 @@
<title> HTML5 File Reader </title>
<script src="../../js/html5/filereader.js" type="text/JavaScript"></script>
+ <style type="text/css">
+ table {
+ width: 100%;
+ }
+ td {
+ padding: 5px;
+ }
+ </style>
</head>
<body>
@@ -45,7 +53,7 @@
Select File(s) : <input type="file" id="txtFile" name="files[]" multiple/>
</p>
- <table id="output" border='0' cellspacing='0' cellpadding='5' width='100%'>
+ <table id="output">
<tr><th>Filename</th><th>Type</th><th>Preview</th><th>Size (bytes)</th><th>Last Modified</th></tr>
</table>
<div id="errors"></div>
41 kitchenSink/html/html5/inputtypes.html
View
@@ -23,6 +23,14 @@
<script src="../../js/standard.js" type="text/javascript" ></script>
<title> HTML5 Input types </title>
+ <style type="text/css">
+ td {
+ padding: 5px;
+ }
+ th {
+ width: 50px;
+ }
+ </style>
</head>
<body>
@@ -43,15 +51,26 @@
<p>
Using a BlackBerry Smartphone or PlayBook, apply focus to the following fields to observe which variant of the virtual keyboard is invoked.
</p>
- <table cellspacing="0" cellpadding="5" border="0">
+ <table>
+ <tr>
+ <th>text:</th>
+ <td><input type="text" id="txtText" name="txtText" title="Any characters allowed" value="Hello World"/></td>
+ <td>&lt;input type="text"/&gt; </td>
+ </tr>
+ <tr>
+ <th>password:</th>
+ <td><input type="password" id="txtPassword" name="txtPassword" title="Only numeric characters allowed" value=""/></td>
+ <td>&lt;input type="password"/&gt; </td>
+ </tr>
+
<tr>
<th>tel:</th>
- <td><input type="tel" id="txtTel" name="txtTel" title="Only numeric characters allowed" value=""/></td>
+ <td><input type="tel" id="txtTel" name="txtTel" title="Only numeric characters allowed" value="555 1234"/></td>
<td>&lt;input type="tel"/&gt; </td>
</tr>
<tr>
<th>url:</th>
- <td><input type="url" id="txtUrl" value=""/></td>
+ <td><input type="url" id="txtUrl" value="http://devblog.blackberry.com"/></td>
<td>&lt;input type="url"/&gt; </td>
</tr>
<tr>
@@ -61,41 +80,41 @@
</tr>
<tr>
<th>number:</th>
- <td><input type="number" id="txtNumber" min="0" max="50" step="1" value=""/></td>
+ <td><input type="number" id="txtNumber" min="0" max="50" step="1" value="5"/></td>
<td>&lt;input type="number"/&gt; </td>
</tr>
<tr>
<th>range:</th>
- <td><input type="range" id="txtRange" min="-100" max="100" value="0" step="10" value=""/></td>
+ <td><input type="range" id="txtRange" min="-100" max="100" value="0" step="10"/></td>
<td>&lt;input type="range"/&gt; </td>
</tr>
<tr>
<th>date:</th>
- <td><input type="date" id="txtDate" min="1900-01-01" max="1999-12-31" value=""/> </td>
+ <td><input type="date" id="txtDate" min="1900-01-01" max="1999-12-31" value="1979-01-23"/> </td>
<td>&lt;input type="date"/&gt; </td>
</tr>
<tr>
<th>time:</th>
- <td><input type="time" id="txtTime" value=""/></td>
+ <td><input type="time" id="txtTime" value="13:31"/></td>
<td>&lt;input type="time"/&gt; </td>
</tr>
<tr>
<th>datetime:</th>
- <td><input type="datetime" id="txtDateTime" value="" min="2010-11-02" /></td>
+ <td><input type="datetime" id="txtDateTime" value="1979-01-23T04:30:00Z" min="1969-08-15T12:00:00Z" /></td>
<td>&lt;input type="datetime"/&gt; </td>
</tr>
<tr>
<th>month:</th>
- <td><input type="month" id="txtMonth" value=""/></td>
+ <td><input type="month" id="txtMonth" value="1976-06"/></td>
<td>&lt;input type="month"/&gt; </td>
</tr>
<tr>
<th>datetime-local:</th>
- <td><input type="datetime-local" id="txtDateTimeLocal" min="2010-01-01" max="2015-12-31" step="86400" value=""/></td>
+ <td><input type="datetime-local" id="txtDateTimeLocal" min="2010-01-01T12:00:00" max="2015-12-31T12:00:00" step="86400" value="2011-10-28T13:33:00"/></td>
<td>&lt;input type="datetime-local"/&gt; </td>
</tr>
<tr>
- <th width="50">search:</th>
+ <th>search:</th>
<td><input type="search" id="txtSearch" value=""/></td>
<td>&lt;input type="search"/&gt; </td>
</tr>
4 kitchenSink/html/html5/offline.html
View
@@ -37,11 +37,11 @@
</p>
<p>
- <div>This user agent is currently <span id="browserStatus"><i>Unknown</i></span>.</div>
+ This user agent is currently <span id="browserStatus"><i>Unknown</i></span>.
</p>
<p>
- <div>Last checked <span id="currentDate"></span>.</div>
+ Last checked <span id="currentDate"></span>.
</p>
</div>
2  kitchenSink/html/html5/video.html
View
@@ -39,7 +39,7 @@
<i><b>This page requires an active network connection.</b></i>
</p>
<p>
- Files used in this sample: <a href="http://mirror.bigbuckbunny.de/peach/bigbuckbunny_movies/big_buck_bunny_1080p_surround.avi" />big_buck_bunny_1080p_surround.avi</a> (886Mb), <a href="http://upload.wikimedia.org/wikipedia/commons/b/b5/I-15bis.ogg">I-15bis.ogg</a> (6.5Mb), <a href="http://cdn.kaltura.org/apis/html5lib/kplayer-examples/media/bbb_trailer_iphone.m4v">bbb_trailer_iphone.m4v</a> (4Mb).
+ Files used in this sample: <a href="http://mirror.bigbuckbunny.de/peach/bigbuckbunny_movies/big_buck_bunny_1080p_surround.avi">big_buck_bunny_1080p_surround.avi</a> (886Mb), <a href="http://upload.wikimedia.org/wikipedia/commons/b/b5/I-15bis.ogg">I-15bis.ogg</a> (6.5Mb), <a href="http://cdn.kaltura.org/apis/html5lib/kplayer-examples/media/bbb_trailer_iphone.m4v">bbb_trailer_iphone.m4v</a> (4Mb).
</p>
<code>
&lt;video height="240px" width="320px" controls="controls" poster="[src of image to display on load]" preload="none" src="[your movie file location]"&gt; <br/>
4 kitchenSink/html/html5/websockets.html
View
@@ -43,9 +43,9 @@
<p>
Message : <input type="text" id="txtMessage" size="20" maxlength="30"/>
<button id="btnSend" onclick="sendMessage()">Send Message</button> <b>ATTENTION:</b> Messages are sent to a public server (ws://node.remysharp.com:8001).
- <h3>Socket Messages:</h3>
- <div id="theMessages"></div>
</p>
+ <h3>Socket Messages:</h3>
+ <div id="theMessages"></div>
<div id="output"></div>
<p>
44 kitchenSink/html/html5/workers.html
View
@@ -24,6 +24,11 @@
<title> HTML5 Web Workers </title>
<script src="../../js/html5/workers.js" type="text/JavaScript"></script>
+ <style type="text/css">
+ td {
+ padding: 5px;
+ }
+ </style>
</head>
<body>
@@ -37,16 +42,16 @@
</p>
<p>
- <div>Calculate # of prime numbers between 2 and <input type="text" id="txtUpper" value="1000000" size="7" maxlength="7"/> (5 times):</div>
+ Calculate # of prime numbers between 2 and <input type="text" id="txtUpper" value="1000000" size="7" maxlength="7"/> (5 times):
<button id="btnRegular" onclick="calculate(false)">Begin (Main Thread)</button>
<button id="btnWorker" onclick="calculate(true)">Begin (Worker Threads)</button>
</p>
<div id="comments"></div>
- <table cellspacing="5" cellpadding="5">
+ <table>
<tr>
- <td id="outputNormal" valign="top"></td>
- <td id="outputWorker" valign="top"></td>
+ <td id="outputNormal" class="tdtop"></td>
+ <td id="outputWorker" class="tdtop"></td>
</tr>
</table>
@@ -69,22 +74,21 @@
<p>Since workers process data asyncronously, there is no way to predict or determine the order in which they will complete their processing.</p>
<h3>Flow of events:</h3>
- <p>
- <table cellpadding="5">
- <tr>
- <td rowspan="2" valign="middle"><b>[Main Thread]</b></td>
- <td>1. postMessage</td>
- <td>--&gt;</td>
- <td>2. onmessage(function)</td>
- <td rowspan="2" valign="middle"><b>[Worker Thread]</b></td>
- </tr>
- <tr>
- <td>4. onmessage(function)</td>
- <td>&lt;--</td>
- <td>3. postMessage</td>
- </tr>
- </table>
- </p>
+
+ <table>
+ <tr>
+ <td rowspan="2" class="tdmid"><b>[Main Thread]</b></td>
+ <td>1. postMessage</td>
+ <td>--&gt;</td>
+ <td>2. onmessage(function)</td>
+ <td rowspan="2" class="tdmid"><b>[Worker Thread]</b></td>
+ </tr>
+ <tr>
+ <td>4. onmessage(function)</td>
+ <td>&lt;--</td>
+ <td>3. postMessage</td>
+ </tr>
+ </table>
<h3>Max Workers</h3>
<p>Is there a limit to how many workers can be created? I think Chrome caps it at 16. It is advised to use the .terminate() method to destroy unused Worker objects.</p>
24 kitchenSink/html/usecase/progress.html
View
@@ -40,21 +40,25 @@
<h3>Examples:</h3>
<ol>
<li>
- Click on the 'show activity indicator' button to dynamically display a visual indicator for a fixed period of time.
<p>
- Duration: <input type="number" id="txtDuration" value="2"/> (seconds)
- <div id="activityIndicator" class="hide">
- Loading ...
- </div>
+ Click on the 'show activity indicator' button to dynamically display a visual indicator for a fixed period of time.
+ </p>
+ Duration: <input type="number" id="txtDuration" value="2"/> (seconds)
+ <div id="activityIndicator" class="hide">
+ Loading ...
+ </div>
+ <p>
<button onclick="beginActivityIndicator()">Show Activity Indicator</button>
- </p>
+ </p>
</li>
<li>
- Click on the 'show progress' button to display a meter, that updates over an interval of time.
<p>
- <div class="progressBar">
- <div id="level" class="progressLevel">&nbsp;</div>
- </div>
+ Click on the 'show progress' button to display a meter, that updates over an interval of time.
+ </p>
+ <div class="progressBar">
+ <div id="level" class="progressLevel">&nbsp;</div>
+ </div>
+ <p>
<button onclick="showProgress()">Show Progress</button>
</p>
</li>
BIN  kitchenSink/img/screenshots/enable_ripple.jpg
View
Deleted file not rendered
BIN  kitchenSink/img/screenshots/use_ripple.jpg
View
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
103 kitchenSink/index.html
View
@@ -48,13 +48,13 @@
</p>
- <h2 id="lookfeelheader">Look and Feel <img src="img/minimize.png"/></h2>
+ <h2 id="lookfeelheader">Look and Feel <img src="img/minimize.png" alt="minimize icon"/></h2>
<ul id="lookfeelcontent" class="section">
<li class="category"><h3>User Interface</h3> - Design your app to look the way you want it to</li>
- <li> <a href="html/browser/formfields.html"> HTML Form Fields</a> <img src="img/html5_logo_sm.png"/> Collect information from users</li>
- <li> <a href="html/css3/fonts.html"> Fonts </a> <img src="img/css3_logo.png" width="20"/> Use standard or custom fonts</li>
- <li> <a href="html/css3/mediaquery.html"> Media Query </a> <img src="img/css3_logo.png" width="20"/> Single CSS for multiple screen dimensions</li>
+ <li> <a href="html/browser/formfields.html"> HTML Form Fields</a> <img src="img/html5_logo_sm.png" alt="html5 logo"/> Collect information from users</li>
+ <li> <a href="html/css3/fonts.html"> Fonts </a> <img src="img/css3_logo.png" width="20" alt="css logo"/> Use standard or custom fonts</li>
+ <li> <a href="html/css3/mediaquery.html"> Media Query </a> <img src="img/css3_logo.png" width="20" alt="css logo"/> Single CSS for multiple screen dimensions</li>
<li> <a href="html/browser/viewport/viewport.html"> Viewport </a> Virtual rendering area for Web content</li>
<li> <a href="html/browser/pagedimensions.html"> Screen Dimensions</a> Detect page width &amp; height </li>
<li> <a href="html/browser/orientation.html"> Orientation </a> Detect when page layout changes</li>
@@ -64,21 +64,21 @@ <h2 id="lookfeelheader">Look and Feel <img src="img/minimize.png"/></h2>
<li class="category"><h3>User Experience</h3> - Make your content more enjoyable / easier to use.</li>
<li> <a href="html/browser/useragent.html"> User Agent </a> Detect what browser your users have </li>
- <li> <a href="html/html5/inputtypes.html">Input Types</a> <img src="img/html5_logo_sm.png"/> Associates virtual keyboard variant with input fields</li>
- <li> <a href="html/apis/ui.html"> Dialog API</a> <img src="img/gear.png"/> Manipulate system dialog boxes.</li>
- <li> <a href="html/apis/menu.html">Menu API</a> <img src="img/gear.png"/> Manipulate menu items for the application.</li>
+ <li> <a href="html/html5/inputtypes.html">Input Types</a> <img src="img/html5_logo_sm.png" alt="html5 logo"/> Associates virtual keyboard variant with input fields</li>
+ <li> <a href="html/apis/ui.html"> Dialog API</a> <img src="img/gear.png" alt="gear icon"/> Manipulate system dialog boxes.</li>
+ <li> <a href="html/apis/menu.html">Menu API</a> <img src="img/gear.png" alt="gear icon"/> Manipulate menu items for the application.</li>
<li> <a href="html/usecase/spacing.html"> Use of whitespace </a> Give users enough space for interaction</li>
<li> <a href="html/usecase/progress.html"> Progress indicator </a> Display progress while events processing</li>
- <li> <a href="html/css3/transformations.html"> Transformations </a> <img src="img/css3_logo.png" width="20"/> Move, scale and rotate in 2D or 3D</li>
- <li> <a href="html/css3/animations.html"> Animations </a> <img src="img/css3_logo.png" width="20"/> Use animation to provide visual feedback </li>
+ <li> <a href="html/css3/transformations.html"> Transformations </a> <img src="img/css3_logo.png" width="20" alt="css logo"/> Move, scale and rotate in 2D or 3D</li>
+ <li> <a href="html/css3/animations.html"> Animations </a> <img src="img/css3_logo.png" width="20" alt="css logo"/> Use animation to provide visual feedback </li>
<li> <a href="html/browser/window.html"> Window object</a> Represents an open window in a browser. </li>
<li class="category"><h3>User Input</h3> - Respond to physical user input. </li>
- <li> <a href="html/browser/touch.html"> Touch Events</a> <img src="img/globe.png"/> Respond to Touch events (start, move, end)</li>
+ <li> <a href="html/browser/touch.html"> Touch Events</a> <img src="img/globe.png" alt="globe icon"/> Respond to Touch events (start, move, end)</li>
<li> <a href="html/browser/gestures.html">Swipe Gestures</a> Transform touch events into swipe gestures</li>
<li> <a href="html/browser/keyevents.html"> Keyboard events </a> Listen for key press events </li>
- <li> <a href="html/browser/motion.html"> Accelerometer </a> <img src="img/html5_logo_sm.png"/> Measure the 3D motion of a physical device </li>
- <li> <a href="html/browser/zoom.html"> Pinch To Zoom </a> <img src="img/globe.png"/> Control default pinch-to-zoom behavior</li>
+ <li> <a href="html/browser/motion.html"> Accelerometer </a> <img src="img/html5_logo_sm.png" alt="html5 logo"/> Measure the 3D motion of a physical device </li>
+ <li> <a href="html/browser/zoom.html"> Pinch To Zoom </a> <img src="img/globe.png" alt="globe icon"/> Control default pinch-to-zoom behavior</li>
<!--
TO DO CREATE THE FOLLOWING:
<li> <a href="html/apis/focus.html"> Focus navigation </a> </li>
@@ -87,8 +87,8 @@ <h2 id="lookfeelheader">Look and Feel <img src="img/minimize.png"/></h2>
-->
<li class="category"><h3>Graphics</h3> - Provide amazing visual effects.</li>
- <li> <a href="html/browser/flashplayer.html"> Flash </a> <img src="img/globe.png"/> Use Flash content in your app </li>
- <li> <a href="html/html5/canvas.html">Canvas</a> <img src="img/html5_logo_sm.png"/> Use HTML5 canvas content</li>
+ <li> <a href="html/browser/flashplayer.html"> Flash </a> <img src="img/globe.png" alt="globe icon"/> Use Flash content in your app </li>
+ <li> <a href="html/html5/canvas.html">Canvas</a> <img src="img/html5_logo_sm.png" alt="html5 logo"/> Use HTML5 canvas content</li>
<!--
TO DO CREATE THE FOLLOWING:
<li> <a href="html/browser/webgl.html"> WebGL </a> </li>
@@ -99,15 +99,15 @@ <h2 id="lookfeelheader">Look and Feel <img src="img/minimize.png"/></h2>
<li></li>
</ul>
- <h2 id="functionheader">Functionality <img src="img/minimize.png"/></h2>
+ <h2 id="functionheader">Functionality <img src="img/minimize.png" alt="minimize icon"/></h2>
<ul id="functioncontent" class="section">
<li class="category"><h3>Storage</h3> - Memory or file system</li>
- <li> <a href="html/apis/dir.html">Directory API</a> <img src="img/gear.png"/> Interact with directories on the file system.</li>
- <li> <a href="html/apis/file.html">File API</a> <img src="img/gear.png"/> Interact with files on the file system.</li>
- <li> <a href="html/html5/storage.html">LocalStorage &amp; SessionStorage</a> <img src="img/html5_logo_sm.png"/> Save key/value string pairs in memory </li>
- <li> <a href="html/html5/db.html">Web Database</a> <img src="img/html5_logo_sm.png"/> Relational database storage (SQLlite)</li>
- <li> <a href="html/html5/cache/cache.html">Application Cache</a> <img src="img/html5_logo_sm.png"/> Automatic offline storage for remote content </li>
- <li> <a href="html/html5/file.html">File Reader</a> <img src="img/html5_logo_sm.png"/> Read file details from local system </li>
+ <li> <a href="html/apis/dir.html">Directory API</a> <img src="img/gear.png" alt="gear icon"/> Interact with directories on the file system.</li>
+ <li> <a href="html/apis/file.html">File API</a> <img src="img/gear.png" alt="gear icon"/> Interact with files on the file system.</li>
+ <li> <a href="html/html5/storage.html">LocalStorage &amp; SessionStorage</a> <img src="img/html5_logo_sm.png" alt="html5 logo"/> Save key/value string pairs in memory </li>
+ <li> <a href="html/html5/db.html">Web Database</a> <img src="img/html5_logo_sm.png" alt="html5 logo"/> Relational database storage (SQLlite)</li>
+ <li> <a href="html/html5/cache/cache.html">Application Cache</a> <img src="img/html5_logo_sm.png" alt="html5 logo"/> Automatic offline storage for remote content </li>
+ <li> <a href="html/html5/file.html">File Reader</a> <img src="img/html5_logo_sm.png" alt="html5 logo"/> Read file details from local system </li>
<li> <a href="html/usecase/upload.html"> Upload a file </a> Transfer a local file to remote Web server </li>
<!--
TO DO CREATE THE FOLLOWING:
@@ -115,40 +115,40 @@ <h2 id="functionheader">Functionality <img src="img/minimize.png"/></h2>
-->
<li class="category">Multimedia</li>
- <li> <a href="html/apis/audio.html">Audio API</a> <img src="img/gear.png"/> Listing of supported audio functionality </li>
- <li> <a href="html/apis/audioplayer.html">Audio Player API</a> <img src="img/gear.png"/> Plays audio using Java extension.</li>
- <li> <a href="html/html5/audio.html">Audio</a> <img src="img/html5_logo_sm.png"/> Play audio natively through web engine</li>
- <li> <a href="html/html5/video.html">Video</a> <img src="img/html5_logo_sm.png"/> Play video natively through web engine</li>
+ <li> <a href="html/apis/audio.html">Audio API</a> <img src="img/gear.png" alt="gear icon"/> Listing of supported audio functionality </li>
+ <li> <a href="html/apis/audioplayer.html">Audio Player API</a> <img src="img/gear.png" alt="gear icon"/> Plays audio using Java extension.</li>
+ <li> <a href="html/html5/audio.html">Audio</a> <img src="img/html5_logo_sm.png" alt="html5 logo"/> Play audio natively through web engine</li>
+ <li> <a href="html/html5/video.html">Video</a> <img src="img/html5_logo_sm.png" alt="html5 logo"/> Play video natively through web engine</li>
<li class="category">Device Harware Access</li>
- <li> <a href="html/apis/camera.html">Camera API</a> <img src="img/gear.png"/> Use camera to capture pictures and videos</li>
- <li> <a href="html/apis/microphone.html">Microphone API</a> <img src="img/gear.png"/> Record audio from the microphone</li>
- <li> <a href="html/html5/geo.html">Geolocation</a> <img src="img/html5_logo_sm.png"/> Get GPS coordinates (HTML5 solution)</li>
- <li> <a href="html/browser/gps.html"> GPS </a> <img src="img/globe.png"/> Get GPS coordinates (legacy BlackBerry solution) </li>
+ <li> <a href="html/apis/camera.html">Camera API</a> <img src="img/gear.png" alt="gear icon"/> Use camera to capture pictures and videos</li>
+ <li> <a href="html/apis/microphone.html">Microphone API</a> <img src="img/gear.png" alt="gear icon"/> Record audio from the microphone</li>
+ <li> <a href="html/html5/geo.html">Geolocation</a> <img src="img/html5_logo_sm.png" alt="html5 logo"/> Get GPS coordinates (HTML5 solution)</li>
+ <li> <a href="html/browser/gps.html"> GPS </a> <img src="img/globe.png" alt="globe icon"/> Get GPS coordinates (legacy BlackBerry solution) </li>
<li class="category">Device OS Integration</li>
- <li> <a href="html/apis/app.html"> Application API</a> <img src="img/gear.png"/> Application level Functions and attributes </li>
- <li> <a href="html/apis/appevent.html"> Application Events API</a> <img src="img/gear.png"/> Access events triggered by the application</li>
- <li> <a href="html/apis/system.html">System API</a> <img src="img/gear.png"/> System level functions and attributes</li>
- <li> <a href="html/apis/systemevent.html"> System Events API</a> <img src="img/gear.png"/> Access events triggered by the system</li>
- <li> <a href="html/apis/identity.html">Identity API</a> <img src="img/gear.png"/> BlackBerry Smartphone user and account information</li>
- <li> <a href="html/apis/invoke.html">Invoke API</a> <img src="img/gear.png"/> Launch external applications</li>
- <li> <a href="html/browser/schemes.html"> URI schemes </a> <img src="img/globe.png"/> URI schemes supported by the Web engine </li>
+ <li> <a href="html/apis/app.html"> Application API</a> <img src="img/gear.png" alt="gear icon"/> Application level Functions and attributes </li>
+ <li> <a href="html/apis/appevent.html"> Application Events API</a> <img src="img/gear.png" alt="gear icon"/> Access events triggered by the application</li>
+ <li> <a href="html/apis/system.html">System API</a> <img src="img/gear.png" alt="gear icon"/> System level functions and attributes</li>
+ <li> <a href="html/apis/systemevent.html"> System Events API</a> <img src="img/gear.png" alt="gear icon"/> Access events triggered by the system</li>
+ <li> <a href="html/apis/identity.html">Identity API</a> <img src="img/gear.png" alt="gear icon"/> BlackBerry Smartphone user and account information</li>
+ <li> <a href="html/apis/invoke.html">Invoke API</a> <img src="img/gear.png" alt="gear icon"/> Launch external applications</li>
+ <li> <a href="html/browser/schemes.html"> URI schemes </a> <img src="img/globe.png" alt="globe icon"/> URI schemes supported by the Web engine </li>
<li> <a href="html/browser/navigator.html"> Navigator object</a> Provides information about the current platform </li>
- <li> <a href="html/usecase/content.html"> MIME</a> <img src="img/globe.png"/> How to open 3rd party file MIME types</li>
- <li> <a href="html/apis/phone.html">Phone</a> <img src="img/gear.png"/> Information about active BlackBerry Smartphone phone accounts.</li>
+ <li> <a href="html/usecase/content.html"> MIME</a> <img src="img/globe.png" alt="globe icon"/> How to open 3rd party file MIME types</li>
+ <li> <a href="html/apis/phone.html">Phone</a> <img src="img/gear.png" alt="gear icon"/> Information about active BlackBerry Smartphone phone accounts.</li>
<!--
TO DO CREATE THE FOLLOWING:
- <li> <a href="html/apis/message.html">Message</a> <img src="img/gear.png"/> </li>
- <li> <a href="html/apis/camera.html">Find</a> <img src="img/gear.png"/> </li>
- <li> <a href="html/apis/pim.html">PIM</a> <img src="img/gear.png"/> </li>
+ <li> <a href="html/apis/message.html">Message</a> <img src="img/gear.png" alt="gear icon"/> </li>
+ <li> <a href="html/apis/camera.html">Find</a> <img src="img/gear.png" alt="gear icon"/> </li>
+ <li> <a href="html/apis/pim.html">PIM</a> <img src="img/gear.png" alt="gear icon"/> </li>
-->
<li class="category">Network Connectivity</li>
- <li> <a href="html/html5/websockets.html">Web Sockets</a> <img src="img/html5_logo_sm.png"/> Two-way communication with a remote host </li>
- <li> <a href="html/html5/offline.html">Network Connectivity</a> <img src="img/html5_logo_sm.png"/> Detect whether network connection is active </li>
- <li> <a href="html/browser/protocols.html"> Protocols </a> <img src="img/globe.png"/> Protocols supported by the Web engine</li>
- <li> <a href="html/browser/carriernetwork.html">Carrier Network</a> <img src="img/globe.png"/> Information about active carrier network</li>
+ <li> <a href="html/html5/websockets.html">Web Sockets</a> <img src="img/html5_logo_sm.png" alt="html5 logo"/> Two-way communication with a remote host </li>
+ <li> <a href="html/html5/offline.html">Network Connectivity</a> <img src="img/html5_logo_sm.png" alt="html5 logo"/> Detect whether network connection is active </li>
+ <li> <a href="html/browser/protocols.html"> Protocols </a> <img src="img/globe.png" alt="globe icon"/> Protocols supported by the Web engine</li>
+ <li> <a href="html/browser/carriernetwork.html">Carrier Network</a> <img src="img/globe.png" alt="globe icon"/> Information about active carrier network</li>
<!--
TO DO CREATE THE FOLLOWING:
<li> <a href="html/apis/push.html">Push</a> </li>
@@ -165,15 +165,16 @@ <h2 id="functionheader">Functionality <img src="img/minimize.png"/></h2>
<li> <a href="html/usecase/twitter.html"> Twitter Web APIs </a> Integrate your Web content with Twitter </li>
<li class="category">Performance</li>
- <li> <a href="html/html5/workers.html">Web Workers</a> <img src="img/html5_logo_sm.png"/> Multi-thread JavaScript processing </li>
+ <li> <a href="html/html5/workers.html">Web Workers</a> <img src="img/html5_logo_sm.png" alt="html5 logo"/> Multi-thread JavaScript processing </li>
<li> <a href="html/browser/dhtml.html"> DHTML </a> Update HTML dynamically after page load</li>
<li> <a href="html/browser/xhr.html"> XmlHttpRequest </a> Asynchronous HTTP requests from client</li>
<li> <a href="html/css3/sprite.html"> CSS Sprites </a> Reduce HTTP requests for image resources </li>
+ <li> <a href="html/browser/typedarrays.html"> Typed Arrays </a> Fast access to binary data arrays </li>
<li></li>
</ul>
- <h2 id="testingheader">Testing <img src="img/minimize.png"/></h2>
+ <h2 id="testingheader">Testing <img src="img/minimize.png" alt="minimize icon"/></h2>
<ul id="testingcontent" class="section">
<li class="category">BlackBerry</li>
<li> <a href="html/debug/ripple.html"> Ripple </a> Mobile emulator for BlackBerry Smartphone and PlayBook </li>
@@ -189,10 +190,10 @@ <h2 id="testingheader">Testing <img src="img/minimize.png"/></h2>
<div id="legend">
<b>Legend</b>:
<ul>
- <li> <img src="img/html5_logo_sm.png"/> HTML5 feature </li>
- <li> <img src="img/css3_logo.png" width="20"/> CSS3 feature </li>
- <li> <img src="img/gear.png"/> WebWorks JavaScript APIs feature </li>
- <li> <img src="img/globe.png"/> BlackBerry Web engine feature</li>
+ <li> <img src="img/html5_logo_sm.png" alt="html5 logo"/> HTML5 feature </li>
+ <li> <img src="img/css3_logo.png" width="20" alt="css logo"/> CSS3 feature </li>
+ <li> <img src="img/gear.png" alt="gear icon"/> WebWorks JavaScript APIs feature </li>
+ <li> <img src="img/globe.png" alt="globe icon"/> BlackBerry Web engine feature</li>
</ul>
</div>
148 kitchenSink/js/browser/typedarrays.js
View
@@ -0,0 +1,148 @@
+/*
+ * Copyright 2011 Research In Motion Limited.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+ function isNotSupported(id)
+{
+ document.getElementById(id.toLowerCase()).innerHTML = id + " is not supported by this application.";
+}
+function runArrayTest(id)
+{
+ var arr;
+ var arrCopy;
+ var size = 10000000; //100M
+
+ try
+ {
+
+ //First - create the desired array type:
+ switch(id.toLowerCase())
+ {
+ case "float32array":
+ if ((typeof Float32Array) === "undefined")
+ {
+ isNotSupported(id);
+ return false;
+ }
+ arr = new Float32Array(size);
+ arrCopy = new Float32Array(arr.length);
+ break;
+ case "int8array":
+ if ((typeof Int8Array) == "undefined")
+ {
+ isNotSupported(id);
+ return false;
+ }
+ arr = new Int8Array(size);
+ arrCopy = new Int8Array(arr.length);
+ break;
+ case "uint8array":
+ if ((typeof Uint8Array) == "undefined")
+ {
+ isNotSupported(id);
+ return false;
+ }
+ arr = new Uint8Array(size);
+ arrCopy = new Uint8Array(arr.length);
+ break;
+ case "array":
+ if ((typeof Array) == "undefined")
+ {
+ isNotSupported(id);
+ return false;
+ }
+ arr = new Array(size);
+ arrCopy = new Array(arr.length);
+ break;
+ default:
+ alert("Unknown array type: " + id);
+ }
+
+ //Run the performance tests:
+ var sb = new StringBuilder("Results (ms) for " + id + " size " + size + " :");
+ sb.append("<ul>");
+ var i, l;
+
+ var start = new Date();
+ for(i = 0, l = arr.length; i < l; i++)
+ {
+ arr[i] = 0.1234567890123456; //update ever index in the array
+ }
+ sb.append("<li>Write: " + ( + new Date() - start ) + "</li>");
+
+
+
+ var val = 0;
+ start = new Date();
+ for(i = 0, l = arr.length; i < l; i++)
+ {
+ val = arr[i]; //read from every index in the array
+ }
+ sb.append("<li>Read: " + ( +new Date() - start ) + "</li>");
+
+
+
+ start = new Date();
+ for(i = 0, l = arr.length; i < l; i++)
+ {
+ arrCopy[i] = arr[i];
+ }
+ sb.append("<li>Loop Copy: " + ( + new Date() - start ) + "</li>");
+
+/*
+ start = new Date();
+ var arrSliceCopy;
+ switch(id.toLowerCase())
+ {
+ case "float32array":
+ arrSliceCopy = new Float32Array(arr.slice(0, arr.length));
+ break;
+
+ case "int8array":
+ arrSliceCopy = new Int8Array(arr.slice(0, arr.length));
+ break;
+
+ case "uint8array":
+ arrSliceCopy = new Uint8Array(arr.slice(0, arr.length));
+ break;
+
+ case "normalarray":
+ arrSliceCopy = new Array(arr.slice(0, arr.length));
+ break;
+
+ default:
+ alert("Unknown array type: " + id);
+ }
+ sb.append( "Slice Copy: " + ( + new Date() - start ) );
+*/
+ sb.append("</ul>");
+ document.getElementById(id.toLowerCase()).innerHTML = sb.toString();
+
+ }
+ catch (e)
+ {
+ debug.log("runArrayTest", e, debug.exception);
+ }
+}
+
+function doPageLoad(event)
+{
+ runArrayTest("Float32Array");
+ runArrayTest("Int8Array");
+ runArrayTest("Uint8Array");
+ runArrayTest("Array");
+}
+
+window.addEventListener(