• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            eryar

            PipeCAD - Plant Piping Design Software.
            RvmTranslator - Translate AVEVA RVM to OBJ, glTF, etc.
            posts - 603, comments - 590, trackbacks - 0, articles - 0

            OpenCASCADE 平面與球面求交

            Posted on 2019-10-08 22:57 eryar 閱讀(8338) 評論(0)  編輯 收藏 引用 所屬分類: 2.OpenCASCADE

            OpenCASCADE 平面與球面求交

            eryar@163.com

             

            OpenCASCADE提供了類IntAna_QuadQuadGeo用來計算兩個二次曲面quadric(球面、圓柱面、圓錐面及平面,平面是二次曲面的特例)之間的交線。他們之間可能的結(jié)果有:

            l 一個點

            l 一條或兩條直線

            l 一個點和一條直線

            l 圓

            l 橢圓

            l 拋物線

            l 雙曲線

             

            將源碼結(jié)合《高等數(shù)學(xué)》、《解析幾何》等書,可以來學(xué)習(xí)如何將理論付諸實踐。本文主要介紹這個類中平面與球面求交的源碼實現(xiàn)。 

            將源碼列出如下:

            void IntAna_QuadQuadGeo::Perform( const gp_Pln& P
                                             ,const gp_Sphere& S) 
            {
              done = Standard_False;
              Standard_Real A,B,C,D,dist, radius;
              Standard_Real X,Y,Z;
              nbint = 0;
            // debug JAG : on met typeres = IntAna_Empty par defaut...
              typeres = IntAna_Empty;
              P.Coefficients(A,B,C,D);
              S.Location().Coord(X,Y,Z);
              radius = S.Radius();
              dist = A * X + B * Y + C * Z + D;
              if (Abs( Abs(dist) - radius) < Epsilon(radius)) {
                // on a une seule solution : le point projection du centre de la sphere
                // sur le plan
                nbint = 1;
                typeres = IntAna_Point;
                pt1.SetCoord(X - dist*A, Y - dist*B, Z - dist*C);
              }
              else if (Abs(dist) < radius) {
                // on a un cercle solution
                nbint = 1;
                typeres = IntAna_Circle;
                pt1.SetCoord(X - dist*A, Y - dist*B, Z - dist*C);
                dir1 = P.Axis().Direction();
                if(P.Direct()==Standard_False) dir1.Reverse();
                dir2 = P.Position().XDirection();
                param1 = Sqrt(radius*radius - dist*dist);
              }
              param2bis=0.0; //-- pour eviter param2bis not used .... 
              done = Standard_True;
            }

            理解上述代碼需要有平面一般方程的概念及點到平面的距離計算公式:

             

            源碼實現(xiàn)步驟如下:

            l 取出平面一般方程的系數(shù):ABCD及球心坐標(biāo)XYZ

            l 計算球心到平面的距離dist

            l 若距離dist等于球面的半徑,則平面為球面的切平面,只有一個交點;

            l 若距離dist小于球面的半徑,則平面與球面的交線為圓;

            其中需要注意的是在獲取平面一般方程的參數(shù)時,平面的法向為單位向量,所以在計算球心到平面的距離時的分母為1

            從上述代碼可以看出OpenCASCADE的算法類的特點:即都有一個算法完成狀態(tài)的函數(shù)IsDone(),通過成員變量done來設(shè)置,算法執(zhí)行前都設(shè)置成false,算法成功后設(shè)置成true。還有一個前綴在變量名和函數(shù)名中很普遍,就是nb,是數(shù)量Number的縮寫,這里是一個成員變量nbint,即相交的數(shù)量。

             


            為了方便大家在移動端也能看到我的博文和討論交流,現(xiàn)已注冊微信公眾號,歡迎大家掃描下方二維碼關(guān)注。
            Shing Liu(eryar@163.com)
            热综合一本伊人久久精品| 国产精品久久久久久影院| 久久人妻少妇嫩草AV蜜桃| 欧美激情精品久久久久久久| 香蕉久久影院| 欧美黑人激情性久久| 久久最近最新中文字幕大全| 久久综合久久鬼色| 久久久婷婷五月亚洲97号色| 青青青伊人色综合久久| 久久天天躁狠狠躁夜夜躁2014| 久久久无码精品亚洲日韩蜜臀浪潮 | 色妞色综合久久夜夜| 色综合久久久久网| 久久亚洲AV无码精品色午夜麻豆| 一本久道久久综合狠狠爱| 日本精品久久久久中文字幕| 伊人久久精品无码二区麻豆| 国产精品内射久久久久欢欢| 久久国产高潮流白浆免费观看| 亚洲国产成人乱码精品女人久久久不卡 | 99精品久久久久久久婷婷| 中文字幕无码精品亚洲资源网久久| 伊人丁香狠狠色综合久久| 国内高清久久久久久| 久久丝袜精品中文字幕| 99久久精品久久久久久清纯| 久久99国产综合精品女同| 伊人久久精品无码二区麻豆| 亚洲精品成人久久久| 免费一级欧美大片久久网| 精品久久国产一区二区三区香蕉 | 亚洲国产精品一区二区三区久久| 99国产精品久久| 丁香五月网久久综合| 九九久久99综合一区二区| 无码专区久久综合久中文字幕| 久久婷婷人人澡人人爽人人爱| 日本精品久久久久中文字幕8| 国产成人久久激情91| 伊人久久精品线影院|