• <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點(diǎn)向平面投影

            Posted on 2019-05-29 21:02 eryar 閱讀(1607) 評(píng)論(0)  編輯 收藏 引用 所屬分類: 2.OpenCASCADE

            OpenCASCADE點(diǎn)向平面投影

             

            OpenCASCADEProjLib類提供了解析曲線(直線、圓、橢圓、拋物線、雙曲線)向解析曲面(平面、圓柱面、圓錐面、球面、圓環(huán)面)投影的功能,主要用來(lái)計(jì)算三維曲線在二維參數(shù)空間的參數(shù)。

             

            其中點(diǎn)向平面投影是最簡(jiǎn)單的情況,本文主要介紹點(diǎn)向平面投影的注意事項(xiàng)。ProjLib類是個(gè)工具類,因?yàn)槠浜瘮?shù)都是靜態(tài)函數(shù)。點(diǎn)向平面投影很簡(jiǎn)單,直接用ProjLib::Project(aPlane, aPoint)即可。

             

            其實(shí)現(xiàn)代碼如下:

            gp_Pnt2d  ProjLib::Project(const gp_Pln& Pl, const gp_Pnt& P)
            {
              Standard_Real U, V;
              ElSLib::Parameters(Pl, P, U, V);
              return gp_Pnt2d(U,V);
            }
            inline void ElSLib::Parameters(const gp_Pln& Pl,
                      const gp_Pnt& P,
                      Standard_Real& U,
                      Standard_Real& V) {
              ElSLib::PlaneParameters(Pl.Position(),P,U,V);
            }
            void ElSLib::PlaneParameters (const gp_Ax3& Pos,
                     const gp_Pnt& P,
                     Standard_Real& U,
                     Standard_Real& V)
            {
              gp_Trsf T;
              T.SetTransformation (Pos);
              gp_Pnt Ploc = P.Transformed (T);
              U = Ploc.X();
              V = Ploc.Y();
            }
            

            從上面的代碼可以看出,點(diǎn)向平面投影實(shí)現(xiàn)就是將點(diǎn)變換到平面所在的坐標(biāo)系中。使用這個(gè)類向平面投影要注意的事項(xiàng)是平面的構(gòu)造。平面gp_Pln有如下構(gòu)造函數(shù):

             

            默認(rèn)構(gòu)造函數(shù):構(gòu)造了一個(gè)XOY平面

            基于一個(gè)坐標(biāo)系gp_Ax3構(gòu)造平面

            基于一個(gè)點(diǎn)和一個(gè)方向構(gòu)造平面

            基于平面的系數(shù)方程,即AX+BY+CZ+D=0

            前兩個(gè)構(gòu)造函數(shù)很清晰,而第三個(gè)構(gòu)造函數(shù)即基于一個(gè)點(diǎn)和一個(gè)方向構(gòu)造平面的方式?jīng)]有明確,注釋不清晰。這里的方向指定了平面的法向,但是還缺少一個(gè)方向來(lái)確定一個(gè)坐標(biāo)系,所以使用這個(gè)構(gòu)造函數(shù)來(lái)生成平面的時(shí)候,需要理解其生成另外一個(gè)方向的算法是不是自己需要的。

            gp_Pln::gp_Pln (const gp_Pnt& P,
              const gp_Dir& V)
            {
              Standard_Real A = V.X();
              Standard_Real B = V.Y();
              Standard_Real C = V.Z();
              Standard_Real Aabs = A;
              if (Aabs < 0) Aabs = - Aabs;
              Standard_Real Babs = B;
              if (Babs < 0) Babs = - Babs;
              Standard_Real Cabs = C;
              if (Cabs < 0) Cabs = - Cabs;
              //  pour determiner l'axe X :
              //  on dit que le produit scalaire Vx.V = 0. 
              //  et on recherche le max(A,B,C) pour faire la division.
              //  l'une des coordonnees du vecteur est nulle. 
              if( Babs <= Aabs && Babs <= Cabs) {
                if (Aabs > Cabs)  pos = gp_Ax3 (P, V, gp_Dir (-C,0., A));
                else              pos = gp_Ax3 (P, V, gp_Dir ( C,0.,-A));
              }
              else if( Aabs <= Babs && Aabs <= Cabs) {
                if (Babs > Cabs)  pos = gp_Ax3 (P, V, gp_Dir (0.,-C, B));
                else              pos = gp_Ax3 (P, V, gp_Dir (0., C,-B));
              }
              else {
                if (Aabs > Babs)  pos = gp_Ax3 (P, V, gp_Dir (-B, A,0.));
                else              pos = gp_Ax3 (P, V, gp_Dir ( B,-A,0.));
              }
            }
            

            當(dāng)這里確定平面坐標(biāo)系的方式與需要的不一致時(shí),在使用投影算法的時(shí)候就會(huì)產(chǎn)生問(wèn)題。

            精品久久久久久国产| 国产精品青草久久久久婷婷| 久久久WWW免费人成精品| 狠狠色综合久久久久尤物| 噜噜噜色噜噜噜久久| 久久国产高潮流白浆免费观看| 国产亚洲精午夜久久久久久 | 亚洲性久久久影院| 少妇内射兰兰久久| 久久99精品久久久久久噜噜| 伊人情人综合成人久久网小说| 久久久久久久久久久久久久| 99久久国语露脸精品国产| 伊人久久大香线蕉精品不卡 | 色婷婷综合久久久久中文一区二区| 久久午夜电影网| 性色欲网站人妻丰满中文久久不卡| 久久国产影院| 久久天堂电影网| 波多野结衣中文字幕久久 | 久久久久亚洲av无码专区喷水 | 人妻丰满?V无码久久不卡| 国产午夜精品久久久久免费视| 婷婷久久综合九色综合绿巨人 | 精品久久久无码中文字幕| 中文字幕久久精品无码| 久久久久久A亚洲欧洲AV冫| 色综合久久综合中文综合网| 久久精品国产亚洲7777| 亚洲精品高清国产一久久| avtt天堂网久久精品| 2021精品国产综合久久| 久久精品国产亚洲av麻豆色欲| 国产精品久久久久久五月尺| 天堂无码久久综合东京热| 久久久无码精品午夜| 久久久久香蕉视频| 国产精品久久久天天影视香蕉| 久久精品中文騷妇女内射| 性做久久久久久久| 久久永久免费人妻精品下载|