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

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>
            久久青青草综合| 好看的亚洲午夜视频在线| 久久精品国产亚洲高清剧情介绍 | 亚洲视频香蕉人妖| 久久精品人人做人人爽| 久久一区二区三区av| 牛牛精品成人免费视频| 欧美日韩精品一区| 一区二区三区久久| 国产一区导航| 久久精品网址| 亚洲午夜激情网页| 国产日韩精品在线播放| 99re6热在线精品视频播放速度 | 久久亚洲欧美| 欧美国产日韩一二三区| 国产亚洲欧美一区二区三区| 国产麻豆91精品| 一区二区三区国产在线| 午夜精品久久久久久99热软件| 欧美激情视频免费观看| 亚洲日本中文字幕区| 国产欧美短视频| 欧美国产另类| 欧美不卡在线| 激情视频一区二区| 欧美三级电影网| 夜夜嗨av色综合久久久综合网| 久久久久九九九九| 欧美高清在线一区| 亚洲视频一区| 亚洲电影中文字幕| 99亚洲伊人久久精品影院红桃| 久久精品一区二区三区四区 | 日韩视频免费观看| 一区二区日韩| 在线观看日韩www视频免费| 欧美日韩在线免费观看| 亚洲欧美国产精品桃花| 欧美一区视频| 欧美大胆成人| 亚洲国产毛片完整版| 亚洲免费福利视频| 亚洲精品国产精品国自产在线| 午夜精品剧场| 18成人免费观看视频| 久久蜜臀精品av| 欧美制服丝袜第一页| 亚洲在线观看视频网站| 亚洲毛片在线看| 欧美日韩三级电影在线| 久久婷婷国产综合精品青草 | 欧美日韩黄视频| 最新国产拍偷乱拍精品| 欧美在线1区| 一区二区高清在线观看| 国产欧美日韩高清| 美日韩精品免费| 亚洲靠逼com| 欧美成人精品激情在线观看| 亚洲影院一区| 亚洲第一久久影院| 亚洲视频精品在线| 夜夜夜久久久| 99国产精品久久久久老师| 在线成人激情黄色| 欧美一区二区三区四区在线| 久久综合九色综合欧美就去吻| 蜜臀久久99精品久久久画质超高清| 欧美精品一区二区三| 精久久久久久久久久久| 欧美一区在线看| 久久国产精品72免费观看| 在线国产精品一区| 亚洲福利电影| 欧美 日韩 国产在线 | 亚洲精品视频在线观看网站 | 国产精品免费观看在线| 亚洲精品影视| 亚洲成人资源| 亚洲视频综合在线| 性欧美办公室18xxxxhd| 中文成人激情娱乐网| 亚洲精选中文字幕| 久久亚洲春色中文字幕| 亚洲精品美女在线| 国产一区二区看久久| 日韩视频中文字幕| 国产精品黄色在线观看| 欧美一区二区三区视频在线观看| 欧美日一区二区在线观看 | 亚洲第一精品影视| 久久久青草婷婷精品综合日韩| 国产精品乱码一区二三区小蝌蚪| 亚洲人成人77777线观看| 一区二区日韩| 99精品国产在热久久婷婷| 黄色成人在线| 久久精品麻豆| 欧美激情国产高清| 欧美激情一二区| 国产精品区二区三区日本| 另类专区欧美制服同性| 最新亚洲视频| 欧美精品亚洲精品| 久久精品国产一区二区三 | 亚洲第一精品久久忘忧草社区| 欧美激情免费观看| 午夜老司机精品| 一区二区在线观看av| 欧美在线观看天堂一区二区三区| 欧美一级网站| 久久久天天操| 亚洲精品中文字幕有码专区| 久久久久高清| 国产精品视频免费| 欧美国产欧美亚州国产日韩mv天天看完整| 噜噜噜在线观看免费视频日韩| 久久一区亚洲| 欧美日韩精品一区二区天天拍小说| 欧美高清视频免费观看| 麻豆精品视频在线观看| 欧美视频第二页| 亚洲国产欧美另类丝袜| 老司机免费视频久久| 国产精品视频网址| 极品av少妇一区二区| 欧美福利一区| 久久国产欧美| 99国内精品| 亚洲综合成人在线| 欧美涩涩网站| 免费国产自线拍一欧美视频| 欧美freesex8一10精品| 久久这里有精品15一区二区三区| 国产亚洲亚洲| 亚洲人成人77777线观看| 欧美人交a欧美精品| 99精品久久久| 亚洲三级色网| 你懂的视频一区二区| 欧美专区在线观看| 欧美一区二区精品久久911| 激情懂色av一区av二区av| 中国成人在线视频| 欧美精品一区三区| 日韩一区二区免费看| 99视频+国产日韩欧美| 欧美日本中文字幕| 欧美一区在线直播| 亚洲福利视频在线| 国产精品毛片大码女人| 国产综合久久| 欧美一区二区三区在线观看视频| 亚洲高清不卡在线| 欧美激情区在线播放| 国产精品va在线| 欧美日本久久| 亚洲欧洲日韩综合二区| 欧美三区在线视频| 欧美国产欧美亚州国产日韩mv天天看完整| 久久精品2019中文字幕| 一本色道综合亚洲| 一区二区三区欧美亚洲| 久久九九久精品国产免费直播| 免费欧美在线| 亚洲精品国产精品国自产观看浪潮| 欧美在线视频免费播放| 亚洲国产精品v| 亚洲高清一区二区三区| 亚洲尤物在线| 国产一二精品视频| 国产精品99久久久久久人| 一本色道久久加勒比88综合| 在线观看日韩av| 亚洲精品免费在线| 久久久久国色av免费看影院| 亚洲精品日韩精品| 亚洲卡通欧美制服中文| av成人国产| 欧美午夜一区二区福利视频| 亚洲影视九九影院在线观看| 亚洲国产精品第一区二区三区 | 国产日韩欧美麻豆| av成人免费观看| 亚洲国产高清一区| 国产精品日韩| 国产拍揄自揄精品视频麻豆| 亚洲精品美女在线观看| 久久精品av麻豆的观看方式| 亚洲尤物视频在线| 久久精品成人| 亚洲午夜激情在线| 国外成人在线视频网站| 国产一级一区二区| 欧美高清在线播放| 久久国产精品电影| 欧美国产精品劲爆| 久久成年人视频| 欧美日在线观看|