zoukankan      html  css  js  c++  java
  • 得到相交的三角面片的三个顶点坐标

    class PickEvent : public osgGA::GUIEventHandler
    {
    public:
     PickEvent(osg::Geometry* drawable) : _drawable(drawable){}
     ~PickEvent(){}
    public:
     bool handle(const osgGA::GUIEventAdapter& ea, osgGA::GUIActionAdapter& aa)
     {
      if (ea.getEventType() == osgGA::GUIEventAdapter::PUSH)
      {
         osgViewer::Viewer* viewer = dynamic_cast<osgViewer::Viewer*>(&aa);
          double x = ea.getX();
          double y = ea.getY();

       osgUtil::LineSegmentIntersector* picker = new osgUtil::LineSegmentIntersector(osgUtil::Intersector::WINDOW, x,y);
       osg::Camera* camera = viewer->getCamera();
       osgUtil::IntersectionVisitor visitor(picker);
       camera->accept(visitor);
       if (picker->containsIntersections())
       {
        osgUtil::LineSegmentIntersector::Intersections::iterator it = picker->getIntersections().begin();
        osg::Geometry* geometry = (*it).drawable->asGeometry();
        osg::Vec3Array* vertes = dynamic_cast<osg::Vec3Array*>( geometry->getVertexArray() );
        osg::Vec3* first = &(vertes->front());
        int i = (*it).indexList[0];
        int j = (*it).indexList[1];
        int k = (*it).indexList[2];

        osg::Vec3 test1 = *(first+i);
        osg::Vec3 test2 = *(first+j);
        osg::Vec3 test3 = *(first+k);
        }
       
       

      }
      return false;
      
     }
    public:
     osg::Transform* _transform;
     osg::Geometry* _drawable;

    };

  • 相关阅读:
    Linux下vi的用法
    C++程序设计语言编程风格演变史(转载)
    软件项目经理必备素质(转)
    DES加密算法的实现
    世界编程大赛一等奖作品
    AStar算法的原理及应用
    一个DirectX使用的例子
    ConsolePlayer
    自制贪吃蛇游戏
    关于安装 DirectX SDk Dec 2005 后无法编译DirectShow应用程序的问题
  • 原文地址:https://www.cnblogs.com/lizhengjin/p/1787388.html
Copyright © 2011-2022 走看看