33#ifndef DART_GUI_OSG_RENDER_HEIGHTMAPSHAPENODE_HPP_ 
   34#define DART_GUI_OSG_RENDER_HEIGHTMAPSHAPENODE_HPP_ 
   36#include "dart/config.hpp" 
   38#include <osg/CullFace> 
   40#include <osg/Geometry> 
   42#include <osg/Material> 
   43#include <osg/MatrixTransform> 
   44#include <osg/ShapeDrawable> 
   57class HeightmapShapeGeode;
 
   87  using osgVec3 = 
typename std::conditional<
 
   88      std::is_same<S, float>::value,
 
   92      std::is_same<S, float>::value,
 
   96      std::is_same<S, float>::value,
 
 
  147    mHeightmapShape(shape),
 
  149    mHeightmapVersion(dynamics::INVALID_INDEX)
 
 
  161  setNodeMask(mVisualAspect->isHidden() ? 0x0u : ~0x0u);
 
  164      && mHeightmapVersion == mHeightmapShape->getVersion())
 
  169  mHeightmapVersion = mHeightmapShape->getVersion();
 
 
  176  if (
nullptr == mGeode)
 
  179        mHeightmapShape.get(), mParentShapeFrameNode, 
this);
 
 
 
  200  : 
ShapeNode(parentNode->getShape(), parentShapeFrame, this),
 
  201    mParentNode(parentNode),
 
  202    mHeightmapShape(shape),
 
  205  getOrCreateStateSet()->setMode(GL_BLEND, ::osg::StateAttribute::ON);
 
  206  getOrCreateStateSet()->setRenderingHint(::osg::StateSet::TRANSPARENT_BIN);
 
  207  getOrCreateStateSet()->setAttributeAndModes(
 
  208      new ::osg::CullFace(::osg::CullFace::BACK));
 
  209  getOrCreateStateSet()->setMode(GL_LIGHTING, ::osg::StateAttribute::ON);
 
 
  226  if (
nullptr == mDrawable)
 
  230    addDrawable(mDrawable);
 
  234  mDrawable->refresh(
false);
 
 
  253      std::is_same<S, float>::value || std::is_same<S, double>::value,
 
  254      "Scalar type should be float or double");
 
  260      !std::is_same<S, double>::value,
 
  261      "OpenSceneGraph currently doesn't support double precision for " 
  268  mElements = new ::osg::DrawElementsUInt(::osg::PrimitiveSet::TRIANGLES);
 
 
  276    const Eigen::Matrix<S, 3, 1>& p1,
 
  277    const Eigen::Matrix<S, 3, 1>& p2,
 
  278    const Eigen::Matrix<S, 3, 1>& p3)
 
  280  return (p2 - p1).cross(p3 - p1).normalized();
 
 
  285    const ::osg::Vec3f& p1, const ::osg::Vec3f& p2, const ::osg::Vec3f& p3)
 
  287  auto normal = (p2 - p1) ^ (p3 - p1);
 
 
  294    const ::osg::Vec3d& p1, const ::osg::Vec3d& p2, const ::osg::Vec3d& p3)
 
  296  auto normal = (p2 - p1) ^ (p3 - p1);
 
 
  306    ::osg::DrawElementsUInt& faces,
 
  312  const auto rows = heightmap.rows();
 
  313  const auto cols = heightmap.cols();
 
  317  if (rows < 2 || cols < 2)
 
  323  vertices.resize(
static_cast<std::size_t
>(heightmap.size()));
 
  327  for (
auto i = 0; i < rows; ++i)
 
  329    for (
auto j = 0; j < cols; ++j)
 
  331      const auto index = cols * i + j;
 
  333          j * scale.x(), -(i * scale.y()), heightmap(i, j) * scale.z());
 
  363  faces.reserve(6 * (rows - 1) * (cols - 1));
 
  364  for (
auto i = 1; i < rows; ++i)
 
  366    for (
auto j = 1; j < cols; ++j)
 
  369      const auto p1i = i - 1;
 
  370      const auto p1j = j - 1;
 
  372      const auto p2i = i - 1;
 
  376      const auto p3j = j - 1;
 
  379      const auto p1 = p1i * cols + p1j;
 
  380      const auto p2 = p2i * cols + p2j;
 
  381      const auto p3 = p3i * cols + p3j;
 
  382      const auto curr = i * cols + j;
 
  392      faces.push_back(curr);
 
  396  normals.reserve(heightmap.size());
 
  397  for (
auto i = 0; i < rows; ++i)
 
  399    for (
auto j = 0; j < cols; ++j)
 
  402      const auto p2i = i - 1;
 
  406      const auto p3j = j - 1;
 
  409      const auto p4j = j + 1;
 
  411      const auto p5i = i + 1;
 
  415      const auto p2 = p2i * cols + p2j;
 
  416      const auto p3 = p3i * cols + p3j;
 
  417      const auto p4 = p4i * cols + p4j;
 
  418      const auto p5 = p5i * cols + p5j;
 
  419      const auto curr = i * cols + j;
 
  421      const auto& ptCurr = vertices[curr];
 
  426        sum += 
getNormal(ptCurr, vertices[p2], vertices[p3]);
 
  428      if (i + 1 < rows && j > 0)
 
  429        sum += 
getNormal(ptCurr, vertices[p3], vertices[p5]);
 
  431      if (i + 1 < rows && j + 1 < cols)
 
  432        sum += 
getNormal(ptCurr, vertices[p5], vertices[p4]);
 
  434      if (i > 0 && j + 1 < cols)
 
  435        sum += 
getNormal(ptCurr, vertices[p4], vertices[p2]);
 
  439      normals.push_back(sum);
 
 
  449    setDataVariance(::osg::Object::STATIC);
 
  451    setDataVariance(::osg::Object::DYNAMIC);
 
  455  const auto& 
heightmap = mHeightmapShape->getHeightField();
 
  468        mHeightmapShape->getScale());
 
  479    if (mColors->size() != 1)
 
 
 
 
 
 
std::string type
Definition SdfParser.cpp:82
std::size_t index
Definition SkelParser.cpp:1672
Shape for a height map.
Definition HeightmapShape.hpp:47
Eigen::Matrix< S, Eigen::Dynamic, Eigen::Dynamic, Eigen::RowMajor > HeightField
Definition HeightmapShape.hpp:53
@ STATIC
Definition Shape.hpp:83
Definition ShapeFrame.hpp:54
bool isHidden() const
True iff the ShapeNode is set to be hidden.
Definition ShapeFrame.cpp:177
Definition ShapeFrameNode.hpp:61
Definition HeightmapShapeNode.hpp:83
Eigen::Matrix< S, 3, 1 > Vector3
Definition HeightmapShapeNode.hpp:85
~HeightmapShapeDrawable() override=default
typename std::conditional< std::is_same< S, float >::value, ::osg::Vec3f, ::osg::Vec3d >::type osgVec3
Definition HeightmapShapeNode.hpp:90
void refresh(bool firstTime)
Definition HeightmapShapeNode.hpp:446
dynamics::VisualAspect * mVisualAspect
Definition HeightmapShapeNode.hpp:111
HeightmapShapeGeode< S > * mParent
Definition HeightmapShapeNode.hpp:112
typename std::conditional< std::is_same< S, float >::value, ::osg::Vec4Array, ::osg::Vec4dArray >::type Vec4Array
Definition HeightmapShapeNode.hpp:98
dynamics::HeightmapShape< S > * mHeightmapShape
Definition HeightmapShapeNode.hpp:110
::osg::ref_ptr<::osg::DrawElementsUInt > mElements
Definition HeightmapShapeNode.hpp:116
::osg::ref_ptr< Vec3Array > mNormals
Definition HeightmapShapeNode.hpp:117
::osg::ref_ptr<::osg::Vec4Array > mColors
Definition HeightmapShapeNode.hpp:118
HeightmapShapeDrawable(dynamics::HeightmapShape< S > *shape, dynamics::VisualAspect *visualAspect, HeightmapShapeGeode< S > *parent)
Definition HeightmapShapeNode.hpp:246
typename std::conditional< std::is_same< S, float >::value, ::osg::Vec3Array, ::osg::Vec3dArray >::type Vec3Array
Definition HeightmapShapeNode.hpp:94
::osg::ref_ptr< Vec3Array > mVertices
Definition HeightmapShapeNode.hpp:115
Definition HeightmapShapeNode.hpp:124
dynamics::HeightmapShape< S > * mHeightmapShape
Definition HeightmapShapeNode.hpp:138
HeightmapShapeDrawable< S > * mDrawable
Definition HeightmapShapeNode.hpp:139
void refresh()
Update all rendering data for this ShapeNode.
Definition HeightmapShapeNode.hpp:215
void extractData()
Definition HeightmapShapeNode.hpp:224
virtual ~HeightmapShapeGeode()
Definition HeightmapShapeNode.hpp:239
HeightmapShapeNode< S > * mParentNode
Definition HeightmapShapeNode.hpp:137
HeightmapShapeGeode(dynamics::HeightmapShape< S > *shape, ShapeFrameNode *parentShapeFrame, HeightmapShapeNode< S > *parentNode)
Definition HeightmapShapeNode.hpp:196
Definition HeightmapShapeNode.hpp:61
HeightmapShapeNode(std::shared_ptr< dynamics::HeightmapShape< S > > shape, ShapeFrameNode *parent)
Definition HeightmapShapeNode.hpp:144
void extractData(bool firstTime)
Definition HeightmapShapeNode.hpp:174
S_ S
Definition HeightmapShapeNode.hpp:63
std::shared_ptr< dynamics::HeightmapShape< S > > mHeightmapShape
Definition HeightmapShapeNode.hpp:75
virtual ~HeightmapShapeNode() override
Definition HeightmapShapeNode.hpp:189
HeightmapShapeGeode< S > * mGeode
Definition HeightmapShapeNode.hpp:76
void refresh() override
Update all rendering data for this ShapeNode.
Definition HeightmapShapeNode.hpp:157
std::size_t mHeightmapVersion
Definition HeightmapShapeNode.hpp:77
Definition ShapeNode.hpp:59
dart::dynamics::VisualAspect * mVisualAspect
Pointer to the VisualAspect associated with this ShapeNode.
Definition ShapeNode.hpp:106
::osg::Vec4d eigToOsgVec4d(const Eigen::MatrixBase< Derived > &vec)
Definition Utils.hpp:138
Eigen::Matrix< S, 3, 1 > getNormal(const Eigen::Matrix< S, 3, 1 > &p1, const Eigen::Matrix< S, 3, 1 > &p2, const Eigen::Matrix< S, 3, 1 > &p3)
Definition HeightmapShapeNode.hpp:275
void setVertices(const typename dynamics::HeightmapShape< S >::HeightField &heightmap, typename HeightmapShapeDrawable< S >::Vec3Array &vertices, ::osg::DrawElementsUInt &faces, typename HeightmapShapeDrawable< S >::Vec3Array &normals, typename HeightmapShapeDrawable< S >::Vector3 scale)
Definition HeightmapShapeNode.hpp:303
Definition BulletCollisionDetector.cpp:65