Lighthouse3d.com

uW(.JUMLO-O)ͭKLSW(L)ɰU7TWHL(3RRl bJP< Send me bugs and suggestions, please
VRML Script Tutorial
Full list

VRML Interactive Tutorial

Introduction
VRML File Structure
Drawing: Shape node
Geometry Nodes:
Box
Sphere
Cone
Cylinder
PointSet
IndexedLineSet
IndexedFaceSet
Extrusion
ElevationGrid
Example: Chessboard
Text
FontStyle
Appearance
Material
Textures
Image Texture
Movie Texture
Pixel Texture
Texture Coordinate
Texture Transform
Let there be Light
Directional Light
Point Light
Spot Light
Materials with Colored Lights
Hierarchical Node Structures
Group
Transform
Collision
Anchor
Billboard
Switch
Inlining Files
Defining and Instancing Nodes
Defining Levels of Detail
Events in VRML
Creating Paths between events: ROUTE
Generating Events based on Timers or User Actions
Timers
Touch Sensor
Visibility Sensor
Dragging Sensors
Plane Sensor
Sphere Sensor
Cylinder Sensor
Proximity Sensors
Example: Proximity sensor
Interpolators
Color
Coordinate
Normal
Orientation
Position
Scalar
Example
Let the Music Play
Sound
AudioClip
Bindable Nodes
Who Am I: NavigationInfo
Where Am I: ViewPoint
Adding Realism to the world
Background
Fog
Information about your world
WorldInfo
Definition for Auxiliary Nodes
Coordinate
Color
Normal

Z6y ];CƼ.YN%s*[Tlש-Ϭ "AcBёd<)Hu)n4ݛ0cյ~\׷B [튂OX(<~X1C]Kl:/e}ݝ8y6K9fԏu{jS[@O4t<^UմGiׯiZ¹[_Dk- Wf8{PF{F/*T  b ,n[tfQҖñA$xs1 y̧w2B1o5WzN{Ubߦ(avώ\C I5x)&gA{lJċ&cd12h@S=\7K(sRQ`EF@IN ~Ur]mohV(ƷyRL }|dJ!lvKO܁d,^M ’&^z!K0lɆB0I0;crUuq)gYЁTh+Qb$m%鬩,80Ds m2cc=3ϜG㠍E3u8! (IӗOxzVng_(uNIA.D7Q@x'b U'[\?I^{͵у28R~L|qXwSEN#zs;hf=g"^yKϷ@QT.EH?`nVv m?s! U٤0j-BH?6^Y",Ry0C)sg,k;WWļgQ`]F-E_߿o-;܅dygZmc 0P50j3P IAY:h>`O!!鷬,$A SDkJ2.):)JyP%4 N6 擗E''vKgks6xd* F#eNeu[wK .ŕgq/dL^ou\R] |ss]׬ IۀU[wL߫ZN =.";sPdVwmű:bd@^ܵ`$cQz!1'JhBvӛ#H;ׅTNi;Օ<4hd֧$HbբqAk?rDe9_gbxmd%KDC`ŢB4b0܏G|D c%e3(,IdGbGL2 !_B%73w VMf=/JXo+<廉?ѩrZ?~)H)>4f#N<[&p2\-$w{E>KX(Uv^xR.%tWZRmW k+R8^ ,$Y0IM,E`Ueh ֪ jkeZWW uEW fvsqycOrin1R704XX_W_"Uhr=D^(/L!!% e: w7榐"%m"͝G}<? |LR8B " P`VI])U2%$`n >Uхt+[x G6G&ɞ `XfS:;' 58XP>dRL*8`R0V܅LYncKj|F*i^ εTקOrJbt7L٦DBIYnmwC'(҂ qJ&ᵀ?^Q^nNv5@K mK6fu`iT̂*tfԬγx+k^~Wlkܼ~МAbSα7.95.~Z.7>9]yF|*.vˇvrX/ ᕗo~z;C 9 '3$@,]xz;uT=+gjUgu6t <*aˈS"N85.\sNUˇo^&;~'qߴ6]U\Gz~p쮸뫆our۸Jڗ]E0[pE5` .BY i ʃe&}s&{3ryOgK|jy:8 ?v5|,bg[L[aks=&՘(y=^MoΗD"ww %J#t$ `w,vr %Ж׾Bnm?DO8ZVi+OQ;tڗGc;SN[U۟zq2>;s^|gI 3~ggrrpw'm||˓})\o9lb$lVGdP#BϠ@+XT?VMLi㜋ÎqE@͘S!t~vmYFK{QMVse@y˅m_4bl|t^$Iצ7f*?kx ċ,kZwO Gм{&EEsu<UcN'IVwSuucj~:F5|<;/I}\(ΌoJQ$itꗅHG%R(,Ё2#uoGxgSQтxwYkwoT# ]Y:e_5i& a&KQ1Q <IJdG17<)!Eq,V#SE~",'ESR\?Nh>,"ˡT$oG11S"7uJtd'nj& ?rXϝsAseP:nsPC2 04[Jb,wA=d>nW0p=US[/_%g0_B^CMrr5FtE8lΠN8n!ga>hCͪG+~116 NGea`p,g"3( 0(xaW]jRrV!j%ϿMVN u0b.0IQ|QAqB ą- cMl)8gnGl0ӧˆ%ܻ{鑌]L.Âl*u+`Ls}XE.N/k-䨏G<.oܠ[Uf21ɴbB]B*+~.O3q럻ccMw_s lוc<= ЕFt1:?,H9Fj,lW)LPj6mkZj|u`qeh-Z'6b.?wo"\ձf1Q_`tHJGEl .'7d$1u74jj%ڴP.l:Iٟ1{mI^eQ^w^)q˷K Z 9Ӝ0Og>pf_s( 'W0Ϙ^~\Ͻ/F-L4f29.~Lۧ| 8+ه"˃f?w,`3$B7?F*쵘۳Xm{:/>kIIw Ùz׭QLSܵWG,}5"RdT$i~;V9fB{zbFA$gc'N,G{rxjE œw 4T 1T9䙿*ډ3cd6*)`9g?Ϟ6TJ U$1P![-r!{V̾IIh}$ܼF2uYTaCgnlHX̢}\u*bnrʴrx^w f>. ̢jWx3pgU,y+dDRNJFY(tƜLlM2I~<1(A|[g.jrVS|PzqOL XMiF D3t{gvB ,mVuL3pF4X]2 xL&ua;=щ[~"%^Z'R^L9w4= 7M~PZC`r_'[omEXSa ֹLPJu9XE j {J_Yw1G)gFkFP>ZK C6NJ˺L RfLӭh4B/OӜྐྵoDUҰLqh z:(\$Vϛp( 6Ew)>7p7.CiEvb0ٕO=Cz=RoƧNEi w$vaw'yfwz@rg:uU4D¢rċtsQ^_yl5&.,A|ptZ qS3YCaCc|_%+%L%n@%5PG^m{r*1 JHqP:dqo L 38It:!Ou`?/r, =h7<Qy[lCc҇SICCDz7= ֒>N-9ZIVb~dst%y~H<%:z5"f3vzb":f7ugIOL6(6ya{IN6*9)m>H2,zX ~#wRrc=*TKJλJ`HEߗp{=0PS1̳B"܂ (J!1`[=~̊H<ԥu.Hwyw5p k _(srm>njJnytjנX-l E&0QqP8/rvdK,%@.mqzU}:W[WmdSPLuqu"okaE8E6`$g"x,OUI$YI8wd[DKP$gh{gȋ IPl LIBDnx† . @J(^y0lJ@H(?6ߧ --ǹq: t 8ҵwpJ-Cmj4 T:Gb[$l/${5ڗ<*YglxH;_\egx]V.Ӗ65RC) xMҢK+ġ"DC'Ϗ`7;~:s;y;p6\:L^׋ݡ{NאxAA]"46D;ra Y>`~ ĺ^%Y6rV.&OE%CDRp-ՐCz-PVMZOQY) o{ E3\@fk<E s2E5[>u:u,2~<9ѹ٠>nQ+Vm%GILDg4С_RVkJyj~bҟJ2!֘ 4;Ա|{j{d(,W3:Gi h bp]Xp%#" =  Ħ$9H}^^mҙ&DM48 R$'w.0J!/GC1QR)fwP>0\5:Ƣ38Z^ LQ5\TB+RrWCrH2O&D!=X)qN2C^I>P).<T@s9pLTBP}zy֑/sW(%\}ٛPewc]T)<4S{Z&`BQ4Lu5yaG5Jp,4`ǖk=J=4c*^!aQKנ#w}8$ZYg4ѐZR%q6ڤk Б}LH\h-=Ft 4}6$aBDi]<)Nl|,Y3.[U Xk%#JϭwP5Y!ְb ѰMN^wmʳu#t^g±1\łqJ^)l NsA.ٛ+Yءl ԀaƯwfuoʦb:MPըޞ1Wm[YC>':ŵ[BWEDQ" 1NFwqm ,!8G/BqY֣E. -XOuܺ!Y#NW78c^j#=F?jШДD&UMDtM[M޺-Er/4並zo7v_5ЕDİYgN:[#dۜ5p;X|2Hi0oqq iÎzBi)6,;6/MQ}: m͞5[id9A}|#d;ݪ9UH>@7p7dA~b-o*E?nt!"TQfMnr{A3lY 8>nm57y-5-eEAC )c]EjUj, S  =غa%e=p=3"O28Z`E竷VdB㬗o3eN' E.QL jT9GT9٨xYhvWh|܍KVPJ>cvY_PxFϭ];XVC*,xZli_+CS ۯtMVUMu d;JP'}H6~'ÌT#\Vм%+mv[lO@M O‡Bv &6!ltH!&}4L/+' ,9P'Y%\?nhrg 9@#avG霽| ̗H[=zr2 }/}jOsJb\'?e;}4GS91؝M{v)39[}ܜZh^7%67sUJzn4X4S=jxmo=sJyR%munh^oS%~,UJ ^zIɿhD>}|}c"l!45d8_nZ"-`jl , ]\`]ŕpq'C q=>6i:>6dJ2n{wXg%|37p$1Tˋ͢ݸb-`'?8uA[٧Y\['{Hmr'w.a: RNh{蟊O9b]koFY~QD^8N>h],@ ņ"U{̐CR P$;CTʒlቀj(_?CS=R|LS@__4WIm]P!0/`"Δ"')or WOtK[L3x9}Q&Xl '("W5aݭCk;bݡed4MIW8VSQ9m&h:yq&#B$ߤ2و̒(J#e:qcK`v$Ib𥞂>kQjmRf§ $.rq!9ENOdK?>g +@+ "- C$8gөŮ~Z݈AAm7 04:_-QP˸ƵKinMکr,!CDOxK3)Rү'qgЏ>}[~ AG5UZ EjY3|:>X=ͽ7#@y]"\<4QwlImhoShRV*K_B$ҋpƝEpFeb6Lut22uƼ),Onw{=`BӪ ŽV'Q,=8?SG\󲰖A.)L_"4'Rac2.V`u[(F%IEUT.,`YBb3Z[zy* tz * LZz25P <Ûf'G۪Ge/K^%=4MsǮ2S5T"j0hˢkCב_cE]kDP, NyQ#0@DQ$77 mԝ*C,VFɖdf)kA_&tA㫽  W hUݲH}j%:;U~LTAS*Slc1hVQ.tBAz Qnu݌L&(n#s=EXzc NŃ{0v\ '`=!풪9uZ1WxlHk$e#M?Q&:@}mze֭qP_jS. PqZ\͙^ɮچߞj7ZT&)@YrIրz!+T,<m]a}ڇ_?HI1ڨ{:1ػЇ7/[R~ ثP;.<`>J02[qq)fI<"7_2BWFMuja쪶~?w|'ivI!IQd[xa6gÎ<'c_pk\Γ|[Bz ^*#S<|~q}qIL(~~W~/X)СQBל5͵C!w甛K-mf.0uq2>e~j;O!ÆGr2'px4}B"H-"9wK~Ä[vN'ѓhY AD2ȠFm^Ŕ'x_is}Ә?SAS]Y+yֈ_&nSp->ݝVo`8|;jN[V;d)l|?5gJK,z WÜZuL;NQ 4y}ũ<I}w 7

Anchor Node


If you're not familiar to grouping nodes in VRML see the section Creating Hierarchical Node Structures for general information on grouping.

The Anchor node lets you define a set of objects as a link to a url. When you click in one of the objects within an Anchor node the url will be fetched.

Anchor nodes can also be used to set a given Viewpoint. Examples will be provided bellow.

When the user has the mouse over an object contained in an Anchor node the url will be displayed.

The following fields are present:
  • children which contains all the nodes included in the group.
  • url specifies the url to be fetched or a Viewpoint to become active. You can specify multiple locations if you want to, the browser will look for data in those locations in decreasing order of preference.
  • parameter supplies additional information for the browser. For instance you can specify the target window where the url should be displayed.
  • description specifies a string which will replace the url information given to the user when the mouse is over an object contained within an Anchor.
  • bboxCenter specifies the center of a box that encloses the nodes in the group. The value for this field is a 3D point.
  • bboxSize specifies where the size of a box that encloses the nodes in the group. By default this field has a value of -1 -1 -1, which implies that no box is defined. The values for this field must be greater than or equal to zero. If the children nodes do not fit inside the box defined the results are undefined.
  • The latter two fields are optional. They can be used by the browser for optimization purposes.



    Syntax:
    Anchor {
    children [ ]
    url [ ]
    parameter
    description ""
    bboxCenter 0 0 0
    bboxSize -1 -1 -1
    }




    Example:
    Anchor {
    children [ Shape { geometry Sphere { } }]
    url "http://www.my_server.pt/my_world.wrl"
    description "My World"
    parameter ["target=my_frame" ]
    }


    In the above example when the mouse is over an object contained in the Anchor node a prompt will be displayed with the message "My World" (If description was absent the prompt would display the url specified). When the user clicks an object contained in the Anchor node the specified url is fetched and displayed in the frame named "my_frame".

    The next example shows an Anchor which is linked to a Viewpoint. When the mouse is over an object contained in the Anchor node a prompt will be displayed with the message "My Point of View". When the user clicks an object contained in the Anchor node the specified Viewpoint becomes active.

    Example:
    Anchor {
    children [ Shape { geometry Sphere { } } ]
    url #my_viewpoint
    description "My Point of View"
    }