Posted on 2017-12-27 20:43
eryar 阅读(2667)
评论(0) 编辑 收藏 引用 所属分类:
2.OpenCASCADE
OpenCASCADE构造一柱曲面
eryar@163.com
Abstract. 本文主要介绍常见的曲面如一般柱面(拉伸曲面)、旋转面在OpenCASCADE中的构造方法,由此思考一般放样算法的实现。
Key Words. Common Surface, Extrusion, Revolution
1.Introduction
实体Solid就是由面组成,面中包含几何曲面,常见的几何曲面有平面,柱面,旋转面等。对几何曲面有一些功能要求:如计算指定参数u,v处的点,切线等,即求指定参数u,v处的0阶导数、1阶导数,N阶导数;获取参数空间等。
data:image/s3,"s3://crabby-images/c0918/c09188a26be3f0f81c753fe9c7d49ec4d20bb797" alt="wps_clip_image-5601 wps_clip_image-5601"
图1. 放样曲面
由类图可以看出,放样曲面Swept Surface有两种形式:Geom_SurfaceOfLinearExtrusion和Geom_SurfaceOfRevolution。一种是线性拉伸成形的曲面,一种是旋转成形的曲面。
data:image/s3,"s3://crabby-images/03281/03281fae395d84b84afc49e6d5aa4a4ad268155f" alt="wps_clip_image-11911 wps_clip_image-11911"
图2. 拉伸曲面
如上图1所示,可以将一条曲线沿一方向拉伸一定的距离来构造曲面,被拉伸的曲线称为准线。
data:image/s3,"s3://crabby-images/112e4/112e47899198bb3f66cd5ca34d0a54454d62e139" alt="wps_clip_image-28612 wps_clip_image-28612"
图3. 旋转曲面
如上图2所示,将一条曲线绕指定的轴线旋转一定的角度得到一个旋转面。
本文结合OpenCASCADE中源码来说明拉伸曲面及旋转曲面原理。
2.The Surface of Extrusion
OpenCASCADE中线性拉伸曲面的类名为:Geom_SurfaceOfLinearExtrusion,其参数方程如下:
data:image/s3,"s3://crabby-images/51445/51445206812c0686e4fbbd0537f5685ead83a173" alt="wps_clip_image-363 wps_clip_image-363"
其中参数u的定义域决定准线C(u)的参数范围;参数v的取值范围是无穷的。即拉伸曲面是一个很长的柱面,如果在参数v上不加限制的话。其中一些计算功能代码如下所示:
//! Shift the point along direction to the given distance (theShift)
void Shift(const Standard_Real theShift, gp_Pnt& thePoint) const
{
thePoint.ChangeCoord() += myDirection.XYZ() * theShift;
}
void GeomEvaluator_SurfaceOfExtrusion::D0(
const Standard_Real theU, const Standard_Real theV,
gp_Pnt& theValue) const
{
if (!myBaseAdaptor.IsNull())
myBaseAdaptor->D0(theU, theValue);
else
myBaseCurve->D0(theU, theValue);
Shift(theV, theValue);
}
从计算曲面上在指定参数u,v处的点的函数D0()可以看出,先根据参数u计算出准线上的点,再将点沿拉伸方向移动拉伸向量模的距离。
data:image/s3,"s3://crabby-images/13206/1320698a90fb84069c4d02ef570630b7e69067a9" alt="wps_clip_image-10127 wps_clip_image-10127"
图4. 拉伸多边形
如上图4所示为将多边形准线沿着Z方向拉伸得到一个拉伸曲面。
3.The Surface of Revolution
OpenCASCADE中旋转曲面的类名为:Geom_SurfaceOfRevolution,其参数方程如下:
data:image/s3,"s3://crabby-images/4b90d/4b90deebe595074d26f6c3592b8805a117638b6c" alt="wps_clip_image-21064 wps_clip_image-21064"
其中计算旋转曲面上对应参数u,v的点的代码如下:
void GeomEvaluator_SurfaceOfRevolution::D0(
const Standard_Real theU, const Standard_Real theV,
gp_Pnt& theValue) const
{
if (!myBaseAdaptor.IsNull())
myBaseAdaptor->D0(theV, theValue);
else
myBaseCurve->D0(theV, theValue);
gp_Trsf aRotation;
aRotation.SetRotation(myRotAxis, theU);
theValue.Transform(aRotation);
}
根据代码可知,先根据参数v计算曲线上的点,再将点按指定的轴旋转变换。
data:image/s3,"s3://crabby-images/e1641/e164160957244f46c4f5db94600fd9ab91feb4d8" alt="wps_clip_image-12126 wps_clip_image-12126"
图5. 旋转曲面
如上图5所示,将红色母线绕Y轴旋转90度得到的旋转曲面。线性拉伸曲面和旋转曲面都是特定条件下的放样曲面。拉伸曲面为沿直线放样得到的曲面,旋转曲面是沿圆放样得到的曲面。由此,可以思考一个问题,那就是如何将任意一个曲面沿任意路径来放样构造曲面呢?
data:image/s3,"s3://crabby-images/5dcd7/5dcd72b9f66440920a5f5d19fd70f9b7106aab78" alt="wps_clip_image-8780 wps_clip_image-8780"
图6. 放样曲面
为了方便大家在移动端也能看到我的博文,现已注册微信公众号,欢迎大家扫描下方二维码关注。
data:image/s3,"s3://crabby-images/0d8d4/0d8d4c1c76a5aee7321535ff3356022fe468b820" alt="微信公众号 Shing Liu(eryar@163.com)"