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

eryar

PipeCAD - Plant Piping Design Software.
PlantAssistant - Translate AVEVA RVM/SP3D VUE to glTF, STEP, etc.
posts - 606, comments - 590, trackbacks - 0, articles - 0

Make Helix Curve in OpenCASCADE

Posted on 2015-07-09 21:52 eryar 閱讀(5743) 評論(15)  編輯 收藏 引用 所屬分類: 2.OpenCASCADE

Make Helix Curve in OpenCASCADE

eryar@163.com

Abstract. OpenCASCADE does not provide helix curve directly, but you can build a helix curve by the pcurve of a surface(curve on surface). When you understand the pcurve of a surface, you can make a helix curve easily. The paper first make a helix by Tcl in Draw Test Harness, then translate the Tcl script to OpenCASCADE C++ code.

Key Words. OpenCASCADE, Helix Curve, PCurve, Sweep, Spring


1. Introduction

螺旋線是實踐中常用到的曲線,例如平頭螺絲釘?shù)耐饩壡€就是螺旋線。當我們擰緊平頭螺絲釘時,它的外緣曲線上的任一點M一方面繞螺絲釘?shù)妮S旋轉(zhuǎn),另一方面又沿平行于軸線的方向前進,點M就走出一段螺旋線。[1]

如果空間一點M在圓柱面x*x+y*y=a*a上以角速度ω繞z軸旋轉(zhuǎn),同時又以線速度υ沿平等于z軸正方向上升(其中ω,υ都是常數(shù)),那未點M構(gòu)成的圖形叫螺旋線。其參數(shù)方程為:

wps_clip_image-3353

wps_clip_image-14885

Figure 1.1 A Helix Curve

OpenCASCADE中并沒有直接提供構(gòu)造螺旋線的類和函數(shù),因此只有自己來構(gòu)造了,其中構(gòu)造的核心是要理解PCurve(曲面的參數(shù)曲線)。本文先以Tcl腳本在Draw Test Harness中快速生成一個螺旋線,再將相應(yīng)的Tcl腳本轉(zhuǎn)換成C++代碼。在理解Pcurve概念的基礎(chǔ)上來構(gòu)造螺旋線還是很簡單的,甚至還可以擴展應(yīng)用。

2.Make Helix Curve

在OpenCASCADE提供的一個經(jīng)典例子:生成一個酒瓶中,就有螺旋線的應(yīng)用,即生成瓶口處的螺紋。當時看這例子的時候也是沒有完全理解,究竟怎么生成的那個螺旋線?感謝lifenli的提醒,使我又重溫了一遍例子,頓時茅塞頓開,明白了pcurve的一個應(yīng)用。

由《OpenCASCADE BRep Format》[4]中可知,圓柱面的參數(shù)方程為:

wps_clip_image-29114

假設(shè)當你在參數(shù)空間[u,v]中創(chuàng)建一條二維曲線后,可根據(jù)這個二維曲線來計算對應(yīng)曲面上的三維曲線。根據(jù)二維曲線的不同定義,得到的結(jié)果如下:

條件

參數(shù)方程

參數(shù)曲線

U=0

S(v)=P+r*cos(u)+vDz

與Z軸平行的直線

V=0

S(u)=P+r*(cos(u)*Dx+sin(u)*Dy)

與XOY面平行的圓

U!=0 && V != 0

S(u,v)=P+r(cos(u)*Dx+sin(u)*Dy)+vDz

螺旋線

對比螺旋線的參數(shù)方程可知,當參數(shù)空間中的u和v都不為0時,得到的圓柱面上的線就是螺旋線。考慮最簡單的情況,那就是u=v,即在參數(shù)空間中是一條斜率k=1的直線。在OpenCASCADE的Draw Test Harness用Tcl腳本測試,Tcl腳本如下所示:
#
# make helix curve in OpenCASCADE.
# Shing Liu(eryar@163.com)
# 2015-07-08 22:00
#


pload MODELING VISUALIZATION

cylinder aCylinder 
6

line aLine2d 
0 0 1 1
trim aSegment aLine2d 
0 2*pi

mkedge aHelixEdge aSegment aCylinder 
0 6*pi

vdisplay aHelixEdge
代碼先加載所需的造型及顯示模塊,然后創(chuàng)建一個圓柱面aCylinder;一條二維直線aLine2d;再將參數(shù)范圍限定在0到2PI之間;最后使用了用曲面及其上的pcurve來創(chuàng)建邊的算法mkedge生成了螺旋線并顯示在三維窗口中。

wps_clip_image-9019

Figure 2.1 Make a helix by Tcl script

上述Tcl腳本可以很容易的轉(zhuǎn)換成C++代碼的,下面給出相應(yīng)的C++實現(xiàn),源碼如下所示:


#define WNT

#include 
<gp_Lin2d.hxx>

#include 
<GCE2d_MakeSegment.hxx>

#include 
<Geom_CylindricalSurface.hxx>

#include 
<BRepBuilderAPI_MakeEdge.hxx>

#include 
<TopoDS_Edge.hxx>

#include 
<BRepTools.hxx>

#pragma comment(lib, 
"TKernel.lib")
#pragma comment(lib, 
"TKMath.lib")
#pragma comment(lib, 
"TKG3d.lib")
#pragma comment(lib, 
"TKBRep.lib")
#pragma comment(lib, 
"TKGeomBase.lib")
#pragma comment(lib, 
"TKTopAlgo.lib")


void makeHelix(void)
{
    Handle_Geom_CylindricalSurface aCylinder 
= new Geom_CylindricalSurface(gp::XOY(), 6.0);

    gp_Lin2d aLine2d(gp_Pnt2d(
0.00.0), gp_Dir2d(1.01.0));

    Handle_Geom2d_TrimmedCurve aSegment 
= GCE2d_MakeSegment(aLine2d, 0.0, M_PI * 2.0);

    TopoDS_Edge aHelixEdge 
= BRepBuilderAPI_MakeEdge(aSegment, aCylinder, 0.06.0 * M_PI).Edge();

    BRepTools::Dump(aHelixEdge, std::cout);

    BRepTools::Write(aHelixEdge, 
"d:/helix.brep");
}

int main(int argc, char* argv[])
{
    makeHelix();

    
return 0;
}

由C++代碼可知,生成螺旋線的關(guān)鍵是在生成邊的時候,將pcurve和相應(yīng)的曲面及其參數(shù)范圍一起傳給了生成邊的類,這樣就得到拓樸邊了。如果想要得到幾何的螺旋線,可以使用工具BRep_Tool::Curve()來將拓樸邊中的幾何曲線提取出來。經(jīng)過測試,用pcurve生成的Edge中沒有三維幾何曲線,不過occ提供了一個靜態(tài)函數(shù)來將pcurve對應(yīng)的三維曲線擬合成nurbs曲線,函數(shù)為:BRepLib::BuildCurve3d();

參數(shù)空間中pcurve的斜率決定了螺旋線的螺距pitch,當其他參數(shù)不變,改變斜率后得到如下圖所示結(jié)果:

wps_clip_image-2214

Figure 2.2 Different Pitch by different K

由圖可知,當pcurve的斜率越小時,得到的螺旋線的螺距也越小。修改pcurve的斜率只需要修改上述Tcl腳本中的aLine2d的斜率。

如當斜率k=1時的pcurve為:

line aLine2d 0 0 1 1

當斜率k=1.0/5.0時的pcurve為:

line aLine2d 0 0 5 1

當斜率k=1.0/10.0時的pcurve為:

line aLine2d 0 0 10 1

可以自己嘗試修改看看沒的斜率得到的不同螺旋線的螺距變化。

3.Spring: Sweep profile along helix

得到螺旋線后自然就想到能不能用一個圓沿著螺旋線來放樣,從而得到一個彈簧。下面還是用Tcl腳本在Draw Test Harness中嘗試一下,相應(yīng)的C++實現(xiàn)也是很容易找到相關(guān)的類。


#
# make helix curve in OpenCASCADE.
# Shing Liu(eryar@163.com)
# 2015-07-08 22:00
#


pload MODELING VISUALIZATION

cylinder aCylinder 
6

line aLine2d 
0 0 1 1
trim aSegment aLine2d 
0 2*pi

mkedge aHelixEdge aSegment aCylinder 
0 6*pi

# there is no curve 3d in the pcurve edge.
mkedgecurve aHelixEdge 0.001

wire aHelixWire aHelixEdge

circle profile 
6 0 0 0 4 1 1
mkedge profile profile
wire profile profile
mkplane profile profile

pipe aSpring aHelixWire profile

vdisplay aSpring
vsetmaterial aSpring steel
vsetgradientbg 
180 200 255 180 180 180 2
vsetdispmode 
1
vzbufftrihedron

# set ray tracing
if { ! [catch {vrenderparams -raytrace -shadows -reflections -fsaa -rayDepth 5}] } {
    vtextureenv on 
1
}

生成效果如下圖所示:

wps_clip_image-8846

Figure 3.1 Spring by sweep a circle along a helix path

當將pcruve在圓錐面上生成三維曲線時就會得到類似夏天的蚊香那樣螺旋形狀。同樣使用上述代碼,只是將圓柱面改成圓錐面得到:

wps_clip_image-3726

Figure 3.2 Mosquito Coil

4.Conclusion

綜上所述,常見的計算幾何造型書中講到曲線的參數(shù)方程都會以螺旋線為經(jīng)典例子,甚至是高等數(shù)學(xué)中也是一樣,由此可見螺旋線是很常見的一種曲線。但是occ中并沒有直接提供螺旋線的幾何曲線,只有通過pcurve來構(gòu)造了。所以理解pcurve后,才好理解make bottle例子中的瓶頸螺紋部分的代碼。

通過將一個輪廓沿著螺旋線掃掠可以得出很多有意思的模型。在使用sweep的過程中發(fā)現(xiàn)pcurve生成的邊Edge中并沒有三維幾何曲線,所以會導(dǎo)致算法失敗。最終發(fā)現(xiàn)occ提供了一個將pcurve生成的邊中生成出一個擬合三維幾何曲線的函數(shù)BRepLib::BuildCurve3d()。對于一些在曲面上的曲線的造型可以參考這種用法,用pcurve來構(gòu)造。

5. References

1. 同濟大學(xué)數(shù)學(xué)教研室. 高等數(shù)學(xué)(上). 高等教育出版社. 1978

2. Helix. http://mathworld.wolfram.com/Helix.html

3. OpenCASCADE Make Bottle Tutorial. 2015

4. OpenCASCADE BRep Format. 2015

5. 莫勇,常智勇. 計算機輔助幾何造型技術(shù). 科學(xué)出版社. 2009

 

PDF Version and Tcl Script Make Helix Curve in OpenCASCADE

Feedback

# re: Make Helix Curve in OpenCASCADE  回復(fù)  更多評論   

2015-07-10 09:32 by 谷粒OO
沒想到螺旋線居然有公式~~~我以前是在3DS Max中反復(fù)畫,最后“根據(jù)感覺”用OpenGL畫出來了。

# re: Make Helix Curve in OpenCASCADE  回復(fù)  更多評論   

2015-07-10 15:16 by eryar
@谷粒OO

厲害啊!

看樣子有時感覺也很重要。^_^

# re: Make Helix Curve in OpenCASCADE  回復(fù)  更多評論   

2016-03-15 18:56 by 五只羊
博主您好,您這個斜率跟螺距有具體的換算公式嗎?

# re: Make Helix Curve in OpenCASCADE  回復(fù)  更多評論   

2016-03-15 19:13 by eryar
@五只羊

公式就在那螺旋線的參數(shù)方程中,仔細理解后就知道了

# re: Make Helix Curve in OpenCASCADE  回復(fù)  更多評論   

2016-03-16 15:28 by 遠離顛倒夢想
您好,,這個掃略功能是否掃略的平面必須垂直于所掃略的曲線端點的切向量?就是對平面的位置有沒有要求?

# re: Make Helix Curve in OpenCASCADE  回復(fù)  更多評論   

2016-03-16 19:31 by eryar
@遠離顛倒夢想
對平面的法向量沒有要求,只要不與掃略曲線平行。

# re: Make Helix Curve in OpenCASCADE  回復(fù)  更多評論   

2016-03-17 20:47 by 遠離顛倒夢想
是的,像您上面的螺旋彈簧的例子,那個掃略的平面是一個圓,,那這個圓是否應(yīng)該畫在端點處的法向量相垂直的地方?不然掃略下去肯定會有一部分掃壞了。。。

# re: Make Helix Curve in OpenCASCADE  回復(fù)  更多評論   

2016-03-17 21:38 by eryar
@遠離顛倒夢想
掃略平面法向不一定與端點處切向量垂直,你可以嘗試看看

# re: Make Helix Curve in OpenCASCADE  回復(fù)  更多評論   

2016-05-04 22:12 by liyunzhou
請問樓主,怎么由參數(shù)方程構(gòu)造曲線呢?

# re: Make Helix Curve in OpenCASCADE  回復(fù)  更多評論   

2016-05-04 22:54 by eryar
@liyunzhou

要看下你的參數(shù)方程是什么樣子的。

# re: Make Helix Curve in OpenCASCADE  回復(fù)  更多評論   

2016-05-05 08:53 by liyunzhou
@eryar
OCC里面能對任意給定的參數(shù)方程構(gòu)造曲線嗎?比如:
x=a*(2*cos(t)-cos(2*t))
y=a*(2*sin(t)-sin(2*t))

# re: Make Helix Curve in OpenCASCADE  回復(fù)  更多評論   

2016-05-05 11:03 by eryar
@liyunzhou
OCC目前Geom_Curve中支持Bezier和B樣條曲線,以及二次曲線,像圓,橢圓,拋物線,雙曲線。

對任意的參數(shù)曲線,我覺得有兩種方法:
1.可以參考二次曲線的類實現(xiàn),從Geom_Curve派生,實現(xiàn)相關(guān)虛函數(shù);
2.將你的參數(shù)曲線轉(zhuǎn)換成B樣條曲線;

Best Regards,
Shing Liu

# re: Make Helix Curve in OpenCASCADE  回復(fù)  更多評論   

2016-05-05 12:02 by liyunzhou
@eryar
謝謝樓主的解答,第一種方法應(yīng)該沒問題。我不太理解第二種方法具體怎么進行,是和您的《OpenCASCADE Conic to BSpline Curves-Parabola》(http://m.shnenglu.com/eryar/archive/2014/10/02/208484.html)這篇文章里介紹的方法類似嗎?針對參數(shù)方程確定B樣條的各個參數(shù)。

# re: Make Helix Curve in OpenCASCADE  回復(fù)  更多評論   

2016-05-05 18:26 by eryar
@liyunzhou

原理和這個類似,不過那幾個類只針對二次曲線到B樣條的轉(zhuǎn)換。

# re: Make Helix Curve in OpenCASCADE  回復(fù)  更多評論   

2016-05-05 21:20 by liyunzhou
@eryar
好的,謝謝樓主耐心解答。
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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小说| 国产精品久久久久一区| 亚洲美女免费精品视频在线观看| 久久久之久亚州精品露出| 欧美黄色aa电影| 亚洲欧美一级二级三级| 欧美激情一区二区三区高清视频| 在线观看成人网| 久久综合色婷婷| 久久九九免费视频| 在线不卡免费欧美| 欧美一区二区三区免费在线看| 欧美不卡视频| 欧美1区2区3区| 久久国产精品99久久久久久老狼| 国产精品视频精品视频| 午夜精品久久久99热福利| 亚洲视频精选在线| 国产精品久久久久久久久果冻传媒| 亚洲欧美另类国产| 亚洲一区二区不卡免费| 国产精品美女久久久浪潮软件| 午夜精品久久一牛影视| 欧美一区二区精品久久911| 国产一区二区中文字幕免费看| 久久青草福利网站| 欧美成人三级在线| 亚洲图片在线观看| 亚洲女性裸体视频| 一色屋精品视频在线看| 欧美在线你懂的| 香蕉久久精品日日躁夜夜躁| 国产精品美女| 欧美一区视频| 欧美xx视频| 亚洲精品一区二区三区在线观看 | 国产精品草草| 性欧美1819sex性高清| 久久精品夜夜夜夜久久| 99亚洲精品| 欧美一区二区日韩| 亚洲欧洲三级电影| 亚洲——在线| 亚洲三级电影在线观看 | 国产真实精品久久二三区| 欧美在线观看你懂的| 亚洲一区二区欧美日韩| 亚洲大片一区二区三区| 99国产精品久久| 一区在线电影| 欧美激情一区二区三区全黄| 欧美美女bb生活片| 欧美伊人久久久久久久久影院| 久久国产精品久久w女人spa| …久久精品99久久香蕉国产| 日韩一级黄色av| 在线播放精品| 欧美一区二区三区视频免费播放| 亚洲欧洲日韩综合二区| 欧美一区二区高清在线观看| 在线一区二区日韩| 蜜桃av一区| 噜噜噜久久亚洲精品国产品小说| 欧美精品久久久久久久久老牛影院| 99视频+国产日韩欧美| 欧美在线在线| 欧美亚洲在线| 欧美三日本三级少妇三99| 亚洲高清激情| 国产一区二区三区四区五区美女 | 久久国产精品久久久久久| 亚洲一区图片| 欧美日韩亚洲在线| 在线视频日韩| 欧美噜噜久久久xxx| 亚洲国产精品成人综合| 狠狠色综合一区二区| 亚洲欧美在线x视频| 欧美一区二区啪啪| 国产精品扒开腿爽爽爽视频| 久久久久久久一区| 国产精品一卡二| 蜜臀av性久久久久蜜臀aⅴ四虎| 日韩午夜精品| 久久婷婷蜜乳一本欲蜜臀| 亚洲毛片av在线| 国产欧美在线看| 欧美激情一区二区三区四区| 午夜激情一区| 亚洲黄页视频免费观看| 欧美综合国产精品久久丁香| 亚洲人成网站精品片在线观看| 国产精品乱人伦一区二区| 麻豆成人91精品二区三区| 在线综合亚洲| 亚洲欧美日产图| 91久久久久久久久久久久久| 国产精品区一区二区三| 牛牛影视久久网| 午夜在线一区| 99精品国产99久久久久久福利| 久久香蕉国产线看观看av| 一本久久青青| 91久久精品国产91性色| 国产视频精品免费播放| 欧美日韩亚洲在线| 欧美不卡视频一区发布| 欧美在线影院| 亚洲女同精品视频| 夜夜嗨av色综合久久久综合网| 欧美www视频| 久久九九国产| 欧美一区二区三区在线免费观看| 一本色道**综合亚洲精品蜜桃冫| 亚洲成人原创| 影音欧美亚洲| 红桃视频欧美| 国内精品久久久久久久影视蜜臀 | 欧美伊人久久久久久午夜久久久久| 99精品欧美一区二区三区| 影音先锋另类| 国外视频精品毛片| 国产日韩欧美综合一区| 国产精品va| 国产精品va在线播放| 欧美女同在线视频| 欧美激情精品久久久久久蜜臀| 久久中文欧美| 久久天天综合| 久久在线免费观看视频| 久久久www| 久久激情五月丁香伊人| 亚洲天堂av高清| 久久精品国产v日韩v亚洲| 在线电影欧美日韩一区二区私密| 韩国成人福利片在线播放| 好看的日韩视频| 在线播放一区| 亚洲精品日日夜夜| 99精品欧美一区二区蜜桃免费| 99在线热播精品免费| 一区二区三区蜜桃网| 亚洲性人人天天夜夜摸| 亚洲在线一区二区| 国产亚洲精品v| 激情久久久久| 91久久久久久久久| 一区二区三区三区在线| 亚洲综合电影| 久久精品91久久香蕉加勒比| 久久久久女教师免费一区| 久久夜色精品亚洲噜噜国产mv| 欧美/亚洲一区| 亚洲精品国产品国语在线app| 亚洲人体偷拍| 亚洲一区二区三区激情| 久久精品成人欧美大片古装| 六月婷婷久久| 欧美日韩免费在线观看| 国产精品入口66mio| 国产综合在线视频| 亚洲精品视频一区二区三区| 亚洲一区二区三区午夜| 久久久久久亚洲综合影院红桃 | 韩国在线一区| 亚洲欧洲一区二区天堂久久| 一区二区三区日韩精品| 久久精品久久综合| 欧美国产日韩一区二区| 一区二区三区日韩| 久久九九国产精品| 欧美网站在线观看| 精品成人在线观看| 99re在线精品| 久久久www成人免费毛片麻豆| 亚洲欧美国产制服动漫| 亚洲欧美日韩国产中文| 性做久久久久久久免费看| 牛人盗摄一区二区三区视频| 亚洲免费成人| 久久久久国产精品www| 欧美日韩一区精品| 好吊色欧美一区二区三区四区| 亚洲精品日韩在线观看| 久久国产精品一区二区三区四区| 裸体丰满少妇做受久久99精品| 亚洲另类自拍| 欧美影院精品一区| 国产精品theporn88| 亚洲电影免费观看高清完整版在线| 亚洲一区二区三区精品视频| 欧美va日韩va| 销魂美女一区二区三区视频在线| 欧美激情一区二区三区全黄| 永久免费精品影视网站| 性欧美在线看片a免费观看|