青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

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 閱讀(8359) 評論(0)  編輯 收藏 引用 所屬分類: 2.OpenCASCADE

OpenCASCADE 平面與球面求交

eryar@163.com

 

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

l 一個點

l 一條或兩條直線

l 一個點和一條直線

l 圓

l 橢圓

l 拋物線

l 雙曲線

 

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

將源碼列出如下:

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;
}

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

 

源碼實現步驟如下:

l 取出平面一般方程的系數:ABCD及球心坐標XYZ

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

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

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

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

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

 


為了方便大家在移動端也能看到我的博文和討論交流,現已注冊微信公眾號,歡迎大家掃描下方二維碼關注。
Shing Liu(eryar@163.com)
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            狼人社综合社区| 国产女主播一区二区三区| 一区二区三区在线不卡| 久久国内精品自在自线400部| 亚洲综合好骚| 国产亚洲一区二区精品| 久久综合狠狠综合久久激情| 久久婷婷国产麻豆91天堂| 亚洲激情二区| 日韩午夜免费| 国产午夜精品麻豆| 欧美激情一区二区三区高清视频| 欧美激情一区二区在线| 亚洲一二三区在线| 亚洲欧美日韩一区在线观看| 国内偷自视频区视频综合| 欧美大片在线观看| 国产精品草莓在线免费观看| 久久久国产精彩视频美女艺术照福利| 欧美在线国产精品| 亚洲乱码国产乱码精品精98午夜| 在线视频亚洲| 影音先锋久久久| 一区二区欧美日韩| 在线观看国产日韩| 在线视频欧美精品| 亚洲国产精品va在线看黑人| 一区二区三区高清在线观看| 在线播放豆国产99亚洲| 一区二区三区欧美| 最新日韩在线| 亚洲女人天堂av| 日韩亚洲视频在线| 久久久久久999| 亚洲自拍电影| 免费在线亚洲| 久久精品视频免费播放| 欧美精品一区二区久久婷婷| 欧美一区二区视频在线| 老司机久久99久久精品播放免费 | 一本综合久久| 久久精品日韩欧美| 欧美亚洲一区| 欧美视频在线免费| 亚洲激情另类| 国产老女人精品毛片久久| 亚洲欧洲日韩在线| 在线国产日韩| 久久久999成人| 久久er99精品| 国产精品日韩一区| 一本色道久久综合| 一区二区三区精密机械公司 | 亚洲欧美一区二区视频| 一区二区三区四区国产| 久久久久免费| 性亚洲最疯狂xxxx高清| 亚洲一区在线播放| 欧美日韩ab| 最新国产精品拍自在线播放| 亚洲成色777777在线观看影院| 午夜精品一区二区三区在线视 | 狠狠爱成人网| 欧美在线地址| 久久久国产一区二区| 国产精品一区二区在线| 亚洲综合视频一区| 午夜在线一区| 国产欧美一区二区精品忘忧草| 亚洲色无码播放| 午夜精品福利一区二区蜜股av| 欧美视频中文字幕在线| 一本一本久久a久久精品牛牛影视| 99视频热这里只有精品免费| 欧美精品一区二区三区很污很色的 | 亚洲精品一区在线| 一区二区三区视频在线| 欧美午夜精品久久久久久超碰| 99re6这里只有精品| 亚洲免费影视第一页| 国产伦理精品不卡| 欧美在线1区| 欧美成人午夜免费视在线看片| 亚洲高清在线精品| 欧美日韩国产一区精品一区| 亚洲午夜一级| 另类国产ts人妖高潮视频| 亚洲人成在线观看网站高清| 欧美日韩在线第一页| 亚洲男人第一网站| 蜜臀va亚洲va欧美va天堂| 亚洲美女色禁图| 国产精品美女久久福利网站| 久久精品99无色码中文字幕| 欧美高清视频一区| 亚洲免费视频在线观看| 激情综合自拍| 国产精品护士白丝一区av| 久久精品视频一| 日韩视频在线永久播放| 久久久久久久一区| 一区二区三区成人精品| 国产资源精品在线观看| 欧美日韩大片| 久久久久久久综合| 亚洲亚洲精品三区日韩精品在线视频| 久久久久中文| 亚洲一区影院| 亚洲乱码国产乱码精品精可以看| 国产乱码精品一区二区三区av| 欧美 日韩 国产一区二区在线视频| 在线亚洲伦理| 亚洲国产精品第一区二区| 久久激情婷婷| 亚洲一区二区三区精品在线| 91久久精品久久国产性色也91| 国产精品久久久免费| 欧美精品18+| 久久综合色天天久久综合图片| 亚洲一二三区在线| 日韩视频在线观看国产| 欧美激情在线播放| 欧美成人三级在线| 久久精品国产亚洲a| 亚洲香蕉成视频在线观看| 亚洲国产婷婷香蕉久久久久久| 久久乐国产精品| 欧美一级在线亚洲天堂| 亚洲天堂网站在线观看视频| 亚洲国产色一区| 在线成人av网站| 韩日成人av| 国产亚洲va综合人人澡精品| 国产精品美女久久久免费| 欧美日韩在线播放| 欧美日韩国产色综合一二三四| 女主播福利一区| 欧美成人激情视频| 欧美福利视频一区| 欧美电影免费观看| 欧美极品aⅴ影院| 欧美激情视频网站| 欧美激情精品久久久久| 欧美激情第六页| 欧美理论电影在线播放| 欧美日本亚洲| 欧美四级在线| 国产精品女同互慰在线看| 国产精品日韩精品欧美在线| 国产精品日韩高清| 国产资源精品在线观看| 在线观看欧美日韩国产| 91久久久久| 在线一区二区三区四区| 亚洲免费一级电影| 久久久久久高潮国产精品视| 老司机免费视频久久| 欧美激情国产日韩| 亚洲美女中文字幕| 亚洲欧美春色| 久久中文欧美| 欧美日韩亚洲另类| 国产日韩精品在线播放| 在线 亚洲欧美在线综合一区| 亚洲精品免费电影| 亚洲一区二区成人在线观看| 欧美一区二区三区在| 牛牛影视久久网| 亚洲伦理久久| 欧美一区二区啪啪| 欧美成人日本| 国产日韩专区| 亚洲精品一区二区三区樱花| 亚洲在线免费观看| 美女精品视频一区| 亚洲最快最全在线视频| 欧美中在线观看| 欧美美女操人视频| 国模叶桐国产精品一区| 夜夜嗨av色一区二区不卡| 欧美在线黄色| 亚洲日本免费电影| 欧美影院精品一区| 欧美日韩亚洲综合在线| 狠狠色噜噜狠狠色综合久| 亚洲视频国产视频| 免播放器亚洲| 午夜久久福利| 欧美日韩视频在线第一区| 激情综合在线| 欧美一级久久| 日韩亚洲欧美精品| 免费亚洲网站| 韩国av一区二区三区四区| 亚洲视频在线观看一区| 欧美高清视频| 久久精品国产69国产精品亚洲 | 亚洲女人天堂成人av在线| 欧美国内亚洲| 激情自拍一区|