DOM manipulation by Wiimote/Gainer over HTTP
2008.05.15 @ YAPC::Asia 2008 Tokyo
Yusuke Kawasaki【川﨑有亮】
http://www.kawa.net/
Keyboard operation
- [→] next
- [←] prev
- [↑] index
This presentation uses "S6", great JavaScript based presentation tool, created by amachang.
One-click translation
Example: Welcome!
Powered by
Google AJAX Language API
Questions
Question #1
- Do you know XML?
<?xml version='1.0' encoding='UTF-8'?> <document> <foo>bar</foo> </document>
Question #2
- Do you know DOM?
var foo = document.getElementById('foo'); var bar = document.createElement('a'); foo.appendChild( bar );
Question #3
When you're developing an Ajax-based application,
- Do you like to manipulate XML documents with such DOM methods?
Question #4
- Do you like to play Nintendo Wii?
data:image/s3,"s3://crabby-images/a9f8a/a9f8a67979543136d5ba7f610abffaa2fb48a8bd" alt=""
Wii Remote is a device ONLY for the Wii game console?
Why don't you like to manipulate DOM like playing Wii?
TODAY'S AGENDA
- Demo: DOM manipulation
- Who am I?
- JavaScript animation
- Real device web service
- Wii Remote
- Gainer
§2
WHO AM I?
- Japanese
- Male
- JavaScript♥
- Perl♥
- Xiaolongbao♥
CPAN Author
XML::TreePP
XML manipulation without Wiimote.
use XML::TreePP; my $tpp = XML::TreePP->new(); my $url = "http://use.perl.org/index.rss"; my $tree = $tpp->parsehttp( GET => $url ); print $tree->{"rdf:RDF"}->{channel}->{title}, "\n"; print $tree->{"rdf:RDF"}->{channel}->{link}, "\n";
http://www.kawa.net/works/perl/treepp/treepp-e.html 2006.02.20
JKL.ParseXML
XML manipulation without Wiimote (again).
<script src="jkl-parsexml.js"></script> <script> var url = "zip.xml"; var http = new JKL.ParseXML( url ); var data = http.parse(); document.write( data.items.item.jpref ); // like E4X </script>
§3
JavaScript animation
Animation.Cube demo
Animation.Raster demo
JavaScript + Canvas Powered 3D Engine
data:image/s3,"s3://crabby-images/e5b13/e5b1383e105ecdf2ea8c7991b225da60918789b1" alt=""
under development.
http://www.kawa.net/works/js/wire3d/v2/wiimote3d.html 2008/03/17
wire3d.js
<script src="wire3d.js" type="text/javascript"></script> <script src="wire3d-wiimote.js" type="text/javascript"></script> <script type="text/javascript"> var wii = new Wire3D.Item.Wiimote(); wii.resize( 1.0, 1.0, 1.0 ); wii.rotate( 0.0, 0.3, -0.5 ); var space = new Wire3D.Space(); space.append( wii ); camera = new Wire3D.Camera( 'demo_here', space ); camera.display(); </script>
§4
Real device web service
Wiimote
Wiimote over HTTP
data:image/s3,"s3://crabby-images/ea934/ea9344555da1b7e5b3c3f11b89b8bb71fdcde5ba" alt=""
is a tech for manipulating Wiimotes through the Internet.
WoH's architecture
data:image/s3,"s3://crabby-images/7cc53/7cc535dbc0ed6d23bbb57c43f4160a53b2cc80d2" alt=""
MAX: 7 Wiimotes
data:image/s3,"s3://crabby-images/cd069/cd069dbddd765b3e80ffe8ddd8739d9e7fae08d6" alt=""
MAX: 7 Players
data:image/s3,"s3://crabby-images/b6cc4/b6cc4f64c8afaba23e6202a0df4ac205a2c2a93c" alt=""
Player number indicator
data:image/s3,"s3://crabby-images/089b4/089b4d1c581095625c7c3be305558c8db8c7a145" alt=""
Get the Wiimote over HTTP server right now!
http://code.google.com/p/wiimote-over-http/
- Java (not Perl :)
- Jetty embed HTTPd
- BLUECOVE 2.0.2
- WIDCOMM Driver
§5
Real device web service
Gainer
digital/analog x I/O x 4
data:image/s3,"s3://crabby-images/f8914/f8914eea0365136716dc8d52848dbf1abfdec5b9" alt=""
Device::Gainer module
use Device::Gainer; my $opt = { host => '192.168.1.xx' }; my $gainer = Device::Gainer->new( %$opt ); $gainer->on_pressed( sub { print "PRESSED\n"; } ); $gainer->on_released( sub { print "RELEASED\n"; } ); $gainer->turn_on_led(); $gainer->turn_off_led();
POE::Component::Server::HTTP
use POE qw( Component::Server::HTTP ); use HTTP::Request::AsCGI; use CGI; my $aliases = POE::Component::Server::HTTP->new( %$conf ); POE::Kernel->run(); sub handler { my ($req, $res) = @_; my $ascgi = HTTP::Request::AsCGI->new($req)->setup; my $cgi = CGI->new(); $res->content_type('text/plain'); $res->content('Hello, World!'); $res->code(RC_OK); return RC_OK; }
GoH's architecture
data:image/s3,"s3://crabby-images/8aacb/8aacbbee972d955eff14f7f4b5971b2339b158c9" alt=""
Over the Net means...
data:image/s3,"s3://crabby-images/55324/5532410e30813a720b9f8f93f00099bbac958c15" alt=""
§5
Extra
The JUI Conference
data:image/s3,"s3://crabby-images/63d9f/63d9f57aacda50e13a5db6bf7195713362403f02" alt=""
2008.05.19 18:30-
Next Monday @ Ginza, Tokyo
Acknowledgements
Thank you!
See you again in Chicago!
YAPC::NA 2008
2008.06.18 11:45 AM