亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

Render OpenCascade Geometry Curves in OpenSc

系統(tǒng) 3112 0

在OpenSceneGraph中繪制OpenCascade的曲線

Render?OpenCascade Geometry Curves in OpenSceneGraph

eryar@163.com

摘要Abstract:本文簡要說明OpenCascade中幾何曲線的數(shù)據(jù),并將這些幾何曲線在OpenSceneGraph中繪制出來。?

關(guān)鍵字KeyWords:OpenCascade、Geometry Curve、OpenSceneGraph、B-Spline、NURBS?

一、引言 Introduction

結(jié)合《BRep Format Description White Paper》對OpenCascade中的幾何數(shù)據(jù)結(jié)構(gòu)有詳細的介紹。OpenCascade中BRep格式中的曲線總共分為九種,不過有二維三維之分:?

1.直線 Line?

2.圓 Circle?

3.橢圓 Ellipse?

4.拋物線 Parabola?

5.雙曲線 Hyperbola?

6.Bezier曲線 Bezier Curve?

7.B-Spline曲線 B-Spline Curve?

8.裁剪曲線 Trimmed Curve?

9.偏移曲線 Offset Curve?

曲線的幾何數(shù)據(jù)都有一個抽象基類Geom_Curve,類圖如下所示:?

wps_clip_image-32738

Figure 1.1 Geometry curve class diagram?

抽象基類Geom_Curve有幾個純虛函數(shù)FirstParameter()、LastParameter()、Value(),根據(jù)這幾個虛函數(shù),就可以計算曲線上對應(yīng)參數(shù)U的值。類圖如下圖所示:?

wps_clip_image-32037

Figure 1.2 Geom_Curve Inherited class diagram?

每種曲線都對那些純虛函數(shù)進行實現(xiàn),使計算曲線上點的方式統(tǒng)一。?

二、程序示例 Code Example

根據(jù)抽象基類Geom_Curve的幾個純虛函數(shù):?

1.FirstParameter();?

2.LastParameter();?

3.Value(u);?

利用多態(tài)可將曲線上點都以統(tǒng)一的方式計算出來,并使用GL_LINE_STRIP繪制出來。示例程序如下所示:

      
        /*
      
      
        

*    Copyright (c) 2013 eryar All Rights Reserved.

*

*        File    : Main.cpp

*        Author  : eryar@163.com

*        Date    : 2013-08-09 18:09

*        Version : 1.0v

*

*    Description : Draw OpenCascade Geometry Curves in OpenSceneGraph.

*                  


      
      
        */
      
      
        //
      
      
         OpenSceneGraph library.
      
      

#include <osgDB/ReadFile>
      
        

#include 
      
      <osgViewer/Viewer>
      
        

#include 
      
      <osgViewer/ViewerEventHandlers>
      
        

#include 
      
      <osgGA/StateSetManipulator>




      
        #pragma
      
       comment(lib, "osgd.lib")


      
        #pragma
      
       comment(lib, "osgDbd.lib")


      
        #pragma
      
       comment(lib, "osgGAd.lib")


      
        #pragma
      
       comment(lib, "osgViewerd.lib")




      
        //
      
      
         OpenCascade library.
      
      

#include <TColgp_Array1OfPnt.hxx>
      
        

#include 
      
      <TColStd_Array1OfReal.hxx>
      
        

#include 
      
      <TColStd_Array1OfInteger.hxx>
      
        



#include 
      
      <Geom_Circle.hxx>
      
        

#include 
      
      <Geom_Ellipse.hxx>
      
        

#include 
      
      <Geom_Hyperbola.hxx>
      
        

#include 
      
      <Geom_Parabola.hxx>
      
        

#include 
      
      <Geom_BezierCurve.hxx>
      
        

#include 
      
      <Geom_BSplineCurve.hxx>




      
        #pragma
      
       comment(lib, "TKernel.lib")


      
        #pragma
      
       comment(lib, "TKMath.lib")


      
        #pragma
      
       comment(lib, "TKG3d.lib")




      
        //
      
      
         Curve Segment Delta.
      
      
        const
      
      
        double
      
       CURVE_SEGMENT_DELTA = 
      
        0.01
      
      
        ;




      
      
        /*
      
      
        

* @brief Build geometry curve of OpenCascade.


      
      
        */
      
      
        

osg::Node
      
      * buildCurve(
      
        const
      
       Geom_Curve&
      
         curve)

{

    osg::ref_ptr
      
      <osg::Geode> geode = 
      
        new
      
      
         osg::Geode();

    osg::ref_ptr
      
      <osg::Geometry> linesGeom = 
      
        new
      
      
         osg::Geometry();

    osg::ref_ptr
      
      <osg::Vec3Array> pointsVec = 
      
        new
      
      
         osg::Vec3Array();



    gp_Pnt point;

    
      
      
        double
      
       dFirst =
      
         curve.FirstParameter();

    
      
      
        double
      
       dLast =
      
         curve.LastParameter();



    Precision::IsNegativeInfinite(dFirst) 
      
      ? dFirst = -
      
        1.0
      
      
         : dFirst;

    Precision::IsInfinite(dLast) 
      
      ? dLast = 
      
        1.0
      
      
         : dLast;

    

    
      
      
        for
      
       (
      
        double
      
       u = dFirst; u <= dLast; u +=
      
         CURVE_SEGMENT_DELTA)

    {

        point 
      
      =
      
         curve.Value(u);



        pointsVec
      
      ->
      
        push_back(osg::Vec3(point.X(), point.Y(), point.Z()));

    }



    
      
      
        //
      
      
         Set the colors.
      
      

    osg::ref_ptr<osg::Vec4Array> colors = 
      
        new
      
      
         osg::Vec4Array;

    colors
      
      ->push_back(osg::Vec4(
      
        1.0f
      
      , 
      
        1.0f
      
      , 
      
        0.0f
      
      , 
      
        0.0f
      
      
        ));

    linesGeom
      
      ->setColorArray(colors.
      
        get
      
      
        ());

    linesGeom
      
      ->
      
        setColorBinding(osg::Geometry::BIND_OVERALL);



    
      
      
        //
      
      
         Set the normal in the same way of color.
      
      

    osg::ref_ptr<osg::Vec3Array> normals = 
      
        new
      
      
         osg::Vec3Array;

    normals
      
      ->push_back(osg::Vec3(
      
        0.0f
      
      , -
      
        1.0f
      
      , 
      
        0.0f
      
      
        ));

    linesGeom
      
      ->setNormalArray(normals.
      
        get
      
      
        ());

    linesGeom
      
      ->
      
        setNormalBinding(osg::Geometry::BIND_OVERALL);



    
      
      
        //
      
      
         Set vertex array.
      
      

    linesGeom->
      
        setVertexArray(pointsVec);

    linesGeom
      
      ->addPrimitiveSet(
      
        new
      
       osg::DrawArrays(osg::PrimitiveSet::LINE_STRIP, 
      
        0
      
      , pointsVec->
      
        size()));

    

    geode
      
      ->addDrawable(linesGeom.
      
        get
      
      
        ());



    
      
      
        return
      
      
         geode.release();

}




      
      
        /*
      
      
        *

* @breif Build geometry curve of OpenCascade.


      
      
        */
      
      
        

osg::Node
      
      *
      
         buildScene()

{

    osg::ref_ptr
      
      <osg::Group> root = 
      
        new
      
      
         osg::Group();



    
      
      
        //
      
      
         1. Build circle curve.
      
      

    Geom_Circle circle(gp::YOZ(), 
      
        1.0
      
      
        );



    root
      
      ->
      
        addChild(buildCurve(circle));



    
      
      
        //
      
      
         2. Build ellipse curve.
      
      

    Geom_Ellipse ellipse(gp::ZOX(), 
      
        1.0
      
      , 
      
        0.3
      
      
        );



    root
      
      ->
      
        addChild(buildCurve(ellipse));



    
      
      
        //
      
      
         3. Build Hyperbola curve.
      
      

    Geom_Hyperbola hyperbola(gp::XOY(), 
      
        1.0
      
      , 
      
        0.6
      
      
        );



    root
      
      ->
      
        addChild(buildCurve(hyperbola));



    
      
      
        //
      
      
         4. Build parabola curve.
      
      

    Geom_Parabola parabola(gp::ZOX(), 
      
        1.0
      
      
        );



    root
      
      ->
      
        addChild(buildCurve(parabola));



    
      
      
        //
      
      
         5. Build Bezier curve.
      
      

    TColgp_Array1OfPnt poles(
      
        1
      
      , 
      
        4
      
      
        );

    poles.SetValue(
      
      
        1
      
      , gp_Pnt(-
      
        1
      
      , -
      
        1
      
      , 
      
        0
      
      
        ));

    poles.SetValue(
      
      
        2
      
      , gp_Pnt(
      
        1
      
      , 
      
        2
      
      , 
      
        0
      
      
        ));

    poles.SetValue(
      
      
        3
      
      , gp_Pnt(
      
        3
      
      , 
      
        0
      
      , 
      
        0
      
      
        ));

    poles.SetValue(
      
      
        4
      
      , gp_Pnt(
      
        4
      
      , 
      
        1
      
      , 
      
        0
      
      
        ));

    Geom_BezierCurve bezierCurve(poles);



    root
      
      ->
      
        addChild(buildCurve(bezierCurve));



    
      
      
        //
      
      
         6. Build BSpline curve.
      
      

    TColgp_Array1OfPnt ctrlPnts(
      
        1
      
      , 
      
        3
      
      
        );

    TColStd_Array1OfReal knots(
      
      
        1
      
      , 
      
        5
      
      
        );

    TColStd_Array1OfInteger mults(
      
      
        1
      
      , 
      
        5
      
      
        );

    

    ctrlPnts.SetValue(
      
      
        1
      
      , gp_Pnt(
      
        0
      
      , 
      
        1
      
      , 
      
        0
      
      
        ));

    ctrlPnts.SetValue(
      
      
        2
      
      , gp_Pnt(
      
        1
      
      , -
      
        2
      
      , 
      
        0
      
      
        ));

    ctrlPnts.SetValue(
      
      
        3
      
      , gp_Pnt(
      
        2
      
      , 
      
        3
      
      , 
      
        0
      
      
        ));



    knots.SetValue(
      
      
        1
      
      , 
      
        0.0
      
      
        );

    knots.SetValue(
      
      
        2
      
      , 
      
        0.25
      
      
        );

    knots.SetValue(
      
      
        3
      
      , 
      
        0.5
      
      
        );

    knots.SetValue(
      
      
        4
      
      , 
      
        0.75
      
      
        );

    knots.SetValue(
      
      
        5
      
      , 
      
        1.0
      
      
        );



    mults.Init(
      
      
        1
      
      
        );



    Geom_BSplineCurve bsplineCurve(ctrlPnts, knots, mults, 
      
      
        1
      
      
        );



    root
      
      ->
      
        addChild(buildCurve(bsplineCurve));



    
      
      
        return
      
      
         root.release();

}




      
      
        int
      
       main(
      
        int
      
       argc, 
      
        char
      
      *
      
         argv[])

{

    osgViewer::Viewer myViewer;



    myViewer.setSceneData(buildScene());



    myViewer.addEventHandler(
      
      
        new
      
       osgGA::StateSetManipulator(myViewer.getCamera()->
      
        getOrCreateStateSet()));

    myViewer.addEventHandler(
      
      
        new
      
      
         osgViewer::StatsHandler);

    myViewer.addEventHandler(
      
      
        new
      
      
         osgViewer::WindowSizeHandler);



    
      
      
        return
      
      
         myViewer.run();

}
      
    

因拋物線和雙曲線的FirstParameter()和LastParameter()為負無窮和正無窮,所以對其進行處理,只輸出了部分曲線。?

程序效果如下圖所示:?

wps_clip_image-7357

Figure 2.1 OpenCascade Geometry Curves in OpenSceneGraph?

三、結(jié)論 Conclusion

OpenCascade的幾何數(shù)據(jù)使用還是很方便的,只要將相應(yīng)的曲線構(gòu)造出來之后,計算曲線上的點使用函數(shù)Value()即可,還可計算相應(yīng)參數(shù)處的微分值等。?

通過理解《BRep Format Description White Paper》,可將BRep文件中數(shù)據(jù)導(dǎo)入OpenCascade中與上面實現(xiàn)的程序進行對比,結(jié)果正確。如下圖所示:?

wps_clip_image-13312

Figure 3.1 B-Spline in OpenSceneGraph?

wps_clip_image-6019

Figure 3.2 B-Spline in OpenCascade Draw?

?

Render OpenCascade Geometry Curves in OpenSceneGraph


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯(lián)系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發(fā)表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 四虎影视884a精品国产古代 | 四虎永久成人免费 | 欧美性xxx | 青青热在线精品视频免费 | 欧美成人综合视频 | 亚洲欧美中文字幕专区 | 国产精品亚洲片在线观看麻豆 | 亚洲国产一区二区三区四区五区 | 抱着cao才爽视频 | 天堂一区二区三区精品 | 久久福利青草免费精品 | 欧美精品日日鲁夜夜 | 国产精品区牛牛影院 | 国产女人18一级毛片视频 | 久久99精品久久久久子伦小说 | 免费性生活视频 | 久久77| 他也色在线 | 免费h片网站 | 欧美性色欧美a在线观看 | 国产免费久久精品丫丫 | 两性视频久久 | www.黄黄黄 | 综合久久精品 | 国产福利在线 | 99精品国产自产在线观看 | 成人私拍福利视频在线 | 成人免费黄网站 | 四虎影视库国产精品一区 | 一级毛片欧美一级日韩黄 | 欧美一级毛片不卡免费观看 | 日本-区二区三区免费精品 日本热久久 | 日韩国产欧美成人一区二区影院 | 中文字幕在线观看国产 | 精品久久久影院 | 日韩一区二区三区在线观看 | 久久无码精品一区二区三区 | 欧美性视频在线激情 | 亚洲国产日本 | 3www黄| 精品一区二区三区的国产在线观看 |