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

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>
            一区二区欧美日韩视频| 韩国福利一区| 中国日韩欧美久久久久久久久| 欧美黄色日本| 另类酷文…触手系列精品集v1小说| 永久免费精品影视网站| 亚洲激情一区二区| 欧美区二区三区| 亚洲欧美中文另类| 久久另类ts人妖一区二区| 亚洲激情欧美激情| 在线视频精品一| 国产一区二区三区久久精品| 麻豆精品网站| 欧美日韩国产va另类| 性欧美xxxx视频在线观看| 久久精品视频一| 亚洲精品午夜精品| 亚洲欧美国产精品专区久久| 亚洲丁香婷深爱综合| 欧美激情第8页| 欧美 日韩 国产一区二区在线视频 | 欧美激情第三页| 亚洲一区二区3| 欧美主播一区二区三区美女 久久精品人 | 夜夜嗨av一区二区三区四季av | 国产在线高清精品| 亚洲国产一二三| 国产精品亚洲人在线观看| 美国十次了思思久久精品导航| 欧美日韩精品中文字幕| 久久天天躁夜夜躁狠狠躁2022| 欧美激情一区二区三区高清视频 | 欧美中文字幕在线播放| 农村妇女精品| 久久久xxx| 欧美性视频网站| 欧美激情亚洲激情| 国内免费精品永久在线视频| 99国产精品国产精品久久| 亚洲第一精品影视| 新狼窝色av性久久久久久| 这里只有视频精品| 欧美成人中文| 欧美aaa级| 黄网动漫久久久| 午夜精品视频在线观看| 亚洲一区二区三区影院| 欧美成人精品一区| 男人的天堂成人在线| 国内不卡一区二区三区| 亚洲欧美精品中文字幕在线| 亚洲专区一区二区三区| 欧美人与禽性xxxxx杂性| 免费影视亚洲| 亚洲国产精品第一区二区| 久久国内精品视频| 久久精品99| 国产偷自视频区视频一区二区| 夜夜嗨av一区二区三区四季av| 亚洲精品视频啊美女在线直播| 蜜桃av一区二区三区| 欧美成人精品影院| 亚洲欧洲精品一区二区三区| 久热国产精品视频| 欧美高清一区二区| 亚洲欧洲久久| 欧美精品18+| 99国内精品久久| 亚洲欧美另类综合偷拍| 国产精品入口麻豆原神| 午夜精品免费在线| 久久精品综合网| 136国产福利精品导航| 老色鬼精品视频在线观看播放| 麻豆九一精品爱看视频在线观看免费| 国内精品写真在线观看| 久久香蕉精品| 欧美亚洲三级| 国产精品高潮呻吟久久av黑人| 亚洲视频一二| 国产精品草莓在线免费观看| 一区二区三区**美女毛片 | 国产精品扒开腿做爽爽爽软件| 一区二区三区欧美日韩| 久久成人这里只有精品| 在线观看欧美激情| 欧美片网站免费| 先锋影音一区二区三区| 噜噜噜91成人网| 99视频有精品| 国产美女精品视频| 欧美jizz19性欧美| 亚洲午夜精品一区二区| 快播亚洲色图| 一区二区三区精品国产| 国产视频精品免费播放| 欧美成人精品不卡视频在线观看| 日韩一级成人av| 老色鬼精品视频在线观看播放| 一本色道久久综合| 国产日韩欧美在线视频观看| 另类天堂av| 午夜在线精品| 亚洲精品中文字| 免费欧美电影| 欧美亚洲综合网| 99国产欧美久久久精品| 国产亚洲综合精品| 欧美日韩人人澡狠狠躁视频| 欧美一区视频| 99av国产精品欲麻豆| 欧美va亚洲va国产综合| 性欧美xxxx视频在线观看| 亚洲免费av片| 玉米视频成人免费看| 国产精品视频午夜| 欧美激情亚洲一区| 久久亚洲综合色一区二区三区| 亚洲一区网站| 99国产精品久久久久老师| 欧美激情精品久久久六区热门 | 亚洲精品久久久蜜桃| 国产一区二区三区网站| 国产精品久久久久久久久久久久久久 | 免费一区二区三区| 久久不射中文字幕| 午夜精品一区二区三区电影天堂 | 亚洲乱码国产乱码精品精天堂| 免费在线日韩av| 久久电影一区| 欧美在线观看视频| 亚洲免费视频一区二区| 这里只有精品视频| 在线一区二区日韩| 99国产精品久久久久久久成人热 | 亚洲大片精品永久免费| 激情成人在线视频| 精品不卡在线| 久久久久久久性| 久久久久久久久综合| 欧美在线首页| 久久久777| 久久综合中文色婷婷| 看片网站欧美日韩| 麻豆乱码国产一区二区三区| 久久亚洲视频| 欧美wwwwww| 欧美高清在线观看| 欧美人成在线视频| 欧美日韩一区二区免费视频| 嫩草影视亚洲| 欧美激情 亚洲a∨综合| 欧美精品在线一区| 欧美日韩精品一区二区三区| 欧美日韩一区在线视频| 欧美日韩亚洲一区二区三区在线观看| 欧美精品免费观看二区| 欧美日韩亚洲一区二区三区在线观看 | 久久精品午夜| 美女尤物久久精品| 欧美日韩国产区一| 国产精品初高中精品久久| 国产目拍亚洲精品99久久精品| 国产午夜精品麻豆| 亚洲国产精品女人久久久| 一区二区三区在线高清| 亚洲三级电影在线观看 | 国产一区二区精品在线观看| 亚洲电影观看| 一区二区三区欧美激情| 欧美一区久久| 亚洲成人在线视频播放| 亚洲精品久久嫩草网站秘色 | 亚洲国产裸拍裸体视频在线观看乱了中文 | 亚洲精品美女在线观看播放| 亚洲一区视频在线| 久久香蕉国产线看观看网| 老司机免费视频一区二区| 亚洲日本中文字幕| 午夜精品短视频| 久久国内精品视频| 欧美日韩性生活视频| 国语精品一区| 一本色道久久综合| 久久综合狠狠综合久久综青草 | 亚洲高清免费视频| 亚洲欧美电影院| 欧美激情 亚洲a∨综合| 国产亚洲aⅴaaaaaa毛片| 99国产精品久久久久久久| 久久人人爽人人| 亚洲一级免费视频| 欧美高清免费| 激情视频一区| 性色av一区二区三区红粉影视| 亚洲国产精品第一区二区三区| 欧美一区二区| 国产精品久线观看视频| 夜久久久久久|