[BACK]Return to 05.5.Binding.c++ CVS log [TXT][DIR] Up to [Development] / inventor / apps / examples / Mentor / CXX

File: [Development] / inventor / apps / examples / Mentor / CXX / 05.5.Binding.c++ (download)

Revision 1.1, Thu Jul 17 22:12:37 2003 UTC (14 years, 3 months ago) by jlim
Branch: MAIN
CVS Tags: release-2_1_5-10, HEAD

Moved files from C++ directory.  Changed main() return type from void to int.

/*
 *
 *  Copyright (C) 2000 Silicon Graphics, Inc.  All Rights Reserved. 
 *
 *  This library is free software; you can redistribute it and/or
 *  modify it under the terms of the GNU Lesser General Public
 *  License as published by the Free Software Foundation; either
 *  version 2.1 of the License, or (at your option) any later version.
 *
 *  This library is distributed in the hope that it will be useful,
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 *  Lesser General Public License for more details.
 *
 *  Further, this software is distributed without any warranty that it is
 *  free of the rightful claim of any third person regarding infringement
 *  or the like.  Any license provided herein, whether implied or
 *  otherwise, applies only to this software file.  Patent licenses, if
 *  any, provided herein do not apply to combinations of this program with
 *  other software, or any other product whatsoever.
 * 
 *  You should have received a copy of the GNU Lesser General Public
 *  License along with this library; if not, write to the Free Software
 *  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 *
 *  Contact information: Silicon Graphics, Inc., 1600 Amphitheatre Pkwy,
 *  Mountain View, CA  94043, or:
 * 
 *  http://www.sgi.com 
 * 
 *  For further information regarding this notice, see: 
 * 
 *  http://oss.sgi.com/projects/GenInfo/NoticeExplan/
 *
 */

/*--------------------------------------------------------------
 *  This is an example from the Inventor Mentor,
 *  chapter 5, example 5.
 *
 *  This example illustrates a variety of ways to bind 
 *  materials to a polygon object.
 *  Three cases of a switch statement show various ways of 
 *  binding materials to objects.  
 *  The object used for all three examples is the stellated 
 *  dodecahedron from an earlier example in this chapter.  
 *------------------------------------------------------------*/ 

#include <stdlib.h>
#include <Inventor/Xt/SoXt.h>
#include <Inventor/Xt/viewers/SoXtExaminerViewer.h>
#include <Inventor/nodes/SoCoordinate3.h>
#include <Inventor/nodes/SoIndexedFaceSet.h>
#include <Inventor/nodes/SoMaterial.h>
#include <Inventor/nodes/SoMaterialBinding.h>
#include <Inventor/nodes/SoSeparator.h>

// Positions of all of the vertices:
static float vertexPositions[12][3] =
{
   { 0.0000,  1.2142,  0.7453},  // top

   { 0.0000,  1.2142, -0.7453},  // points surrounding top
   {-1.2142,  0.7453,  0.0000},
   {-0.7453,  0.0000,  1.2142}, 
   { 0.7453,  0.0000,  1.2142}, 
   { 1.2142,  0.7453,  0.0000},

   { 0.0000, -1.2142,  0.7453},  // points surrounding bottom
   {-1.2142, -0.7453,  0.0000}, 
   {-0.7453,  0.0000, -1.2142},
   { 0.7453,  0.0000, -1.2142}, 
   { 1.2142, -0.7453,  0.0000}, 

   { 0.0000, -1.2142, -0.7453}, // bottom
};

// Connectivity, information; 12 faces with 5 vertices each },
// (plus the end-of-face indicator for each face):

static int32_t indices[72] =
{
   1,  2,  3,  4, 5, SO_END_FACE_INDEX, // top face

   0,  1,  8,  7, 3, SO_END_FACE_INDEX, // 5 faces about top
   0,  2,  7,  6, 4, SO_END_FACE_INDEX,
   0,  3,  6, 10, 5, SO_END_FACE_INDEX,
   0,  4, 10,  9, 1, SO_END_FACE_INDEX,
   0,  5,  9,  8, 2, SO_END_FACE_INDEX, 

    9,  5, 4, 6, 11, SO_END_FACE_INDEX, // 5 faces about bottom
   10,  4, 3, 7, 11, SO_END_FACE_INDEX,
    6,  3, 2, 8, 11, SO_END_FACE_INDEX,
    7,  2, 1, 9, 11, SO_END_FACE_INDEX,
    8,  1, 5,10, 11, SO_END_FACE_INDEX,

    6,  7, 8, 9, 10, SO_END_FACE_INDEX, // bottom face
};
 
// Colors for the 12 faces
static float colors[12][3] =
{
   {1.0, .0, 0}, {.0,  .0, 1.0}, {0, .7,  .7}, { .0, 1.0,  0},
   { .7, .7, 0}, {.7,  .0,  .7}, {0, .0, 1.0}, { .7,  .0, .7},
   { .7, .7, 0}, {.0, 1.0,  .0}, {0, .7,  .7}, {1.0,  .0,  0}
};

// Routine to create a scene graph representing a dodecahedron
SoSeparator *
makeStellatedDodecahedron()
{
   SoSeparator *result = new SoSeparator;
   result->ref();

#ifdef IV_STRICT
   // This is the preferred code for Inventor 2.1 

   // Using the new SoVertexProperty node is more efficient
   SoVertexProperty *myVertexProperty = new SoVertexProperty;

   // The material binding.
   myVertexProperty->materialBinding = SoMaterialBinding::PER_FACE;

   // Define colors for the faces
   for (int i=0; i<12; i++)
     myVertexProperty->orderedRGBA.set1Value(i, SbColor(colors[i]).getPackedValue());

   // Define coordinates for vertices
   myVertexProperty->vertex.setValues(0, 12, vertexPositions);

    // Define the IndexedFaceSet, with indices into
   // the vertices:
   SoIndexedFaceSet *myFaceSet = new SoIndexedFaceSet;
   myFaceSet->coordIndex.setValues(0, 72, indices);

   myFaceSet->vertexProperty.setValue(myVertexProperty);
   result->addChild(myFaceSet);

#else
   // The material binding node.
   SoMaterialBinding *myBinding = new SoMaterialBinding;
   myBinding->value = SoMaterialBinding::PER_FACE;
   result->addChild(myBinding);

   // Define colors for the faces
   SoMaterial *myMaterials = new SoMaterial;
   myMaterials->diffuseColor.setValues(0, 12, colors);
   result->addChild(myMaterials);

   // Define coordinates for vertices
   SoCoordinate3 *myCoords = new SoCoordinate3;
   myCoords->point.setValues(0, 12, vertexPositions);
   result->addChild(myCoords);

    // Define the IndexedFaceSet, with indices into
   // the vertices:
   SoIndexedFaceSet *myFaceSet = new SoIndexedFaceSet;
   myFaceSet->coordIndex.setValues(0, 72, indices);
   result->addChild(myFaceSet);
#endif

   result->unrefNoDelete();
   return result;
}

int
main(int argc, char **argv)
{
   int whichBinding = 0;

   if (argc > 1) whichBinding = atoi(argv[1]);
   if (whichBinding > 2 || whichBinding < 0 || argc == 1) {
      fprintf(stderr, "Argument must be 0, 1, or 2\n");
      fprintf(stderr, "\t0 = PER_FACE\n");
      fprintf(stderr, "\t1 = PER_VERTEX_INDEXED\n");
      fprintf(stderr, "\t2 = PER_FACE_INDEXED\n");
      exit(1);
   }

   // Initialize Inventor and Xt
   Widget myWindow = SoXt::init(argv[0]);
   if (myWindow == NULL) exit(1);

   SoSeparator *root = makeStellatedDodecahedron();
   root->ref();

#ifdef IV_STRICT
   // Get the indexed face set for editing
   SoIndexedFaceSet *myIndexedFaceSet;
   myIndexedFaceSet = (SoIndexedFaceSet *) root->getChild(0);

   // Get the SoVertexProperty node for editing the material binding
   SoVertexProperty *myVertexProperty;
   myVertexProperty = (SoVertexProperty *) 
                           myIndexedFaceSet->vertexProperty.getValue();

//////////////////////////////////////////////////////////////
// CODE FOR The Inventor Mentor STARTS HERE (Inventor 2.1)

   // Which material to use to color the faces 
   // half red & half blue
   static int32_t materialIndices[12] = {
      0, 0, 0, 0, 0, 0,
      1, 1, 1, 1, 1, 1,
   };

   switch(whichBinding) {
     case 0:
       // Set up binding to use a different color for each face 
       myVertexProperty->materialBinding = SoMaterialBinding::PER_FACE;
       break;
     case 1:
       // Set up binding to use a different color at each 
       // vertex, BUT, vertices shared between faces will 
       // have the same color.
       myVertexProperty->materialBinding = SoMaterialBinding::PER_VERTEX_INDEXED;
       break;
     case 2:
       myVertexProperty->materialBinding = SoMaterialBinding::PER_FACE_INDEXED;
       myIndexedFaceSet->materialIndex.setValues(
                0, 12, materialIndices);
       break;
   }

// CODE FOR The Inventor Mentor ENDS HERE
//////////////////////////////////////////////////////////////

#else   // old style
   // Get the material binding node for editing
   SoMaterialBinding *myBinding;
   myBinding = (SoMaterialBinding *) root->getChild(0);

   // Get the indexed face set for editing
   SoIndexedFaceSet *myIndexedFaceSet;
   myIndexedFaceSet = (SoIndexedFaceSet *) root->getChild(3);

//////////////////////////////////////////////////////////////
// CODE FOR The Inventor Mentor STARTS HERE

   // Which material to use to color the faces 
   // half red & half blue
   static int32_t materialIndices[12] = {
      0, 0, 0, 0, 0, 0,
      1, 1, 1, 1, 1, 1,
   };

   switch(whichBinding) {
     case 0:
       // Set up binding to use a different color for each face 
       myBinding->value = SoMaterialBinding::PER_FACE;
       break;
     case 1:
       // Set up binding to use a different color at each 
       // vertex, BUT, vertices shared between faces will 
       // have the same color.
       myBinding->value = SoMaterialBinding::PER_VERTEX_INDEXED;
       break;
     case 2:
       myBinding->value = SoMaterialBinding::PER_FACE_INDEXED;
       myIndexedFaceSet->materialIndex.setValues(
                0, 12, materialIndices);
       break;
   }

// CODE FOR The Inventor Mentor ENDS HERE
//////////////////////////////////////////////////////////////
#endif


   SoXtExaminerViewer *myViewer = 
            new SoXtExaminerViewer(myWindow);
   myViewer->setSceneGraph(root);
   myViewer->setTitle("Material Bindings");
   myViewer->show();
   myViewer->viewAll();

   SoXt::show(myWindow);
   SoXt::mainLoop();
}