[X3D-Public] jQuery plugin for working with x3dom scenes
cbullard at hiwaay.net
cbullard at hiwaay.net
Mon Jan 23 19:39:10 PST 2012
A planet system. Perfect.
I'm impressed with what you describe as architectural pieces. What
applications are you considering or is the intent for others to use
these in scene toolbox?
len
Quoting Sven-Erik Tiberg <Sven-Erik.Tiberg at ltu.se>:
> Hi Nathaniel
> Interesting.
> Have you looked into using your animation JQuery lib x3djq.js for
> h-anim animation?
>
> Note: Presently looking into JQuery to combine it with strophe.js to
> run XMPP for MultiUser x3d spaces.
>
> /Sven-Erik Tiberg
>
>
> From: x3d-public-bounces at web3d.org
> [mailto:x3d-public-bounces at web3d.org] On Behalf Of Nathaniel Gibson
> Sent: den 22 januari 2012 05:34
> To: X3D-Public at web3d.org
> Subject: [X3D-Public] jQuery plugin for working with x3dom scenes
>
> Hey everyone, I've been working on a plugin for jQuery which allows
> easy and chained building of an x3dom scene. I know that this is
> the x3d main newsgroup, so I apologize if this might be a little off
> topic since it's based on x3dom (a browser based standard for
> viewing x3d scenes)
>
> I have it up as a project on GitHub right now... My basic goal is
> to make it so that anyone can build an x3d scene almost like they
> build new X3DOM elements and animate in jQuery. I was really
> impressed with what I've seen so far on the x3dom front, so I'm
> trying to make it more accessible for the common web programmer
> (without having to learn rotation matrices, do a lot of
> trigonometry, etc.)
>
> Besides that, I am a web developer who doesn't really like to write
> so many < and > tags, so for me it just makes sense and is way more
> efficient. Here's some of the features I already have implemented
> (some are buggy yet)...
>
> * A 3D cursor (invisible) for each parent DOM object so that if
> you create children of that object, you can control where the offset
> is.
> * Quick and simple animations which add the "ROUTE" tags that
> are necessary for routing PositionInterpolator, RotationInterpolator
> and Scalar interpolations.
> * Ability to send movements and rotations, etc. as an array of data
> * Rotation can be either expressed in [x, y, z, w] with radians
> (normal way), and likewise can be expressed in simply [x, y, z]
> using degrees (i.e: [180, 0, 0]) where javascript handles the
> conversion matrices, etc.
> * Full jQuery chainability for rapid development purposes.
> * A "container" transform which is just an empty transform (a
> very clean way to load parts of the scene using jQuery's "load"
> method [ajax])
> * Many other features: notes taken in the x3djq.js file for all
> the different functions
> Here's some example code for instance of building a solar system
> using the x3dom jQuery plugin. It sets up all 9 planets, (yes, I
> classify pluto as a planet [old habit],) then sets up viewpoints for
> each planet as well as orbits for those planets.
>
> //solar system setup
> $('scene').empty().x3d('setcursor',[0,0,0]).x3d('container','system').x3d('view','systemview',[0,0,30],[0,0,0],.5);
>
> //Set up planets and sun's orbit containers and fill them with
> planets and info, then start rotation
> $('#system').x3d('container','sun_orbit').x3d('container','mercury_orbit').x3d('container','venus_orbit').x3d('container','earth_orbit').x3d('container','mars_orbit').x3d('container','jupiter_orbit').x3d('container','saturn_orbit').x3d('container','uranus_orbit').x3d('container','neptune_orbit').x3d('container','pluto_orbit');
> $('#sun_orbit').x3d('sphere','sun',{radius: 5});
> $('#mercury_orbit').x3d('setcursor',[5.5,0,0]).x3d('sphere','mercury',
> {radius:
> .05}).x3d('setcursor',[5.6,1,0]).x3d('text','mercurytitle','Mercury',{size:
> 20}).x3d('view','mercuryview',[7,0,0],[0,90,0],.5).x3d('rotate',[[0,180,0],[0,360,0]],2.4,true);
> $('#venus_orbit').x3d('setcursor',[6,0,0]).x3d('sphere','venus',
> {radius:
> .15}).x3d('setcursor',[6.2,1,0]).x3d('text','venustitle','Venus',{size:
> 20}).x3d('view','venusview',[8,0,0],[0,90,0],.5).x3d('rotate',[[0,180,0],[0,360,0]],6.13,true);
> $('#earth_orbit').x3d('setcursor',[6.5,0,0]).x3d('sphere','earth',
> {radius:
> .152}).x3d('setcursor',[6.8,0.8,0]).x3d('text','earthtitle','Earth',{size:
> 20}).x3d('view','earthview',[9,0,0],[0,90,0],.5).x3d('rotate',[[0,180,0],[0,360,0]],10,true);
> $('#mars_orbit').x3d('setcursor',[7,0,0]).x3d('sphere','mars',{radius:
> .075}).x3d('setcursor',[7.3,0.5,0]).x3d('text','marstitle','Mars',{size:
> 20}).x3d('view','marsview',[10,0,0],[0,90,0],.5).x3d('rotate',[[0,180,0],[0,360,0]],18.82,true);
> $('#jupiter_orbit').x3d('setcursor',[9.5,0,0]).x3d('sphere','jupiter',{radius: 1.6}).x3d('setcursor',[12,1,0]).x3d('text','jupitertitle','Jupiter',{size:
> 20}).x3d('view','jupiterview',[15,0,0],[0,90,0],.5).x3d('rotate',[[0,180,0],[0,360,0]],118.618,true);
> $('#saturn_orbit').x3d('setcursor',[13,0,0]).x3d('sphere','saturn',{radius:
> 1.5}).x3d('setcursor',[14.5,1,0]).x3d('text','saturntitle','Saturn',{size:
> 20}).x3d('view','saturnview',[16,0,0],[0,90,0],.5).x3d('rotate',[[0,180,0],[0,360,0]],294.571,true);
> $('#uranus_orbit').x3d('setcursor',[15.5,0,0]).x3d('sphere','uranus',{radius: .6375}).x3d('setcursor',[16.5,1,0]).x3d('text','uranustitle','Uranus',{size:
> 20}).x3d('view','uranusview',[18,0,0],[0,90,0],.5).x3d('rotate',[[0,180,0],[0,360,0]],843.233,true);
> $('#neptune_orbit').x3d('setcursor',[18,0,0]).x3d('sphere','neptune',{radius: .6}).x3d('setcursor',[18.8,1,0]).x3d('text','neptunetitle','Neptune',{size:
> 20}).x3d('view','neptuneview',[20,0,0],[0,90,0],.5).x3d('rotate',[[0,180,0],[0,360,0]],1647.9,true);
> $('#pluto_orbit').x3d('setcursor',[19.5,0,0]).x3d('sphere','pluto',{radius:
> .02}).x3d('setcursor',[20,0,0]).x3d('text','plutotitle','Pluto',{size:
> 20}).x3d('view','plutoview',[21,0,0],[0,90,0],.5).x3d('rotate',[[0,180,0],[0,360,0]],2481,true);
>
> //Set up planet group (planet, moons, views, text)
> $('#mercury').x3d('setmaterial',{ texture: 'solarsys/Mercury.jpg'});
>
> $('scene').x3d('changeview','systemview');
>
> If you were to link x3djq.js in your document and put this script in
> as well, you can see the example. I've also put up a temporary
> working example on my site at:
> http://webdombot.com/mediaSpydr/solarsystem.html ... taking a look
> at the DOM through firebug, etc. you will find that creating the
> scene through this plugin has reduced the number of characters I had
> to type in my x3dom scene to about 15% of what it would be if I had
> to write all of those html tags (3,000 some characters compared to
> 19,000+ characters). Besides that, as a developer I wouldn't have
> to teach myself all about routing, etc. concepts just to build
> animations.
>
> There is a list of things yet to be done on the GitHub project so
> that others can take a look at what's working and not.
>
> I could really use some community support on this. Anyone who knows
> jQuery and is willing to pitch in please do. Let's make x3dom a web
> standard and get people building 3d websites!
>
> The GitHub project is located at:
> https://github.com/newsbubbles/x3dom-jQuery-Plugin
>
> I'm working on the animation system and texturing at the moment. My
> overall goal is to have an animation object which allows for simple
> or advanced position/scale/rotation animation, and there's a lot
> more to come.
>
> I welcome anyone who's interested in joining the project.
>
> Nathaniel
>
More information about the X3D-Public
mailing list