SlideShare uma empresa Scribd logo
1 de 111
Baixar para ler offline
Wednesday, November 18, 2009
Browser, Mobile, Cloud, Social, Geo
             Portrait of the developer as a kid in a candy store




        Patrick Chanezon
        Developer Advocate, Google
        http://twitter.com/chanezon

        November 17, 2009
        Argentina
        #devfest09




                               Source Marshall Astor http://www.flickr.com/photos/lifeontheedge/711086777/sizes/l/#cc_license


Wednesday, November 18, 2009
Las calles de Buenos Aires ya son mi entraña




                         “A mi se me hace cuento que empezo Buenos Aires:
                         La juzgo tan eterna como el agua y el aire.”

                         “Hard to believe Buenos Aires had any beginning.
                         I feel it to be as eternal as air and water”
                         Fervor de Buenos Aires (1923)
                                         Photo public domain http://commons.wikimedia.org/wiki/File:Jorge_Luis_Borges_Hotel.jpg
Wednesday, November 18, 2009
The Web Platform is Accelerating




                                                                                                                      Chrome 2.0:
                                                                                                                      May 21, 2009
                                                                                                                      canvas
            User Experience




                                                                                                       Firefox 3.5b4: video
                                                                                                       Apr 27, 2009   geolocation
                                                                                                       canvas         app cache
                                                                                                       video          database
                                                                                                       geolocation workers
                                                                                                       app cache
                                                                                          Android 1.5: database
                                                                                          Apr 13, 2009 workers
                                                                                          canvas
                                                                           Opera Labs:    geolocation
                                                                           Mar 26, 2009   app cache
                                                            Safari 4.0b:
                                                                           canvas         database
                                                            Feb 29, 2009
                                                                           video          workers
                                                            canvas
                                         XHR   iPhone 2.2: video           geolocation
                                       CSS     Nov 22, 2008 app cache
                                 DOM           canvas       database
                                               app cache workers
                              HTML
                                               database

                                                                                                                 native    web

                              1990 -- 2008 Q408                                Q109                            Q209          ...

Wednesday, November 18, 2009
And It’s Solving Key Developer Challenges




                                       Graphics   Location     Storage   Speed
            User Experience




                                         XHR
                                       CSS
                                 DOM
                              HTML



                                                                           native   web

                              1990 -- 2008 Q408              Q109         Q209       ...

Wednesday, November 18, 2009
More Developers
                                                   300
                                                           chrome
                                                           firefox 3.1+
            Monthly Contributors to OSS Browsers




                                                           firefox 2.0-3.0
                                                           webkit
                                                   225




                                                   150




                                                    75




                                                     0
                                                         2002    2003        2004   2005   2006   2007   2008   2009

Wednesday, November 18, 2009
More Speed
                                        80
            SunSpider Runs Per Minute




                                        60


                                                           100x improvement
                                                           in JavaScript performance
                                        40




                                        20




                                         0
                                             2001   2003   2005   2007   Q108   Q208   Q308   Q408   Q109

Wednesday, November 18, 2009
More Users
                                    450




                                    350
            OSS Browser Users (M)




                                    250




                                    150




                                     50
                                          2005   2006   2007   2008   2009

Wednesday, November 18, 2009
A More Powerful Web




                               5>2
Wednesday, November 18, 2009
Cautionary Tales of Latent Lemonade




                                             AJAX (2004)

                               xml (1998)


                     css              xhr
                   (1996)           (1999)




Wednesday, November 18, 2009
HTML 5: A Chance to Do Things Differently




Wednesday, November 18, 2009
canvas             video   geolocation   app cache &   web workers
                                                      database

Wednesday, November 18, 2009
Until Recently, You Couldn’t Draw on the Web

                                   0
                               0                        X

                                           y

                                       x




                                                       height
                                   Y           width




Wednesday, November 18, 2009
And Graphics Weren’t Very Interactive




                               javascript:onClick(Draw());


Wednesday, November 18, 2009
The Usual Options Do This...
                                             Silverlight
                               VML
                                     Flash




Wednesday, November 18, 2009
... But canvas is Intrinsic to the Web

                                       Document Object Model (DOM) Specification
                                       Original: http://www.w3.org/TR/REC-DOM-Level-1/
                                       Latest: http://www.w3.org/TR/DOM-Level-3-Core/
                                       Contributors: Netscape, Sun, Microsoft, W3C, IBM,
                                DOM    Novell, JavaSoft, SoftQuad Inc., Inso EPS, Texcel
                                       Research, Arbortext
            Transparent Stack




                                       Hypertext Markup Language (HTML)
                                       Original: http://tools.ietf.org/html/rfc1866
                                       Latest: http://www.w3.org/TR/html5/
                                HTML   Contributors: T. Berners-Lee, D. Connolly, L. Masinter,
                                       MIT, W3C, AT&T, IBM, Microsoft, Netscape, Novell,
                                       SoftQuad, Spyglass, Adobe, Lotus, CWI, Reuters,
                                       JavaSoft, HP, GRIF, Sun, Opera, Mozilla, Google, Apple

                                       Hypertext Transfer Protocol (HTTP)
                                       Original: http://tools.ietf.org/html/rfc1945
                                       Latest: http://tools.ietf.org/html/rfc2616
                                       Contributors: UC Urvine, Compaq, MIT, Xerox,
                                HTTP   Microsoft, W3C, T. Berners-Lee, R. Fielding, J. Gettys,
                                       J. Mogul, H. Frystyk, L. Masinter, P. Leach




Wednesday, November 18, 2009
// canvas
             defines drawing
             and animation
             APIs with pixel-
             level control

Wednesday, November 18, 2009
canvas demos




Wednesday, November 18, 2009
canvas Piggybacks Overall Browser Speed




                                                        SunSpider Runs Per Minute
Wednesday, November 18, 2009
Is the Web Ready for 3D?




Wednesday, November 18, 2009
Canvas3D, WebGL
                               O3D code.google.com/apis/o3d




Wednesday, November 18, 2009
HTML 5 Support

                                  Chrome   Firefox   Safari   Opera
                        canvas



                          video



              geolocation



                  app cache



                    database



                      workers




Wednesday, November 18, 2009
canvas             video   geolocation   app cache &   web workers
                                                      database

Wednesday, November 18, 2009
Video is Complicated, and Outside Your Control




Wednesday, November 18, 2009
So What
                               Would
                               Occam Do?

       © topatoco.com


Wednesday, November 18, 2009
// HTML 5 makes
             <video> as easy
             as <img>



Wednesday, November 18, 2009
<video> demos




Wednesday, November 18, 2009
HTML 5 Support

                                  Chrome   Firefox   Safari   Opera
                        canvas



                          video



              geolocation



                  app cache



                    database



                      workers




Wednesday, November 18, 2009
canvas             video   geolocation   app cache &   web workers
                                                      database

Wednesday, November 18, 2009
Life’s Better with Location
                                                  2.8 mi

                                                  Places




                                Social   Ads                        Games
                       CRM                                 Photos




                                                           2.1 mi
                                                                    1.1 mi

                                         500 ft

                                 20 ft

                        75 ft
Wednesday, November 18, 2009
But GPS and IP Aren’t Good Enough




                               1. too slow
                               2. too constrained
                               3. too fuzzy

Wednesday, November 18, 2009
1) Cell ID and WiFi Solve The Data Problem...




Wednesday, November 18, 2009
Wednesday, November 18, 2009
2) ...And Browsers Are Now Location-Enabled




Wednesday, November 18, 2009
// the
             geolocation api
             brings browser-
             based location
             to your apps

Wednesday, November 18, 2009
geolocation demos




Wednesday, November 18, 2009
HTML 5 Support

                                  Chrome   Firefox   Safari        Opera
                        canvas



                          video



              geolocation
                                                        (iPhone)


                  app cache



                    database



                      workers




Wednesday, November 18, 2009
canvas             video   geolocation   app cache &   web workers
                                                      database

Wednesday, November 18, 2009
Web Apps Need to Work Everywhere




Wednesday, November 18, 2009
// database and
             app cache store
             user data and
             app resources
             locally

Wednesday, November 18, 2009
app cache & database demos




Wednesday, November 18, 2009
Wednesday, November 18, 2009
index.html
                                       <title>Google Maps</title>
                         Google Maps
                                       <script src="/usr/lib/mojo/framework/mojo.js"
                                         type="text/javascript" x-mojo-version="1">
                                         </script>
                                       <script src="app/assistants/stage-assistant.js"
                                         type="text/javascript"></script>




                                       map-assistant.js
                                       this.controller.serviceRequest
                                       {
                                           'palm://com.palm.location',
                                           {
                                              method: "getFix",
                                              parameters: {mode: "auto"},
                                              onSuccess: this.goFix,
                                              onFailure: this.error
                                           }
                                       };




Wednesday, November 18, 2009
webOS and HTML 5

              • CSS Transformations
              • HTML 5 database for history & bookmarks
              • Canvas in calendar application
              • Extensions
                     - Accelerometer
                     - ...




Wednesday, November 18, 2009
webOS Accelerometer API

              • Shake: distinct start, stop with magnitude
              • Orientation
              • Raw acceleration
                     - Individual acceleration per axis
                     - Individual Pitch, Roll, and Yaw

              • ... all available from JavaScript using the
              DOM Level 2 interface




Wednesday, November 18, 2009
Code Snippet
             <script type="text/javascript">
               // Set up accelerometer event handlers
               window.addEventListener( "shakestart", beginShaking, true );
               window.addEventListener( "shaking", isShaking, true );
               window.addEventListener( "shakeend", endShaking, true );
               window.addEventListener( "acceleration", handleAccel, true );
               function isShaking(event) {
                     // event.magnitude
                     // ...
               }
               function handleAccel(event) {
                     // event.accelX, event.accelY, event.accelZ
                     // event.pitch, event.roll, event.yaw
                     // ...
                   }
             </script>




Wednesday, November 18, 2009
webOS and HTML 5
                        Converge mobile and desktop
                        web application development




Wednesday, November 18, 2009
HTML 5 Support

                                  Chrome   Firefox   Safari        Opera
                        canvas



                          video



              geolocation
                                                        (iPhone)


                  app cache
                                                                     (mobile)


                    database
                                                                     (mobile)


                      workers




Wednesday, November 18, 2009
canvas             video   geolocation   app cache &   web workers
                                                      database

Wednesday, November 18, 2009
A More Powerful Web == More Powerful Apps




Wednesday, November 18, 2009
But More Power == More Responsibility


                               I will not hose the browser with JavaScript

                               I will not hose the browser with JavaScript

                               I will not hose the browser with JavaScript

                               I will not hose the browser with JavaScript

                               I will not hose the browser with JavaScript

                               I will not hose the browser with JavaScript



Wednesday, November 18, 2009
// web workers
             defines an API
             for running
             background
             scripts

Wednesday, November 18, 2009
web workers demos




Wednesday, November 18, 2009
HTML5 Support

                                  Chrome   Firefox   Safari        Opera
                        canvas



                          video



              geolocation
                                                        (iPhone)


                  app cache
                                                                     (mobile)


                    database
                                                                     (mobile)


                      workers
                                                                     (mobile)



Wednesday, November 18, 2009
HTML5 and SVG not available in IE?
           • ChromeFrame plugin implements HTML5 in IE
           • Shim libraries using Flash or VML to implement features
                 – SVGWeb: SVG
                 – Explorercanvas: Canvas
                 – Video for Everybody: Video




            55



Wednesday, November 18, 2009
Chrome Extensions
           • Programs that enhance Google Chrome's functionality

           • Written in HTML, CSS, and JavaScript

           • Integrated using a simple API

           • Developed iteratively




            56



Wednesday, November 18, 2009
A More Powerful Web, Made Easier




Wednesday, November 18, 2009
Nubes
    “¿Qué son las nubes? ¿Una arquitectura
    del azar? Quizá Dios las necesita
    para la ejecución de Su infinita
    obra y son hilos de la trama oscura.
    Quizá la nube sea no menos vana
    que el hombre que la mira en la
    mañana.”

    “What are the clouds? An architecture of
    chance? Perhaps they are the necessary
    things
    from which God weaves his vast
    imaginings, threads of a web of infinite
    expanse. Maybe the cloud is emptiness
    returning, just like the man who watches
    it this morning.”
    Borges, Nubes II, Los Conjurados (1985)


Wednesday, November 18, 2009
App Engine and Google Web Toolkit (GWT)
           Easier to Scale and Optimize Your App




Wednesday, November 18, 2009
200,000+
                   Developers
Wednesday, November 18, 2009
80,000+ Applications
                                                      700
                                                                                                                                               9:30am EST:
            WhiteHouse.gov Queries Per Second (QPS)


                                                                                                                                               Deadline for
                                                                                                                                               submissions
                                                      600
                                                                                             5:00pm EST:
                                                                                             Link on Google
                                                                                             homepage
                                                      500
                                                                                                                                                  11:30am EST:
                                                                                                                                                  Townhall begins

                                                      400
                                                                                    Afternoon EST:
                                                                                    NPR, NYTimes,
                                                                                    CNN coverage
                                                      300



                                                      200     6:45pm EST:
                                                              WhiteHouse.gov
                                                              kick-off blog post                                                                      5:00pm EST:
                                                                                                                                                      WhiteHouse.gov
                                                                                                                                                      wrap-up blog post
                                                      100



                                                        0
                                                            18:00 21:00 24:00 3:00 6:00 9:00 12:00 15:00 18:00 21:00 24:00 3:00 6:00 9:00 12:00 15:00 18:00 21:00 24:00 3:00




Wednesday, November 18, 2009
Launched in the Last 12 Months




                               X   memcache API
                               X SSL support
                               X   system status
                               X paid quota
                               X   cron support
                               X database import
                               X java runtime
Wednesday, November 18, 2009
Launched in the Last 2 Months




                               X   Background processing
                               X XMPP
                               X Incoming email
                               X Datastore stats




Wednesday, November 18, 2009
• Large object store
              • Database export


Wednesday, November 18, 2009
Wednesday, November 18, 2009
Java + App Engine demo




Wednesday, November 18, 2009
UI in the Front...




                                      ...Hosting in the Back



Wednesday, November 18, 2009
GWT Browser-Proofs Your JavaScript Code...



                                          IE

                                        Firefo
                                               x




                                       S afari



                                        Chrome




Wednesday, November 18, 2009
...But CSS Headaches Persist




Wednesday, November 18, 2009
Coming in GWT 2.0: In-Browser Debugging




Wednesday, November 18, 2009
Rich Applications, Extra-Large Codebases




Wednesday, November 18, 2009
LOADING
Wednesday, November 18, 2009
Manual Code Splitting: Not For the Faint of Heart




Wednesday, November 18, 2009
Coming in GWT 2.0: runAsync()

             // example

             public void onMySettingsLinkClicked() {

                   GWT.runAsync(new RunAsyncCallback() {

                        public void onSuccess() {
                          new MySettingsDialog().show();
                        }

                     public void onFailure(Throwable ohNoes) {
                       // indicate that something went wrong,
                       // usually a connectivity or server
                          problem
                     }
                   });
             }

Wednesday, November 18, 2009
runAsync() Helps Apps Startup More Quickly
                                                       1500
                                                                                                                    1400 KB
            Size of Initial JavaScript Download (KB)




                                                       1125




                                                        750
                                                                                     7x Decrease In
                                                                                     Initial Download Size
                                                                                     with runAsync()
                                                        375




                                                                                                                    200 KB

                                                          0
                                                              26-Nov   29-Apr   18-Jun   28-Jul   12-Sep   27-Oct   24-Dec    16-Mar

Wednesday, November 18, 2009
code.google.com/appengine
                               code.google.com/gwt




Wednesday, November 18, 2009
OpenSocial




Wednesday, November 18, 2009
Wednesday, November 18, 2009
Large Reach




                               Over 800M in a year – and more to come!


Wednesday, November 18, 2009
Global Reach




Wednesday, November 18, 2009
OpenSocial Supporting Products




            27 Google Confidential


Wednesday, November 18, 2009
Under the hood: Usage Stats

               • 315M+ App Installs
               • 85M+ Canvas Page Views / Day
               • 7,500+ Apps
               • 20+ Containers




Wednesday, November 18, 2009
The Open Stack




                               XRDS




Wednesday, November 18, 2009
Google Friend Connect




Wednesday, November 18, 2009
Google FriendConnect
                                   • Uses OpenSocial
                                     (gadgets, REST/RPC)
                                   • Allows site owners to
                                     mix in social data to
                                     existing sites
                                   • Cut and paste or
                                   • Deep integrations




Wednesday, November 18, 2009
Google Friend Connect Demos




Wednesday, November 18, 2009
TIME.com Daily Specials

           TIME.com’s Daily Specials provide a
           trusted and entertaining perspective
           on relevant current events.
           These interactive specials use photo and
           video galleries to engage the readers, and
           topics can range from important
           international events like the Pope visiting
           the Middle East) to light hearted topics like
           the Best iPhone Apps.



             Recent Popular Daily Specials             Pageviews
             • top 10 disastrous letterman interviews - 7.4mm
             • top 11 iphone applications - 5.9mm
             •10 things you can like about $4 gas      - 4.3mm
             •10 essential sites                       - 3.0mm




             Source: Omniture SiteCatalyst – Past 12 Months

Wednesday, November 18, 2009
Specials Traffic




                                 176MM
                                 From January – April 2009




Wednesday, November 18, 2009
Challenge




                               How can we make our daily Top 10’s
                                    more fun and engaging?




Wednesday, November 18, 2009
Wednesday, November 18, 2009
TIME Social Lists Demo




Wednesday, November 18, 2009
Architecture



                               Javascript APIs



                                                   JSONP


                               HTML + JavaScript




Wednesday, November 18, 2009
Wednesday, November 18, 2009
Paul Berry, HuffingtonPost




Wednesday, November 18, 2009
Wednesday, November 18, 2009
Wednesday, November 18, 2009
Google Product APIs
           Easier to Add Content and Services To Your Website

                       Search   Feeds    Translation     Calendar     Video    Comments    News




                       Maps     Charts   Contacts      Spreadsheets   Photos   Documents   Auth




Wednesday, November 18, 2009
Data Liberation Front       http://www.dataliberation.org/




        Users should be able to control the data they store in any
        of Google's products. Our team's goal is to make it
        easier to move data in and out.
Wednesday, November 18, 2009
Low-Level API Access Serves Many Needs...
                                 5




                                 4


                                                  Over 4B Google API
            Daily API Hits (B)




                                                  Hits Every Day
                                 3




                                 2




                                 1
                                     May Jun Jul Aug Sept Oct Nov Dec Jan Feb Mar Apr May

Wednesday, November 18, 2009
...But Imagine AdSense for Everything Else




                                Search               Spreadsheets




                        Video            Calendars      Maps




Wednesday, November 18, 2009
Announcing: Google Web Elements
           Copy and Paste Website Content




Wednesday, November 18, 2009
Google Web Elements demo




Wednesday, November 18, 2009
google.com/webelements




Wednesday, November 18, 2009
Android: Seven Months, By The Numbers

              • 30+ carriers in 21 countries
              •18-20 devices by the end of 2009
              • 12,000+ applications in the Android Market
              • 40+ app downloads per user
              • #2 in U.S. mobile web browsing
              • 4 platform releases, and counting...


Wednesday, November 18, 2009
code.google.com/android




Wednesday, November 18, 2009
Google Wave
           • Real time communication and collaboration platform
           • Rich set of APIs
               – Embedding
               – Gadgets
               – Robots
               – Extensions
           • Open Source protocol, Wave federation
           • Open Source server




            104



Wednesday, November 18, 2009
code.google.com/apis/wave




Wednesday, November 18, 2009
Go language
           • A systems programming language
             – expressive
             – concurrent
             – garbage-collected
           • New
           • Experimental
           • Fast
           • Safe
           • Concurrent
           • Open Source



            106



Wednesday, November 18, 2009
golang.org




Wednesday, November 18, 2009
Enjoy the candies!
                                                 http://twitter.com/chanezon


                                                 Browser
                                                     Mobile
                                                 Cloud
                                               Social
                                                      Geo




                               Demos at
                               http://delicious.com/chanezon/devfest09+demos

                                  Source Marshall Astor http://www.flickr.com/photos/lifeontheedge/711086777/sizes/l/#cc_license


Wednesday, November 18, 2009
Wednesday, November 18, 2009

Mais conteúdo relacionado

Semelhante a Browser, Mobile, Cloud, Social, Geo: Portrait of the developer as a kid in a candy store

Google html5 Tutorial
Google html5 TutorialGoogle html5 Tutorial
Google html5 Tutorialjobfan
 
Alejandro Villanueva - Google Inc.
Alejandro Villanueva - Google Inc.Alejandro Villanueva - Google Inc.
Alejandro Villanueva - Google Inc.Alejandro Corpeño
 
Google - Charla para CTOs
Google - Charla para CTOsGoogle - Charla para CTOs
Google - Charla para CTOsPalermo Valley
 
Mozilla in Vietnam 2009
Mozilla in Vietnam 2009Mozilla in Vietnam 2009
Mozilla in Vietnam 2009Gen Kanai
 
HTML5 and Google Chrome - DevFest09
HTML5 and Google Chrome - DevFest09HTML5 and Google Chrome - DevFest09
HTML5 and Google Chrome - DevFest09mihaiionescu
 
Adobe Flex: Creating Widgets for the Desktop and Web
Adobe Flex: Creating Widgets for the Desktop and WebAdobe Flex: Creating Widgets for the Desktop and Web
Adobe Flex: Creating Widgets for the Desktop and WebColin Loretz
 
Mozilla In Malaysia
Mozilla In MalaysiaMozilla In Malaysia
Mozilla In MalaysiaGen Kanai
 
CouchDB to the Edge ApacheCon EU
CouchDB to the  Edge ApacheCon EUCouchDB to the  Edge ApacheCon EU
CouchDB to the Edge ApacheCon EUChris Anderson
 
Vladimir Oane
Vladimir OaneVladimir Oane
Vladimir Oaneevensys
 
Caching, sharding, distributing - Scaling best practices
Caching, sharding, distributing - Scaling best practicesCaching, sharding, distributing - Scaling best practices
Caching, sharding, distributing - Scaling best practicesLars Jankowfsky
 
SAMT09 - Web of Data Tutorial - Part 2
SAMT09 - Web of Data Tutorial - Part 2SAMT09 - Web of Data Tutorial - Part 2
SAMT09 - Web of Data Tutorial - Part 2Bernhard Haslhofer
 
Build HTML5 App (Intel Elements 2011)
Build HTML5 App (Intel Elements 2011)Build HTML5 App (Intel Elements 2011)
Build HTML5 App (Intel Elements 2011)Ariya Hidayat
 
Elements2011 html5-app-110928141627-phpapp01
Elements2011 html5-app-110928141627-phpapp01Elements2011 html5-app-110928141627-phpapp01
Elements2011 html5-app-110928141627-phpapp01Jesse Smith
 
Embracing concurrency for fun utility and simpler code
Embracing concurrency for fun utility and simpler codeEmbracing concurrency for fun utility and simpler code
Embracing concurrency for fun utility and simpler codekamaelian
 
Programming Languages For The Cloud
Programming Languages For The CloudProgramming Languages For The Cloud
Programming Languages For The CloudTed Leung
 
Getting Started with (Distributed) Version Control
Getting Started with (Distributed) Version ControlGetting Started with (Distributed) Version Control
Getting Started with (Distributed) Version ControlJohn Paulett
 
Mobile Web App Development
Mobile Web App DevelopmentMobile Web App Development
Mobile Web App DevelopmentBrian LeRoux
 
Cloudify your applications with Amazon Web Services
Cloudify your applications with Amazon Web ServicesCloudify your applications with Amazon Web Services
Cloudify your applications with Amazon Web ServicesFederico Feroldi
 

Semelhante a Browser, Mobile, Cloud, Social, Geo: Portrait of the developer as a kid in a candy store (20)

Google html5 Tutorial
Google html5 TutorialGoogle html5 Tutorial
Google html5 Tutorial
 
Html5
Html5Html5
Html5
 
Alejandro Villanueva - Google Inc.
Alejandro Villanueva - Google Inc.Alejandro Villanueva - Google Inc.
Alejandro Villanueva - Google Inc.
 
Google - Charla para CTOs
Google - Charla para CTOsGoogle - Charla para CTOs
Google - Charla para CTOs
 
Mozilla in Vietnam 2009
Mozilla in Vietnam 2009Mozilla in Vietnam 2009
Mozilla in Vietnam 2009
 
HTML5 and Google Chrome - DevFest09
HTML5 and Google Chrome - DevFest09HTML5 and Google Chrome - DevFest09
HTML5 and Google Chrome - DevFest09
 
Cloudera Desktop
Cloudera DesktopCloudera Desktop
Cloudera Desktop
 
Adobe Flex: Creating Widgets for the Desktop and Web
Adobe Flex: Creating Widgets for the Desktop and WebAdobe Flex: Creating Widgets for the Desktop and Web
Adobe Flex: Creating Widgets for the Desktop and Web
 
Mozilla In Malaysia
Mozilla In MalaysiaMozilla In Malaysia
Mozilla In Malaysia
 
CouchDB to the Edge ApacheCon EU
CouchDB to the  Edge ApacheCon EUCouchDB to the  Edge ApacheCon EU
CouchDB to the Edge ApacheCon EU
 
Vladimir Oane
Vladimir OaneVladimir Oane
Vladimir Oane
 
Caching, sharding, distributing - Scaling best practices
Caching, sharding, distributing - Scaling best practicesCaching, sharding, distributing - Scaling best practices
Caching, sharding, distributing - Scaling best practices
 
SAMT09 - Web of Data Tutorial - Part 2
SAMT09 - Web of Data Tutorial - Part 2SAMT09 - Web of Data Tutorial - Part 2
SAMT09 - Web of Data Tutorial - Part 2
 
Build HTML5 App (Intel Elements 2011)
Build HTML5 App (Intel Elements 2011)Build HTML5 App (Intel Elements 2011)
Build HTML5 App (Intel Elements 2011)
 
Elements2011 html5-app-110928141627-phpapp01
Elements2011 html5-app-110928141627-phpapp01Elements2011 html5-app-110928141627-phpapp01
Elements2011 html5-app-110928141627-phpapp01
 
Embracing concurrency for fun utility and simpler code
Embracing concurrency for fun utility and simpler codeEmbracing concurrency for fun utility and simpler code
Embracing concurrency for fun utility and simpler code
 
Programming Languages For The Cloud
Programming Languages For The CloudProgramming Languages For The Cloud
Programming Languages For The Cloud
 
Getting Started with (Distributed) Version Control
Getting Started with (Distributed) Version ControlGetting Started with (Distributed) Version Control
Getting Started with (Distributed) Version Control
 
Mobile Web App Development
Mobile Web App DevelopmentMobile Web App Development
Mobile Web App Development
 
Cloudify your applications with Amazon Web Services
Cloudify your applications with Amazon Web ServicesCloudify your applications with Amazon Web Services
Cloudify your applications with Amazon Web Services
 

Mais de Eze Torres

Clase up experiencia de usuario - ux - 2019
Clase up   experiencia de usuario - ux -  2019Clase up   experiencia de usuario - ux -  2019
Clase up experiencia de usuario - ux - 2019Eze Torres
 
Comunicación Interactiva 5 - Modelos de negocio - UP
Comunicación Interactiva 5 - Modelos de negocio - UPComunicación Interactiva 5 - Modelos de negocio - UP
Comunicación Interactiva 5 - Modelos de negocio - UPEze Torres
 
UP - Comunicación Interactiva V - SEO SEM - Ezequiel Torres
UP - Comunicación Interactiva V - SEO SEM - Ezequiel TorresUP - Comunicación Interactiva V - SEO SEM - Ezequiel Torres
UP - Comunicación Interactiva V - SEO SEM - Ezequiel TorresEze Torres
 
UP - Comunicación Interactiva V - Clase 8 - Reportes - Ezequiel Torres
UP - Comunicación Interactiva V - Clase 8 - Reportes - Ezequiel TorresUP - Comunicación Interactiva V - Clase 8 - Reportes - Ezequiel Torres
UP - Comunicación Interactiva V - Clase 8 - Reportes - Ezequiel TorresEze Torres
 
UP - Comunicacion Interactiva V - Clase 3 - Modelos de negocio - Ezequiel Tor...
UP - Comunicacion Interactiva V - Clase 3 - Modelos de negocio - Ezequiel Tor...UP - Comunicacion Interactiva V - Clase 3 - Modelos de negocio - Ezequiel Tor...
UP - Comunicacion Interactiva V - Clase 3 - Modelos de negocio - Ezequiel Tor...Eze Torres
 
UP - Comunicacion Interactiva V - Clase 3 - Modelos de negocio - Ezequiel Torres
UP - Comunicacion Interactiva V - Clase 3 - Modelos de negocio - Ezequiel TorresUP - Comunicacion Interactiva V - Clase 3 - Modelos de negocio - Ezequiel Torres
UP - Comunicacion Interactiva V - Clase 3 - Modelos de negocio - Ezequiel TorresEze Torres
 

Mais de Eze Torres (7)

Clase up experiencia de usuario - ux - 2019
Clase up   experiencia de usuario - ux -  2019Clase up   experiencia de usuario - ux -  2019
Clase up experiencia de usuario - ux - 2019
 
Comunicación Interactiva 5 - Modelos de negocio - UP
Comunicación Interactiva 5 - Modelos de negocio - UPComunicación Interactiva 5 - Modelos de negocio - UP
Comunicación Interactiva 5 - Modelos de negocio - UP
 
UP - Comunicación Interactiva V - SEO SEM - Ezequiel Torres
UP - Comunicación Interactiva V - SEO SEM - Ezequiel TorresUP - Comunicación Interactiva V - SEO SEM - Ezequiel Torres
UP - Comunicación Interactiva V - SEO SEM - Ezequiel Torres
 
UP - Comunicación Interactiva V - Clase 8 - Reportes - Ezequiel Torres
UP - Comunicación Interactiva V - Clase 8 - Reportes - Ezequiel TorresUP - Comunicación Interactiva V - Clase 8 - Reportes - Ezequiel Torres
UP - Comunicación Interactiva V - Clase 8 - Reportes - Ezequiel Torres
 
UP - Comunicacion Interactiva V - Clase 3 - Modelos de negocio - Ezequiel Tor...
UP - Comunicacion Interactiva V - Clase 3 - Modelos de negocio - Ezequiel Tor...UP - Comunicacion Interactiva V - Clase 3 - Modelos de negocio - Ezequiel Tor...
UP - Comunicacion Interactiva V - Clase 3 - Modelos de negocio - Ezequiel Tor...
 
UP - Comunicacion Interactiva V - Clase 3 - Modelos de negocio - Ezequiel Torres
UP - Comunicacion Interactiva V - Clase 3 - Modelos de negocio - Ezequiel TorresUP - Comunicacion Interactiva V - Clase 3 - Modelos de negocio - Ezequiel Torres
UP - Comunicacion Interactiva V - Clase 3 - Modelos de negocio - Ezequiel Torres
 
Greenpeace FB
Greenpeace FBGreenpeace FB
Greenpeace FB
 

Último

Moroccan Architecture presentation ( Omar & Yasine ).pptx
Moroccan Architecture presentation ( Omar & Yasine ).pptxMoroccan Architecture presentation ( Omar & Yasine ).pptx
Moroccan Architecture presentation ( Omar & Yasine ).pptxOmarOuazzani1
 
69 Girls ✠ 9599264170 ✠ Call Girls In East Of Kailash (VIP)
69 Girls ✠ 9599264170 ✠ Call Girls In East Of Kailash (VIP)69 Girls ✠ 9599264170 ✠ Call Girls In East Of Kailash (VIP)
69 Girls ✠ 9599264170 ✠ Call Girls In East Of Kailash (VIP)Escort Service
 
Where to Stay in Lagos, Portugal.pptxasd
Where to Stay in Lagos, Portugal.pptxasdWhere to Stay in Lagos, Portugal.pptxasd
Where to Stay in Lagos, Portugal.pptxasdusmanghaniwixpatriot
 
question 2: airplane vocabulary presentation
question 2: airplane vocabulary presentationquestion 2: airplane vocabulary presentation
question 2: airplane vocabulary presentationcaminantesdaauga
 
5S - House keeping (Seiri, Seiton, Seiso, Seiketsu, Shitsuke)
5S - House keeping (Seiri, Seiton, Seiso, Seiketsu, Shitsuke)5S - House keeping (Seiri, Seiton, Seiso, Seiketsu, Shitsuke)
5S - House keeping (Seiri, Seiton, Seiso, Seiketsu, Shitsuke)Mazie Garcia
 
Inspirational Quotes About Italy and Food
Inspirational Quotes About Italy and FoodInspirational Quotes About Italy and Food
Inspirational Quotes About Italy and FoodKasia Chojecki
 
8377087607 Full Enjoy @24/7 Call Girls in INA Market Dilli Hatt Delhi NCR
8377087607 Full Enjoy @24/7 Call Girls in INA Market Dilli Hatt Delhi NCR8377087607 Full Enjoy @24/7 Call Girls in INA Market Dilli Hatt Delhi NCR
8377087607 Full Enjoy @24/7 Call Girls in INA Market Dilli Hatt Delhi NCRdollysharma2066
 
Dubai Call Girls O528786472 Call Girls Dubai Big Juicy
Dubai Call Girls O528786472 Call Girls Dubai Big JuicyDubai Call Girls O528786472 Call Girls Dubai Big Juicy
Dubai Call Girls O528786472 Call Girls Dubai Big Juicyhf8803863
 
Italia Lucca 1 Un tesoro nascosto tra le sue mura
Italia Lucca 1 Un tesoro nascosto tra le sue muraItalia Lucca 1 Un tesoro nascosto tra le sue mura
Italia Lucca 1 Un tesoro nascosto tra le sue murasandamichaela *
 
How Safe Is It To Witness Whales In Maui’s Waters
How Safe Is It To Witness Whales In Maui’s WatersHow Safe Is It To Witness Whales In Maui’s Waters
How Safe Is It To Witness Whales In Maui’s WatersMakena Coast Charters
 
Authentic Travel Experience 2024 Greg DeShields.pptx
Authentic Travel Experience 2024 Greg DeShields.pptxAuthentic Travel Experience 2024 Greg DeShields.pptx
Authentic Travel Experience 2024 Greg DeShields.pptxGregory DeShields
 
"Fly with Ease: Booking Your Flights with Air Europa"
"Fly with Ease: Booking Your Flights with Air Europa""Fly with Ease: Booking Your Flights with Air Europa"
"Fly with Ease: Booking Your Flights with Air Europa"flyn goo
 
Haitian culture and stuff and places and food and travel.pptx
Haitian culture and stuff and places and food and travel.pptxHaitian culture and stuff and places and food and travel.pptx
Haitian culture and stuff and places and food and travel.pptxhxhlixia
 
Aeromexico Airlines Flight Name Change Policy
Aeromexico Airlines Flight Name Change PolicyAeromexico Airlines Flight Name Change Policy
Aeromexico Airlines Flight Name Change PolicyFlyFairTravels
 
(8264348440) 🔝 Call Girls In Nand Nagri 🔝 Delhi NCR
(8264348440) 🔝 Call Girls In Nand Nagri 🔝 Delhi NCR(8264348440) 🔝 Call Girls In Nand Nagri 🔝 Delhi NCR
(8264348440) 🔝 Call Girls In Nand Nagri 🔝 Delhi NCRsoniya singh
 
Revolutionalizing Travel: A VacAI Update
Revolutionalizing Travel: A VacAI UpdateRevolutionalizing Travel: A VacAI Update
Revolutionalizing Travel: A VacAI Updatejoymorrison10
 
Hoi An Ancient Town, Vietnam (越南 會安古鎮).ppsx
Hoi An Ancient Town, Vietnam (越南 會安古鎮).ppsxHoi An Ancient Town, Vietnam (越南 會安古鎮).ppsx
Hoi An Ancient Town, Vietnam (越南 會安古鎮).ppsxChung Yen Chang
 
Exploring Sicily Your Comprehensive Ebook Travel Guide
Exploring Sicily Your Comprehensive Ebook Travel GuideExploring Sicily Your Comprehensive Ebook Travel Guide
Exploring Sicily Your Comprehensive Ebook Travel GuideTime for Sicily
 

Último (20)

Moroccan Architecture presentation ( Omar & Yasine ).pptx
Moroccan Architecture presentation ( Omar & Yasine ).pptxMoroccan Architecture presentation ( Omar & Yasine ).pptx
Moroccan Architecture presentation ( Omar & Yasine ).pptx
 
69 Girls ✠ 9599264170 ✠ Call Girls In East Of Kailash (VIP)
69 Girls ✠ 9599264170 ✠ Call Girls In East Of Kailash (VIP)69 Girls ✠ 9599264170 ✠ Call Girls In East Of Kailash (VIP)
69 Girls ✠ 9599264170 ✠ Call Girls In East Of Kailash (VIP)
 
Where to Stay in Lagos, Portugal.pptxasd
Where to Stay in Lagos, Portugal.pptxasdWhere to Stay in Lagos, Portugal.pptxasd
Where to Stay in Lagos, Portugal.pptxasd
 
question 2: airplane vocabulary presentation
question 2: airplane vocabulary presentationquestion 2: airplane vocabulary presentation
question 2: airplane vocabulary presentation
 
5S - House keeping (Seiri, Seiton, Seiso, Seiketsu, Shitsuke)
5S - House keeping (Seiri, Seiton, Seiso, Seiketsu, Shitsuke)5S - House keeping (Seiri, Seiton, Seiso, Seiketsu, Shitsuke)
5S - House keeping (Seiri, Seiton, Seiso, Seiketsu, Shitsuke)
 
Inspirational Quotes About Italy and Food
Inspirational Quotes About Italy and FoodInspirational Quotes About Italy and Food
Inspirational Quotes About Italy and Food
 
Enjoy ➥8448380779▻ Call Girls In Sector 62 Noida Escorts Delhi NCR
Enjoy ➥8448380779▻ Call Girls In Sector 62 Noida Escorts Delhi NCREnjoy ➥8448380779▻ Call Girls In Sector 62 Noida Escorts Delhi NCR
Enjoy ➥8448380779▻ Call Girls In Sector 62 Noida Escorts Delhi NCR
 
8377087607 Full Enjoy @24/7 Call Girls in INA Market Dilli Hatt Delhi NCR
8377087607 Full Enjoy @24/7 Call Girls in INA Market Dilli Hatt Delhi NCR8377087607 Full Enjoy @24/7 Call Girls in INA Market Dilli Hatt Delhi NCR
8377087607 Full Enjoy @24/7 Call Girls in INA Market Dilli Hatt Delhi NCR
 
Dubai Call Girls O528786472 Call Girls Dubai Big Juicy
Dubai Call Girls O528786472 Call Girls Dubai Big JuicyDubai Call Girls O528786472 Call Girls Dubai Big Juicy
Dubai Call Girls O528786472 Call Girls Dubai Big Juicy
 
Italia Lucca 1 Un tesoro nascosto tra le sue mura
Italia Lucca 1 Un tesoro nascosto tra le sue muraItalia Lucca 1 Un tesoro nascosto tra le sue mura
Italia Lucca 1 Un tesoro nascosto tra le sue mura
 
How Safe Is It To Witness Whales In Maui’s Waters
How Safe Is It To Witness Whales In Maui’s WatersHow Safe Is It To Witness Whales In Maui’s Waters
How Safe Is It To Witness Whales In Maui’s Waters
 
Authentic Travel Experience 2024 Greg DeShields.pptx
Authentic Travel Experience 2024 Greg DeShields.pptxAuthentic Travel Experience 2024 Greg DeShields.pptx
Authentic Travel Experience 2024 Greg DeShields.pptx
 
"Fly with Ease: Booking Your Flights with Air Europa"
"Fly with Ease: Booking Your Flights with Air Europa""Fly with Ease: Booking Your Flights with Air Europa"
"Fly with Ease: Booking Your Flights with Air Europa"
 
Enjoy ➥8448380779▻ Call Girls In Sector 74 Noida Escorts Delhi NCR
Enjoy ➥8448380779▻ Call Girls In Sector 74 Noida Escorts Delhi NCREnjoy ➥8448380779▻ Call Girls In Sector 74 Noida Escorts Delhi NCR
Enjoy ➥8448380779▻ Call Girls In Sector 74 Noida Escorts Delhi NCR
 
Haitian culture and stuff and places and food and travel.pptx
Haitian culture and stuff and places and food and travel.pptxHaitian culture and stuff and places and food and travel.pptx
Haitian culture and stuff and places and food and travel.pptx
 
Aeromexico Airlines Flight Name Change Policy
Aeromexico Airlines Flight Name Change PolicyAeromexico Airlines Flight Name Change Policy
Aeromexico Airlines Flight Name Change Policy
 
(8264348440) 🔝 Call Girls In Nand Nagri 🔝 Delhi NCR
(8264348440) 🔝 Call Girls In Nand Nagri 🔝 Delhi NCR(8264348440) 🔝 Call Girls In Nand Nagri 🔝 Delhi NCR
(8264348440) 🔝 Call Girls In Nand Nagri 🔝 Delhi NCR
 
Revolutionalizing Travel: A VacAI Update
Revolutionalizing Travel: A VacAI UpdateRevolutionalizing Travel: A VacAI Update
Revolutionalizing Travel: A VacAI Update
 
Hoi An Ancient Town, Vietnam (越南 會安古鎮).ppsx
Hoi An Ancient Town, Vietnam (越南 會安古鎮).ppsxHoi An Ancient Town, Vietnam (越南 會安古鎮).ppsx
Hoi An Ancient Town, Vietnam (越南 會安古鎮).ppsx
 
Exploring Sicily Your Comprehensive Ebook Travel Guide
Exploring Sicily Your Comprehensive Ebook Travel GuideExploring Sicily Your Comprehensive Ebook Travel Guide
Exploring Sicily Your Comprehensive Ebook Travel Guide
 

Browser, Mobile, Cloud, Social, Geo: Portrait of the developer as a kid in a candy store

  • 2. Browser, Mobile, Cloud, Social, Geo Portrait of the developer as a kid in a candy store Patrick Chanezon Developer Advocate, Google http://twitter.com/chanezon November 17, 2009 Argentina #devfest09 Source Marshall Astor http://www.flickr.com/photos/lifeontheedge/711086777/sizes/l/#cc_license Wednesday, November 18, 2009
  • 3. Las calles de Buenos Aires ya son mi entraña “A mi se me hace cuento que empezo Buenos Aires: La juzgo tan eterna como el agua y el aire.” “Hard to believe Buenos Aires had any beginning. I feel it to be as eternal as air and water” Fervor de Buenos Aires (1923) Photo public domain http://commons.wikimedia.org/wiki/File:Jorge_Luis_Borges_Hotel.jpg Wednesday, November 18, 2009
  • 4. The Web Platform is Accelerating Chrome 2.0: May 21, 2009 canvas User Experience Firefox 3.5b4: video Apr 27, 2009 geolocation canvas app cache video database geolocation workers app cache Android 1.5: database Apr 13, 2009 workers canvas Opera Labs: geolocation Mar 26, 2009 app cache Safari 4.0b: canvas database Feb 29, 2009 video workers canvas XHR iPhone 2.2: video geolocation CSS Nov 22, 2008 app cache DOM canvas database app cache workers HTML database native web 1990 -- 2008 Q408 Q109 Q209 ... Wednesday, November 18, 2009
  • 5. And It’s Solving Key Developer Challenges Graphics Location Storage Speed User Experience XHR CSS DOM HTML native web 1990 -- 2008 Q408 Q109 Q209 ... Wednesday, November 18, 2009
  • 6. More Developers 300 chrome firefox 3.1+ Monthly Contributors to OSS Browsers firefox 2.0-3.0 webkit 225 150 75 0 2002 2003 2004 2005 2006 2007 2008 2009 Wednesday, November 18, 2009
  • 7. More Speed 80 SunSpider Runs Per Minute 60 100x improvement in JavaScript performance 40 20 0 2001 2003 2005 2007 Q108 Q208 Q308 Q408 Q109 Wednesday, November 18, 2009
  • 8. More Users 450 350 OSS Browser Users (M) 250 150 50 2005 2006 2007 2008 2009 Wednesday, November 18, 2009
  • 9. A More Powerful Web 5>2 Wednesday, November 18, 2009
  • 10. Cautionary Tales of Latent Lemonade AJAX (2004) xml (1998) css xhr (1996) (1999) Wednesday, November 18, 2009
  • 11. HTML 5: A Chance to Do Things Differently Wednesday, November 18, 2009
  • 12. canvas video geolocation app cache & web workers database Wednesday, November 18, 2009
  • 13. Until Recently, You Couldn’t Draw on the Web 0 0 X y x height Y width Wednesday, November 18, 2009
  • 14. And Graphics Weren’t Very Interactive javascript:onClick(Draw()); Wednesday, November 18, 2009
  • 15. The Usual Options Do This... Silverlight VML Flash Wednesday, November 18, 2009
  • 16. ... But canvas is Intrinsic to the Web Document Object Model (DOM) Specification Original: http://www.w3.org/TR/REC-DOM-Level-1/ Latest: http://www.w3.org/TR/DOM-Level-3-Core/ Contributors: Netscape, Sun, Microsoft, W3C, IBM, DOM Novell, JavaSoft, SoftQuad Inc., Inso EPS, Texcel Research, Arbortext Transparent Stack Hypertext Markup Language (HTML) Original: http://tools.ietf.org/html/rfc1866 Latest: http://www.w3.org/TR/html5/ HTML Contributors: T. Berners-Lee, D. Connolly, L. Masinter, MIT, W3C, AT&T, IBM, Microsoft, Netscape, Novell, SoftQuad, Spyglass, Adobe, Lotus, CWI, Reuters, JavaSoft, HP, GRIF, Sun, Opera, Mozilla, Google, Apple Hypertext Transfer Protocol (HTTP) Original: http://tools.ietf.org/html/rfc1945 Latest: http://tools.ietf.org/html/rfc2616 Contributors: UC Urvine, Compaq, MIT, Xerox, HTTP Microsoft, W3C, T. Berners-Lee, R. Fielding, J. Gettys, J. Mogul, H. Frystyk, L. Masinter, P. Leach Wednesday, November 18, 2009
  • 17. // canvas defines drawing and animation APIs with pixel- level control Wednesday, November 18, 2009
  • 19. canvas Piggybacks Overall Browser Speed SunSpider Runs Per Minute Wednesday, November 18, 2009
  • 20. Is the Web Ready for 3D? Wednesday, November 18, 2009
  • 21. Canvas3D, WebGL O3D code.google.com/apis/o3d Wednesday, November 18, 2009
  • 22. HTML 5 Support Chrome Firefox Safari Opera canvas video geolocation app cache database workers Wednesday, November 18, 2009
  • 23. canvas video geolocation app cache & web workers database Wednesday, November 18, 2009
  • 24. Video is Complicated, and Outside Your Control Wednesday, November 18, 2009
  • 25. So What Would Occam Do? © topatoco.com Wednesday, November 18, 2009
  • 26. // HTML 5 makes <video> as easy as <img> Wednesday, November 18, 2009
  • 28. HTML 5 Support Chrome Firefox Safari Opera canvas video geolocation app cache database workers Wednesday, November 18, 2009
  • 29. canvas video geolocation app cache & web workers database Wednesday, November 18, 2009
  • 30. Life’s Better with Location 2.8 mi Places Social Ads Games CRM Photos 2.1 mi 1.1 mi 500 ft 20 ft 75 ft Wednesday, November 18, 2009
  • 31. But GPS and IP Aren’t Good Enough 1. too slow 2. too constrained 3. too fuzzy Wednesday, November 18, 2009
  • 32. 1) Cell ID and WiFi Solve The Data Problem... Wednesday, November 18, 2009
  • 34. 2) ...And Browsers Are Now Location-Enabled Wednesday, November 18, 2009
  • 35. // the geolocation api brings browser- based location to your apps Wednesday, November 18, 2009
  • 37. HTML 5 Support Chrome Firefox Safari Opera canvas video geolocation (iPhone) app cache database workers Wednesday, November 18, 2009
  • 38. canvas video geolocation app cache & web workers database Wednesday, November 18, 2009
  • 39. Web Apps Need to Work Everywhere Wednesday, November 18, 2009
  • 40. // database and app cache store user data and app resources locally Wednesday, November 18, 2009
  • 41. app cache & database demos Wednesday, November 18, 2009
  • 43. index.html <title>Google Maps</title> Google Maps <script src="/usr/lib/mojo/framework/mojo.js" type="text/javascript" x-mojo-version="1"> </script> <script src="app/assistants/stage-assistant.js" type="text/javascript"></script> map-assistant.js this.controller.serviceRequest { 'palm://com.palm.location', { method: "getFix", parameters: {mode: "auto"}, onSuccess: this.goFix, onFailure: this.error } }; Wednesday, November 18, 2009
  • 44. webOS and HTML 5 • CSS Transformations • HTML 5 database for history & bookmarks • Canvas in calendar application • Extensions - Accelerometer - ... Wednesday, November 18, 2009
  • 45. webOS Accelerometer API • Shake: distinct start, stop with magnitude • Orientation • Raw acceleration - Individual acceleration per axis - Individual Pitch, Roll, and Yaw • ... all available from JavaScript using the DOM Level 2 interface Wednesday, November 18, 2009
  • 46. Code Snippet <script type="text/javascript"> // Set up accelerometer event handlers window.addEventListener( "shakestart", beginShaking, true ); window.addEventListener( "shaking", isShaking, true ); window.addEventListener( "shakeend", endShaking, true ); window.addEventListener( "acceleration", handleAccel, true ); function isShaking(event) { // event.magnitude // ... } function handleAccel(event) { // event.accelX, event.accelY, event.accelZ // event.pitch, event.roll, event.yaw // ... } </script> Wednesday, November 18, 2009
  • 47. webOS and HTML 5 Converge mobile and desktop web application development Wednesday, November 18, 2009
  • 48. HTML 5 Support Chrome Firefox Safari Opera canvas video geolocation (iPhone) app cache (mobile) database (mobile) workers Wednesday, November 18, 2009
  • 49. canvas video geolocation app cache & web workers database Wednesday, November 18, 2009
  • 50. A More Powerful Web == More Powerful Apps Wednesday, November 18, 2009
  • 51. But More Power == More Responsibility I will not hose the browser with JavaScript I will not hose the browser with JavaScript I will not hose the browser with JavaScript I will not hose the browser with JavaScript I will not hose the browser with JavaScript I will not hose the browser with JavaScript Wednesday, November 18, 2009
  • 52. // web workers defines an API for running background scripts Wednesday, November 18, 2009
  • 53. web workers demos Wednesday, November 18, 2009
  • 54. HTML5 Support Chrome Firefox Safari Opera canvas video geolocation (iPhone) app cache (mobile) database (mobile) workers (mobile) Wednesday, November 18, 2009
  • 55. HTML5 and SVG not available in IE? • ChromeFrame plugin implements HTML5 in IE • Shim libraries using Flash or VML to implement features – SVGWeb: SVG – Explorercanvas: Canvas – Video for Everybody: Video 55 Wednesday, November 18, 2009
  • 56. Chrome Extensions • Programs that enhance Google Chrome's functionality • Written in HTML, CSS, and JavaScript • Integrated using a simple API • Developed iteratively 56 Wednesday, November 18, 2009
  • 57. A More Powerful Web, Made Easier Wednesday, November 18, 2009
  • 58. Nubes “¿Qué son las nubes? ¿Una arquitectura del azar? Quizá Dios las necesita para la ejecución de Su infinita obra y son hilos de la trama oscura. Quizá la nube sea no menos vana que el hombre que la mira en la mañana.” “What are the clouds? An architecture of chance? Perhaps they are the necessary things from which God weaves his vast imaginings, threads of a web of infinite expanse. Maybe the cloud is emptiness returning, just like the man who watches it this morning.” Borges, Nubes II, Los Conjurados (1985) Wednesday, November 18, 2009
  • 59. App Engine and Google Web Toolkit (GWT) Easier to Scale and Optimize Your App Wednesday, November 18, 2009
  • 60. 200,000+ Developers Wednesday, November 18, 2009
  • 61. 80,000+ Applications 700 9:30am EST: WhiteHouse.gov Queries Per Second (QPS) Deadline for submissions 600 5:00pm EST: Link on Google homepage 500 11:30am EST: Townhall begins 400 Afternoon EST: NPR, NYTimes, CNN coverage 300 200 6:45pm EST: WhiteHouse.gov kick-off blog post 5:00pm EST: WhiteHouse.gov wrap-up blog post 100 0 18:00 21:00 24:00 3:00 6:00 9:00 12:00 15:00 18:00 21:00 24:00 3:00 6:00 9:00 12:00 15:00 18:00 21:00 24:00 3:00 Wednesday, November 18, 2009
  • 62. Launched in the Last 12 Months X memcache API X SSL support X system status X paid quota X cron support X database import X java runtime Wednesday, November 18, 2009
  • 63. Launched in the Last 2 Months X Background processing X XMPP X Incoming email X Datastore stats Wednesday, November 18, 2009
  • 64. • Large object store • Database export Wednesday, November 18, 2009
  • 66. Java + App Engine demo Wednesday, November 18, 2009
  • 67. UI in the Front... ...Hosting in the Back Wednesday, November 18, 2009
  • 68. GWT Browser-Proofs Your JavaScript Code... IE Firefo x S afari Chrome Wednesday, November 18, 2009
  • 69. ...But CSS Headaches Persist Wednesday, November 18, 2009
  • 70. Coming in GWT 2.0: In-Browser Debugging Wednesday, November 18, 2009
  • 71. Rich Applications, Extra-Large Codebases Wednesday, November 18, 2009
  • 73. Manual Code Splitting: Not For the Faint of Heart Wednesday, November 18, 2009
  • 74. Coming in GWT 2.0: runAsync() // example public void onMySettingsLinkClicked() { GWT.runAsync(new RunAsyncCallback() { public void onSuccess() { new MySettingsDialog().show(); } public void onFailure(Throwable ohNoes) { // indicate that something went wrong, // usually a connectivity or server problem } }); } Wednesday, November 18, 2009
  • 75. runAsync() Helps Apps Startup More Quickly 1500 1400 KB Size of Initial JavaScript Download (KB) 1125 750 7x Decrease In Initial Download Size with runAsync() 375 200 KB 0 26-Nov 29-Apr 18-Jun 28-Jul 12-Sep 27-Oct 24-Dec 16-Mar Wednesday, November 18, 2009
  • 76. code.google.com/appengine code.google.com/gwt Wednesday, November 18, 2009
  • 79. Large Reach Over 800M in a year – and more to come! Wednesday, November 18, 2009
  • 81. OpenSocial Supporting Products 27 Google Confidential Wednesday, November 18, 2009
  • 82. Under the hood: Usage Stats • 315M+ App Installs • 85M+ Canvas Page Views / Day • 7,500+ Apps • 20+ Containers Wednesday, November 18, 2009
  • 83. The Open Stack XRDS Wednesday, November 18, 2009
  • 84. Google Friend Connect Wednesday, November 18, 2009
  • 85. Google FriendConnect • Uses OpenSocial (gadgets, REST/RPC) • Allows site owners to mix in social data to existing sites • Cut and paste or • Deep integrations Wednesday, November 18, 2009
  • 86. Google Friend Connect Demos Wednesday, November 18, 2009
  • 87. TIME.com Daily Specials TIME.com’s Daily Specials provide a trusted and entertaining perspective on relevant current events. These interactive specials use photo and video galleries to engage the readers, and topics can range from important international events like the Pope visiting the Middle East) to light hearted topics like the Best iPhone Apps. Recent Popular Daily Specials Pageviews • top 10 disastrous letterman interviews - 7.4mm • top 11 iphone applications - 5.9mm •10 things you can like about $4 gas - 4.3mm •10 essential sites - 3.0mm Source: Omniture SiteCatalyst – Past 12 Months Wednesday, November 18, 2009
  • 88. Specials Traffic 176MM From January – April 2009 Wednesday, November 18, 2009
  • 89. Challenge How can we make our daily Top 10’s more fun and engaging? Wednesday, November 18, 2009
  • 91. TIME Social Lists Demo Wednesday, November 18, 2009
  • 92. Architecture Javascript APIs JSONP HTML + JavaScript Wednesday, November 18, 2009
  • 97. Google Product APIs Easier to Add Content and Services To Your Website Search Feeds Translation Calendar Video Comments News Maps Charts Contacts Spreadsheets Photos Documents Auth Wednesday, November 18, 2009
  • 98. Data Liberation Front http://www.dataliberation.org/ Users should be able to control the data they store in any of Google's products. Our team's goal is to make it easier to move data in and out. Wednesday, November 18, 2009
  • 99. Low-Level API Access Serves Many Needs... 5 4 Over 4B Google API Daily API Hits (B) Hits Every Day 3 2 1 May Jun Jul Aug Sept Oct Nov Dec Jan Feb Mar Apr May Wednesday, November 18, 2009
  • 100. ...But Imagine AdSense for Everything Else Search Spreadsheets Video Calendars Maps Wednesday, November 18, 2009
  • 101. Announcing: Google Web Elements Copy and Paste Website Content Wednesday, November 18, 2009
  • 102. Google Web Elements demo Wednesday, November 18, 2009
  • 104. Android: Seven Months, By The Numbers • 30+ carriers in 21 countries •18-20 devices by the end of 2009 • 12,000+ applications in the Android Market • 40+ app downloads per user • #2 in U.S. mobile web browsing • 4 platform releases, and counting... Wednesday, November 18, 2009
  • 106. Google Wave • Real time communication and collaboration platform • Rich set of APIs – Embedding – Gadgets – Robots – Extensions • Open Source protocol, Wave federation • Open Source server 104 Wednesday, November 18, 2009
  • 108. Go language • A systems programming language – expressive – concurrent – garbage-collected • New • Experimental • Fast • Safe • Concurrent • Open Source 106 Wednesday, November 18, 2009
  • 110. Enjoy the candies! http://twitter.com/chanezon Browser Mobile Cloud Social Geo Demos at http://delicious.com/chanezon/devfest09+demos Source Marshall Astor http://www.flickr.com/photos/lifeontheedge/711086777/sizes/l/#cc_license Wednesday, November 18, 2009