Difference between revisions of "X3D and HTML5 examples"

From Web3D.org
Jump to: navigation, search
m
Line 99: Line 99:
 
* Set of negotiated <param> pairs: initialization and runtime.
 
* Set of negotiated <param> pairs: initialization and runtime.
  
 +
== X3D served as text/html ==
 +
 +
      &lt;!DOCTYPE html>
 +
      &lt;html>
 +
        &lt;head>
 +
          &lt;style type=text/css'>
 +
            X3D { height:100%;width:100%; }
 +
            svg { height:100%;width:100%; }
 +
          &lt;/style>
 +
        &lt;/head>
 +
        &lt;body>
 +
          &lt;X3D name='x3dBlock' type='model/x3d+xml'
 +
            version='3.3' profile='Interchange'
 +
            allow-same-origin allow-scripts>
 +
            &lt;Scene>
 +
              &lt;Viewpoint description='Start' />
 +
              &lt;Shape>
 +
                &lt;Box size="4 4 4" />
 +
              &lt;/Shape>
 +
              &lt;Shape>
 +
                &lt;Text string='"This is X3D Text"' />
 +
              &lt;/Shape>
 +
            &lt;/Scene>
 +
          &lt;/X3D>
 +
          &lt;svg type='image/svg+xml' version="1.1">
 +
            &lt;ellipse cx="2cm" cy="4cm" rx="2cm" ry="1cm" />
 +
          &lt;/svg>
 +
          &lt;mathml>
 +
            &lt;mrow>&lt;mi> x &lt;/mi>&lt;mo> + &lt;/mo>
 +
            &lt;mrow>&lt;mi> a &lt;/mi>&lt;mo> / &lt;/mo>&lt;mi> b &lt;/mi>
 +
            &lt;/mrow>&lt;/mrow>
 +
          &lt;/mathml>
 +
          &lt;ruby> WWW &lt;rt>World Wide Web&lt;/rt>
 +
          &lt;/ruby>
 +
        &lt;/body>
 +
      &lt;/html>
  
 
== X3D served as application/xhtml+xml ==
 
== X3D served as application/xhtml+xml ==
Line 127: Line 163:
 
       &lt;/html>
 
       &lt;/html>
  
 +
== X3D served as application/xhtml+xml : updates on the tree ==
  
== X3D served as text/html ==
+
      &lt;?xml version="1.0" encoding="utf-8" ?>
 
+
       &lt;!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
       &lt;!DOCTYPE html>
+
        "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
       &lt;html>
+
       &lt;html xmlns="http://www.w3.org/1999/xhtml">
 
         &lt;head>
 
         &lt;head>
 
           &lt;style type=text/css'>
 
           &lt;style type=text/css'>
             X3D { height:100%;width:100%; }
+
             x3d:X3D { height:200px;width:200px; }
            svg { height:100%;width:100%; }
+
 
           &lt;/style>
 
           &lt;/style>
 
         &lt;/head>
 
         &lt;/head>
 
         &lt;body>
 
         &lt;body>
           &lt;X3D name='x3dBlock' type='model/x3d+xml'  
+
           &lt;x3d:X3D name='x3dBlock'
             version='3.3' profile='Interchange'
+
             xmlns:x3d=
             allow-same-origin allow-scripts>
+
             "http://www.web3d.org/specifications/x3d-3.2.xsd">
 
             &lt;Scene>
 
             &lt;Scene>
              &lt;Viewpoint description='Start' />
 
 
               &lt;Shape>
 
               &lt;Shape>
 +
                &lt;Appearance>
 +
  &lt;Material diffuseColor="1 0 0" specularColor=".5 .5 .5" transparency="0" />
 +
&lt;/Appearance>
 
                 &lt;Box size="4 4 4" />
 
                 &lt;Box size="4 4 4" />
 
               &lt;/Shape>
 
               &lt;/Shape>
Line 150: Line 188:
 
                 &lt;Text string='"This is X3D Text"' />
 
                 &lt;Text string='"This is X3D Text"' />
 
               &lt;/Shape>
 
               &lt;/Shape>
            &lt;/Scene>
+
          &lt;/Scene>
          &lt;/X3D>
+
        &lt;/x3d:X3D>
          &lt;svg type='image/svg+xml' version="1.1">
+
 
            &lt;ellipse cx="2cm" cy="4cm" rx="2cm" ry="1cm" />
+
        &lt;script type="text/javascript"><![CDATA[
          &lt;/svg>
+
          &lt;mathml>
+
var solid = true;
            &lt;mrow>&lt;mi> x &lt;/mi>&lt;mo> + &lt;/mo>
+
            &lt;mrow>&lt;mi> a &lt;/mi>&lt;mo> / &lt;/mo>&lt;mi> b &lt;/mi>
+
function toggleRendering()
            &lt;/mrow>&lt;/mrow>
+
{
          &lt;/mathml>
+
var button = document.getElementById("points");
          &lt;ruby> WWW &lt;rt>World Wide Web&lt;/rt>
+
          &lt;/ruby>
+
solid = !solid;
        &lt;/body>
+
 +
if (solid)
 +
button.value = "Blue";
 +
else
 +
button.value = "Red";
 +
 +
var mat = document.getElementsByTagName("Material");
 +
var i = 0, n = mat.length;
 +
 +
var aMat = mat[0];
 +
aMat.setAttribute("diffuseColor", (!solid ? "0 0 1" : "1 0 0"));
 +
 +
return false;
 +
}
 +
 +
]]>&lt;/script>
 +
 +
<p class="case"> &nbsp;  
 +
Dynamic material update
 +
&lt;input type="button" id="points" value="Change Color" onclick="toggleRendering();" />
 +
&lt;/p>
 +
 +
      &lt;/body>
 
       &lt;/html>
 
       &lt;/html>

Revision as of 07:36, 30 October 2009

Here are examples that show different ways of combining HTML web pages and X3D scenes.

HelloWorld.x3d standalone scene

 <X3D profile='Immersive' version='3.2' 
   xmlns:xsd='http://www.w3.org/2001/XMLSchema-instance' 
   xsd:noNamespaceSchemaLocation=
  'http://www.web3d.org/specifications/x3d-3.2.xsd'>
   <head>
     <meta content='HelloWorld.x3d' name='title'/>
   </head>
   <Scene>
     <Group>
       <Viewpoint centerOfRotation='0 -1 0' 
         description='Hello world!' position='0 -1 7'/>
       <Transform rotation='0 1 0 3'>
         <Shape>
           <Sphere/>
           <Appearance>
             <Material diffuseColor='0 0.5 1'/>
             <ImageTexture url='"earth-topo.png"' />
           </Appearance>
         </Shape>
       </Transform>
       <Transform translation='0 -2 0'>
         <Shape>
           <Text solid='false' string='"Hello" "world!"'>
             <FontStyle justify='"MIDDLE" "MIDDLE"'/>
           </Text>
           <Appearance>
             <Material diffuseColor='0.1 0.5 1'/>
           </Appearance>
         </Shape>
       </Transform>
     </Group>
   </Scene>
 </X3D>


HelloWorld.x3d shows a simple standalone example (.html and .png)

X3D embedded in HTML page

HTML Object Tag for X3D shows how to place X3D objects within an HTML page

newHtmlPageWithX3dObject.html is an example HTML scene with X3D object tag to copy, edit and reuse.

<html>
 <body>
  <object data="http://www.web3d.org/x3d/content/examples/HelloWorld.x3d"
    type="model/x3d+xml" height="360" width="	
    <param name="src" value="http://www.web3d.org/x3d/content/examples/HelloWorld.x3d"/>
    <param name="DASHBOARD" value="FALSE"/>
    <param name="SPLASHSCREEN" value="
    <!-- the following anchor-link text is only displayed to user if no X3D plugin is already installed -->
    <div class="noX3dPluginInstalled">
      <a href="http://www.web3d.org/x3d/content/examples/X3dResources.html#Applications" target="helpPage"> 
      Select an X3D plugin to see this example...</a>
    </div>
  </object>
 </body>
</html>


HTML Anchor link to X3D document

HTML anchor links allow an HTML page to load the contents of an X3D scene.

HTML source:

      Here is my
      <a href='HelloWorld.x3d' title='Link to a new X3D document'>HelloWorld example</a> in X3D.

HTML result:

       Here is my HelloWorld example in X3D.

Typically Web browser responses to a user selecting the link:

  • Show X3D scene, if an X3D plugin is installed or native support for X3D is provided
  • If X3D file format is unrecognized, browser might save file or else provide the user a choice to launch an external application (such as an X3D viewer or editor)
  • Show source (if http server X3D MIME type settings are incorrect)


X3D embedded using object element

    <object name='x3dBlock' type='model/x3d+xml' 
      allow-same-origin allow-scripts>
      <param name='src' value='aScene.x3d'>
        <table>...</table>
    </object>
  • Opens nested browsing context in parent block element.
  • Fallback to html. (table in this case.)
  • Connections with DOM via event listeners (DOM<=>SAI).
  • Set of negotiated <param> pairs: initialization and runtime.

X3D served as text/html

      <!DOCTYPE html>
      <html>
        <head>
          <style type=text/css'>
            X3D { height:100%;width:100%; }
            svg { height:100%;width:100%; }
          </style>
        </head>
        <body>
          <X3D name='x3dBlock' type='model/x3d+xml' 
            version='3.3' profile='Interchange'
            allow-same-origin allow-scripts>
            <Scene>
              <Viewpoint description='Start' />
              <Shape>
                <Box size="4 4 4" />
              </Shape>
              <Shape>
                <Text string='"This is X3D Text"' />
              </Shape>
            </Scene>
          </X3D>
          <svg type='image/svg+xml' version="1.1">
            <ellipse cx="2cm" cy="4cm" rx="2cm" ry="1cm" />
          </svg>
          <mathml>
            <mrow><mi> x </mi><mo> + </mo>
            <mrow><mi> a </mi><mo> / </mo><mi> b </mi>
            </mrow></mrow>
          </mathml>
          <ruby> WWW <rt>World Wide Web</rt>
          </ruby>
        </body>
      </html>

X3D served as application/xhtml+xml

      <?xml version="1.0" encoding="utf-8" ?>
      <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" 
        "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
      <html xmlns="http://www.w3.org/1999/xhtml">
        <head>
          <style type=text/css'>
            x3d:X3D { height:200px;width:200px; }
          </style>
        </head>
        <body>
          <x3d:X3D name='x3dBlock'
            xmlns:x3d=
            "http://www.web3d.org/specifications/x3d-3.2.xsd">
            <Scene>
              <Shape>
                <Box size="4 4 4" />
              </Shape>
              <Shape>
                <Text string='"This is X3D Text"' />
              </Shape>
          </Scene>
        </x3d:X3D>
      </body>
      </html>

X3D served as application/xhtml+xml : updates on the tree

      <?xml version="1.0" encoding="utf-8" ?>
      <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" 
        "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
      <html xmlns="http://www.w3.org/1999/xhtml">
        <head>
          <style type=text/css'>
            x3d:X3D { height:200px;width:200px; }
          </style>
        </head>
        <body>
          <x3d:X3D name='x3dBlock'
            xmlns:x3d=
            "http://www.web3d.org/specifications/x3d-3.2.xsd">
            <Scene>
              <Shape>
                <Appearance>

<Material diffuseColor="1 0 0" specularColor=".5 .5 .5" transparency="0" /> </Appearance>

                <Box size="4 4 4" />
              </Shape>
              <Shape>
                <Text string='"This is X3D Text"' />
              </Shape>
          </Scene>
        </x3d:X3D>
       <script type="text/javascript"><![CDATA[

var solid = true;

function toggleRendering() { var button = document.getElementById("points");

solid = !solid;

if (solid) button.value = "Blue"; else button.value = "Red";

var mat = document.getElementsByTagName("Material"); var i = 0, n = mat.length;

var aMat = mat[0]; aMat.setAttribute("diffuseColor", (!solid ? "0 0 1" : "1 0 0"));

return false; }

]]></script>

  Dynamic material update <input type="button" id="points" value="Change Color" onclick="toggleRendering();" /> </p> </body> </html>