Changes

Jump to: navigation, search

Canvas3D JS Library

1,307 bytes added, 20:42, 26 January 2014
no edit summary
== Introduciton =={{Admon/obsolete}}
Under Construction== Introduction ==
The Canvas 3D JS Libary (C3DL) is a Javascript library that will make it easier to write 3D applications using WebGL. It provides a set of math, scene, and 3d object classes to make the canvas more accessible for developers that want to develop 3D content in browser. == People Working On This Project Contributors==
* Catherine Leung
* [[User:asalga | Andor Salga]]* Peter Callaghan* [[User:Pplam3 | Patrick Lam]] (Picking)* [[User:Jamesboston | James Boston]] (Garbage collection)* Mark Paruzel (CodeBot)
* Andrew Smith
* Chris Bishop
* Jeremy Giberson
* Joe Drew
* Matthew Postill
 
== Downloads ==
NOTE: these downloads are mostly meant for in-house testing and not really polished. It may also only work on a specific platform only. please read the note regarding the download.
<BR>
For the library, samples, and tutorials, go to [http://cswww.senecacc3dl.onorg/ c3DL.ca/~leung/canvas3d/canvas3d-0org]As of c3dl 2.0, our library uses WebGL.xpi Andrew's patch] - this change Any WebGL enabled browser will be able to view our content. To get a WebGL enabled browser see Tutorial 1 from our website and you do not need any addons. For all older versions of c3dl, you will need the canvas 3D addon available here:You can get the extension allows the "simple" examples from Vlad's page to work with ati cardshttps://addons.mozilla.org/en-US/firefox/addon/7171 (use suckmenot@mailinator. This is intended com/bugmenot for Windows onlyauthentication). Model viewer examples  NOTE: It is HIGHLY recommended that you do not work yetuse the older version of our library but to use version 2.0 or higher.
== Links ==
* [http://littlesvrwww.c3dl.org c3DL.org]* [http://github.com/cathyatseneca/c3dl GitHub Repo]* [svn://cdot.senecac.on.ca/canvas3dOld SVN Repo]* [http://en.wikipedia.org/wiki/C3DL Wikipedia page]  == Related Resources ==* [http://www.khronos.org/webgl/ Khronos WebGL]  == Documentation == Documentation can be found on our website: [http://www.c3dl.org/index.php/documentation/ c3DL.org].  == Ideas List == Here are the wishlist of things we want to be able to do with the library.... If you want something add it to the list. * 3D Asteroids - Good use of Collision detection, animation, particles, camera work, both mouse and keyboard controls. * Solar System Explorer - Pull the positions of our planets from some sort of webservice and display them, allowing users to see their relative alignment. * Simulation of 3D path finding * 3D graphs:* Display social networks and their relationships<br />:* Get earthquake Richter-scale values from a service and show graphs on a map<br />:* Display 3D graphs beside one another, gas prices along stock market values<br />:* 3D flowcharts<br /> * 3D Traceroute - graphical view of an IP's path across the internet. More details [http://www.c3dl.org/index.php/uncategorized/canvas3d-traceroute-idea/in this blogpost] * 3D Canvas Racing Demo - like [http:/ Our blog/www.tapper-ware.net/canvas3d/ this]but better, to show that it's both easier to use, more functionality is available, and runs much faster (hopefully)
== Prototype ==* Molecule Viewer - Rotate 3D molecules. Similar to [http://img126www.imageshackworldofmolecules.uscom/img1263D/3032/layoutqe4bcarotene_3d.jpg Canvas 3D API - Class Designhtm this]
== Math Operations ==* 3D Sudoku
=== Vector Class ===A Vector basically describes a direction in the form of X, Y, and Z coordinates of a * 3D world. Basic 3D math cannot exist without the utilization of spatial coordinates which the Vector Class encapsulates. The Vector Class will have the following members within it:Rubik's Cube
* Getters** getX() House Explorer/Designer - '''Retrieves Load a mesh of a room or a house and allow users to navigate through the X value'''** getY() - '''Retrieves the Y value'''** getZ() - '''Retrieves the Z value'''environment or design a room in a house.
* Setters** set(newX, newY, newZ) 3D Photo Album - '''This sets new (x, y, z) values Download images and create a 3D photo album similar to the Vector'''** setX(newX) - '''Takes a number value as the new value for X'''** setY(newY) - '''Takes a number value as the new value for Y'''** setZ(newZ) - '''Takes a number value as the new value for Z'''** setFromVector(vec) - '''Takes a Vector object as the new value for [http://www.mypictures3d.com/images/screenshots/art_gallery/art4.jpg this Vector'''].
* Calculations** normalize() Matrix - '''Unit Normalization'''** dot() - '''Calculates the Dot Product. Returns a number'''** length() - '''Returns the Length of Vector from (0Query search engines for sites, chat logs, 0blogs, 0)'''** lengthSq() - '''Returns the Squared value of Length'''** cross(vec) - '''Takes a Vector object etc. and computes display all the Cross Product between the two values. Returns text in a Vector object that is the cross of the two'''** add(vec) matrix- '''Takes a Vector object and adds its values to its own'''** subtract(vec) - '''Takes a Vector object and subtracts its values from its own'''** multiply(scalar) - '''Takes a number value and multiplies (x, y, z) by it'''** divide(scalar) - '''Takes a number value and divides (x, y, z) by it'''** isEqual(vec) - '''Takes a Vector object and compares it to its (x, y, z) values. Returns true if they match'''** multiplyByQuat(quat) - '''Takes a Quaternion and multiplies its orientation by (x, y, z)like fashion. It returns a new Vector orientation'''
=== Matrix Class ===A Matrix Class is necessary to provide Matrix operations such as rotation, translation* Really fancy animation of a bar graph, with columns growing and scaling to any point in the 3D worldarrow moving. It is composed of a 4x4 matrix of floating point values that can Will be applied to any Matrix operationan instant hit with business people. The Matrix Class has the following membersUsable as easy as [http://code.google.com/apis/chart/ google's toy][[Image:higherhigher.jpg]]
* void Identity() - '''Create Identity Matrix'''* void Transpose() - '''Transpose Generic model viewer application, with back/forward/index + zoom/rotate buttons that would download and display models from the web. Would have to be able to convert 3dsmax models in JS. So a Matrix'''* void Inverse() - '''Inverse Matrix Values'''* float Multiply(Matrix) - '''Multiplication by Scalar'''* float Divide(Matrix) - '''Division by Scalar'''* Matrix Add(Matrix) - '''Addition museum or such could just slap the app on the page and give it an array of two Matrices'''* Matrix Subtract(Matrix) - '''Subtraction of two Matrices'''* Vector Multiply(Vector) - '''Matrix times a Vector'''* Matrix Multiply(Matrix) - '''Matrix times a Matrix'''URLs for the stuff to show.
== Camera ==* Pong. Should be fairly easy, we just need to code the collision detection.
=== Pan Camera Class ====== Fixed Camera Class ====== Chase Camera Class ====== Free Camera Class ===* multi-player network air hockey. Supports up to 8 players. Create an arena based on number of players . Each wall has a hole and a paddle that players can move left and right. A ball is randomly sent flying and each time it goes through a hole, the player loses a point. Lose 10 points and that player is eliminated. Last person alive wins.
== World Objects ==* 2 Player Online Chess:* Orbit camera can be used to orbit around the board.<br />:* Effects can be used to change what material the pieces and board use such as metal, wood, etc.<br />:* Picking can be used to allow a simple interface to move the pieces. Either clicking on two tiles can move a piece or clicking on a piece and then a tile can move the piece.<br />:* Further research is needed to determine the best server-side language to use to share board state between players.<br />:* Animation can be achieved simply by setting velocities of pieces.<br />
=== Shape Class ====== Primitive Class ====== Model Class ===[[Category:Open Source Communities]]

Navigation menu