• osg HUD 背景图片设置


    #ifdef _WIN32
    #include <Windows.h>
    #endif // _WIN32
    #include<iostream>
    
    #include <osgViewer/Viewer>
    #include <osgViewer/ViewerEventHandlers> 
    #include <osgViewer/CompositeViewer> 
    
    #include <osgDB/ReadFile>
    
    #include <osg/Geode>
    #include <osg/Node>
    #include <osg/Geometry>
    #include <osg/GraphicsContext>
    #include <osg/ShapeDrawable>
    #include <osg/Material>
    #include <osg/Image>
    #include <osg/Texture2D>
    #include <osg/TexEnv>
    #include <osg/TexGen>
    #include <osg/NodeVisitor>
    #include <osg/MatrixTransform>
    #include <osg/PositionAttitudeTransform>
    #include <osg/AnimationPath>
    #include <osg/Matrixd>
    #include <osg/PagedLOD>
    #include <osg/Camera>
    #include <osgText/Text>
    
    #include <osgGA/TrackballManipulator>
    #include <osgGA/GUIEventHandler>
    #include <osgGA/CameraManipulator>
    #include <osgGA/StandardManipulator>
    #include <osgGA/OrbitManipulator>
    #include <osgGA/TrackballManipulator>
    
    #include <osgUtil/IntersectionVisitor>
    #include <osgUtil/LineSegmentIntersector>
    
    osg::Camera* createBackground(std::string strImg)
    {
        osg::ref_ptr<osg::Geode> geode1 = new osg::Geode;
        osg::ref_ptr<osg::Geometry> geometry1 = new osg::Geometry;
        osg::ref_ptr<osg::Camera> camera1 = new osg::Camera;
    
        camera1->setAllowEventFocus(false);
        camera1->setProjectionMatrixAsOrtho2D(0, 960, 0, 600);
        camera1->setViewport(0, 0, 960, 600);
    
        camera1->setReferenceFrame(osg::Transform::ABSOLUTE_RF);
        camera1->setRenderOrder(osg::Camera::PRE_RENDER);
        camera1->setClearMask(GL_DEPTH_BUFFER_BIT  |  GL_COLOR_BUFFER_BIT);
        //camera1->setClearColor(osg::Vec4());
        camera1->setViewMatrix(osg::Matrix::identity());
    
        //压入顶点
        osg::ref_ptr<osg::Vec3Array> vertex = new osg::Vec3Array;
        vertex->push_back(osg::Vec3(0.0,0.0,0.0));
        vertex->push_back(osg::Vec3(960.0, 0.0, 0.0));
        vertex->push_back(osg::Vec3(960.0, 600.0, 0.0));
        vertex->push_back(osg::Vec3(0.0, 600.0, 0.0));
        geometry1->setVertexArray(vertex);
    
        //压入法线
        osg::ref_ptr<osg::Vec3Array> norml = new osg::Vec3Array;
        norml->push_back(osg::Vec3(0.0, 0.0, 1.0));
        geometry1->setNormalArray(norml);
        geometry1->setNormalBinding(osg::Geometry::BIND_OVERALL);
    
        //纹理坐标
        osg::ref_ptr<osg::Vec2Array> coord = new osg::Vec2Array;
        coord->push_back(osg::Vec2(0.0,0.0));
        coord->push_back(osg::Vec2(1.0, 0.0));
        coord->push_back(osg::Vec2(1.0, 1.0));
        coord->push_back(osg::Vec2(0.0, 1.0));
        geometry1->setTexCoordArray(0, coord);
        geometry1->addPrimitiveSet(new osg::DrawArrays(osg::PrimitiveSet::QUADS, 0, 4));
    
        osg::ref_ptr<osg::Image> img1 = osgDB::readImageFile(strImg);
        if (!img1.valid())
        {
            std::cout << "" << std::endl;
        }
    
        osg::ref_ptr<osg::Texture2D> texture2d = new osg::Texture2D;
        texture2d->setImage(0, img1);
        geometry1->getOrCreateStateSet()->setTextureAttributeAndModes(0,texture2d,osg::StateAttribute::ON);
    
    
        camera1->addChild(geode1);
        geode1->getOrCreateStateSet()->setMode(GL_LIGHTING, osg::StateAttribute::OFF);
        geode1->addDrawable(geometry1);
    
    
        return camera1.release();
    }
    
    
    int main()
    {
        osg::ref_ptr<osgViewer::Viewer> viewer1 = new osgViewer::Viewer;
        osg::ref_ptr<osg::Group> group1 = new osg::Group;
    
        osg::ref_ptr<osg::Node> node1 = osgDB::readNodeFile("D:\参考手册\BIM\osg\build20190628.osgb");
    
        group1->addChild(createBackground("D:\参考手册\images\104.jpg"));
        group1->addChild(node1.get());
    
        viewer1->getCamera()->setClearMask(GL_DEPTH_BUFFER_BIT);
        viewer1->setSceneData(group1.get());
        viewer1->setUpViewInWindow(200, 200, 960, 600, 0);
    
        return viewer1->run();
    }

  • 相关阅读:
    FileManager(文件管理类)
    XE6 IntraWeb.v14.0.32安装及破解指南
    在应收应付系统凭证做冲销后,如何取消冲销?
    delphi将图片保存到SQL数据库和读取图片
    去掉cxgrid 中的过滤下拉箭头
    CxGrid 分组以后自动排序了,可以禁止自动排序吗
    最简单解决CHM文件无法显示的办法
    用友T3、T6常见问题
    SQL2005还原数据库3154错误
    cxGrid 怎样才能让不自动换行 WordWrap:=false
  • 原文地址:https://www.cnblogs.com/herd/p/11116470.html
Copyright © 2020-2023  润新知