Difference between revisions of "FSOSS 2010/processing.js/"

From CDOT Wiki
Jump to: navigation, search
Line 1: Line 1:
 
<h3>Game Development Using Processing.js</h3>
 
<h3>Game Development Using Processing.js</h3>
  
<b>Intro</b><br />
+
<b>Intro (me)</b><br />
 
<ul>
 
<ul>
 
   <li>Seneca college BSD student</li>
 
   <li>Seneca college BSD student</li>
 
   <li>Research assistant in CDOT</li>
 
   <li>Research assistant in CDOT</li>
 
   <li>Related projects: [http://www.c3dl.org C3DL] and [http://zenit.senecac.on.ca/wiki/index.php/XB_PointStream XB PointStream]</li>
 
   <li>Related projects: [http://www.c3dl.org C3DL] and [http://zenit.senecac.on.ca/wiki/index.php/XB_PointStream XB PointStream]</li>
 +
  <li>[http://asalga.wordpress.com Wordpress], [http://twitter.com/asalga Twitter]</li>
 
</ul>
 
</ul>
  
Line 46: Line 47:
 
<b>Coordinate system</b><br />
 
<b>Coordinate system</b><br />
 
<ul>
 
<ul>
  <li>size() sets canvas dimensions</li>
+
<li>size() sets canvas dimensions</li>
 
  <li> top-left corner [0, 0]</li>
 
  <li> top-left corner [0, 0]</li>
 
  <li> X increases right</li>
 
  <li> X increases right</li>

Revision as of 10:30, 27 October 2010

Game Development Using Processing.js

Intro (me)


Goals

  • Develop a simple 2D or 3D game using in Processing


Processing (aka P5) Processing.org

  • Open source data visualization language
  • Developed in Java
  • "Sketches" written using Java syntax
  • Requires a JVM plug-in
  • Uses the <object> tag
  • [code.google.com/p/processing/issues/list Bug tracking]


Processing.js (aka PJS) ProcessingJS.org

  • Open source JavaScript port of Processing
  • Started by John Resig
  • Many contributions by Seneca
  • Bug Tracking
  • Does not require a plug-in
  • Uses the <canvas> tag


Setting up Processing.js


Coordinate system

  • size() sets canvas dimensions
  • top-left corner [0, 0]
  • X increases right
  • Y increases downwards


Basiscs

1 - size, background, rect Example
2 - setup Example
3 - draw, noStroke, ellipse, fill, mousePressed Example
4 - line, stroke, strokeWeight Example
5 - ArrayList Example

Input

6 - mousePressed, mouseReleased, println Example
X  - keyPressed, keyCode, keyReleased Example

Transfomations

7 - transforms, triangle, rect, (point)
8 - more transforms
9 - 2D Vectors (dot, mult, etc.)
10 - class (?)
11 - type demo (text, textWidth)
12 - PImage, timing, random
13 - Particle System

3D

X - box Example
X - sphere, sphereDetail Example
X - Vertex
X - Texture Example

DOM Manipulation/Library Integration

DOM Interaction Example
Integration with jQueryUI - Example
Audio Example, Audio Data API Demos
Physics using Box2DJS - Al MacDonald's Demo, 0.1 PJS Crayon Physics
More demos! My PJS Web IDE (Visualizations, Spatial hierarchies, Image manipulation, Particle Systems!)
Games
3D Pong by bmidgley
Tower Defense by Will Larson and Peter Burns
Core by Andor Salga