Now: Tutorial for Web and Software Design > XML > XML Mobile > XML Content
> All Aboard AJAX, HTML Canvas, and the Supertrain [Bookmark it]
All Aboard AJAX, HTML Canvas, and the Supertrain

All Aboard AJAX, HTML Canvas, and the Supertrain
by Dave Hoover |

Now I'll update the client side to display the hotspots. Because hotspot status changes much less frequently than train status, I'll use a separate window.setInterval to poll for hotspot data once an hour.

docroot/redwood.html



...

<script type="text/javascript">

  ...

  var hotspots = []

  var canvas = undefined



  if ($("redwood").getContext) {

    canvas = $("redwood").getContext("2d")

    window.setInterval(updateCanvas, 1000 * 2)

    window.setInterval(updateHotspots, 1000 * 60 * 60)

    updateCanvas()

    updateHotspots()

  }



  function updateHotspots() {

    new Ajax.Request("/train/hotspots",

                     { onComplete: function(request) {

                         hotspots = eval(request.responseText)

                       }

                     })

  }



  function updateCanvas() {

    new Ajax.Request("/train/line",

                     { onComplete: function(request) {

                         var jsonData = eval(request.responseText)

                         if (jsonData == undefined) { return }

                         clearScreen()

                         jsonData.each(function(data) {

                           trains[data.track].update(data.location)

                         })

                         drawTracks()

                         drawHotspots()

                       }

                     })

  }

  ...

  function drawHotspots() {

    hotspots.each(function(hotspot) {

      tracks[hotspot.track].drawHotspot(hotspot.location)

    })

  }



  function Track(y) {

    ...

    this.hotspotRadius = 6

    this.hotspotColor = "red"

    this.drawHotspot = drawHotspot

  }

  ...

  function drawHotspot(location) {

    canvas.moveTo(location, this.y)

    canvas.beginPath()

    canvas.fillStyle = this.hotspotColor

    canvas.arc(location, this.y, this.hotspotRadius, 0, Math.PI, false)

    canvas.closePath()

    canvas.fill()

  }

  ...

</script>

...

Figure 7
Figure 7.

That completes the proof of concept! My customer from the State of Washington is satisfied and has asked me to hook the TrainSpotter class into the production messaging service for a test run against the real Woodinville-Redmond Supertrain line. If all goes well, I'm going to have a lot of work to do...

Resources

  • Supertrain Example Files
  • Canvas Tutorial
  • Prototype JavaScript Framework
  • Javascript
  • Ruby
  • WEBrick
  • The Lightweight Visual Thesaurus
  • Train images
  • WordNet

Prev  [1] [2] [3] [4] [5] [6] 

[Bookmark][Print] [Close][To Top]
  • Prev Article-XML:

  • Next Article-XML:
  • Related Materias
    Push, Pull, Next!
    Seeking Equality
    Comparing CSS and XSL: A R
    Visualizing XSLT in SVG
    Controlling the DOCTYPE an
    Finding the First, Last, B
    A Realists SMIL Manifesto,
    Comparing and Replacing St
    Splitting and Manipulating
    Template Languages in XSLT
    Topics
    Photoshop Tutorial
     

    Special Effect

      3D Effect
      Photoshop Articles
    Programming Tutorial
     

    C/C++ Tutorial

      Visual Basic
      C# Tutorial
    Database Tutorial
     

    MySQL Tutorial

      MS SQL Tutorial
      Oracle Tutorial
    Graphic Design Tutorial
     

    Coreldraw Tutorial

      Illustrator Tutorial
      3D Graphics Articles
    Webmaster Articles
     

    Domain Service

      Web Hosting
      Site Promotion
    Java Tutorial&Articles
     

    Java Servlets

      JavaEE Tutorial
     

    JavaBeans Tutorial

    XML Tutorial&Articles
     

    XML Style Tutorial

      AJAX Tutorial
      XML Mobile
    Flash Tutorial&Articles
     

    Flash Video

      Action Script
      Flash Articles
    OS Tutorial&Articles
     

    Linux Tutorial

      Symbian Tutorial
      MacOS Tutorial