天气与日历 切换到窄版

 找回密码
 立即注册
中国膜结构网
十大进口膜材评选 十大国产膜材评选 十大膜结构设计评选 十大膜结构公司评选
查看: 4|回复: 0

How to Intersect a line with a solid?‎如何将直线与实线相交?‎

[复制链接]

该用户从未签到

主题

0

回帖

2912

积分

管理员

积分
2912
发表于 2024-6-22 09:46:18 | 显示全部楼层 |阅读模式
[code]// This is command 'INTSOLID'

void Asdkintsolid()

{



AcDbObjectId lineId;

AcDbObjectId solidId;

AcDbEntity * pEnt;

AcDbEntity * pLinearEnt;

AcGePoint3dArray hitPoints;

int nHitsWanted;



ads_name en ;

ads_point pt ;



// User picks a line

  if ( acedEntSel (_T("\nSelect a line: "), en, pt) != RTNORM )

  return;

// Get pointer to line

if ( acdbGetObjectId (lineId, en) != Acad::eOk )

{

  return;

}

acdbOpenAcDbEntity(pLinearEnt, lineId, AcDb::kForRead );

if(pLinearEnt == NULL )

{

  acutPrintf(_T("\nCannot open line"));

  return;

}



// User picks a solid

  if ( acedEntSel (_T("\nSelect a solid: "), en, pt) != RTNORM )

  return;



// Get pointer to line

if ( acdbGetObjectId (solidId, en) != Acad::eOk )

{

  return;

}

acdbOpenAcDbEntity(pEnt, solidId, AcDb::kForRead );

if(pEnt == NULL )

{

  acutPrintf(_T("\nCannot open solid"));

  pLinearEnt->close();

  return;

}



// Get required number of intersections to be returned.

// If user enters zero, then we will return all intersections.

  if (RTNORM != acedGetInt(_T("\nEnter number of Hits required : "),

   &nHitsWanted))

{

  acutPrintf(_T("\nYou must enter an integer"));

   pEnt->close();

   pLinearEnt->close();

  return;

}



// Find number of intersections

if ( Acad::eOk != getHits( pLinearEnt, pEnt,

  nHitsWanted, hitPoints))

{

   pEnt->close();

   pLinearEnt->close();

  return;

}



// Entities not needed any more

pEnt->close();

pLinearEnt->close();



// Print out intersections

int len = hitPoints.length();

if ( len == 0 )

{

  acutPrintf(_T("\nNo intersections found."));

}

else

{

  acutPrintf(_T("\n%d intersections found."), len);



  for (int i = 0; i < len; i++)

  {

   AcGePoint3d pt = hitPoints[i];

      acutPrintf(_T("\nIntersection %d: (%f, %f, %f)"),

    i+1, pt[X], pt[Y], pt[Z]);

  }

}

return;

}





Acad::ErrorStatus getHits( AcDbEntity * pLinearEnt,

       AcDbEntity * pEnt,

       int nHitsWanted,

       AcGePoint3dArray &hitPoints)

// Parameters:

//  AcDbEntity * pLinearEnt - pointer to a line

//  AcDbEntity * pEnt - pointer to a solid

//  int nHitsWanted - number of intersections

//  to return (0 means return all)

//  AcGePoint3dArray hitPoints - array to

//  return intersection points

// Returns:

//  Acad::eOk - if all is well

//  Acad::eInvalidInput - if there is a problem

{

// Check that solid pointer is a really a solid

if( !(pEnt->isKindOf(AcDb3dSolid::desc()) ||

   pEnt->isKindOf(AcDbRegion::desc()) ||

   pEnt->isKindOf(AcDbBody::desc()) ) )

{

  acutPrintf(_T("\nSecond argument must be a solid, not a %s"),

   pEnt->isA()->name());

  return Acad::eInvalidInput;

}



// Check that the line pointer is a line.

// If it is, create a corresponding AcGe object.

AcGeLinearEnt3d * pGeLine;

if(pLinearEnt->isKindOf( AcDbLine::desc() )) {

  AcDbLine * pLine = (AcDbLine*)pLinearEnt;

  pGeLine = new AcGeLineSeg3d(pLine->startPoint(),

   pLine->endPoint() );

} else if (pLinearEnt->isKindOf( AcDbRay::desc() )) {

  AcDbRay * pRay = (AcDbRay*)pLinearEnt;

  pGeLine = new AcGeRay3d(pRay->basePoint(), pRay->unitDir() );

} else if (pLinearEnt->isKindOf( AcDbXline::desc() )) {

  AcDbXline * pXline = (AcDbXline *)pLinearEnt;

  pGeLine = new AcGeLine3d(pXline->basePoint(),

   pXline->unitDir() );

} else {

  acutPrintf(_T("\nFirst argument must be a line, not a %s"),

   pLinearEnt->isA()->name());

  return Acad::eInvalidInput;

}



// Find the number of intersections using B-Rep API

AcBrBrep*pBrep = new AcBrBrep;

AcDbObjectId solidId = pEnt->objectId();

pBrep->setSubentPath( AcDbFullSubentPath( solidId,

  AcDbSubentId()));



AcBrHit*pHits = NULL;

Adesk::UInt32 nHitsFound;

pBrep->getLineContainment(*pGeLine, nHitsWanted,

  nHitsFound, pHits );



// Append valid intersection points to hitPoints

for( Adesk::UInt32 i=0;i<nHitsFound; i++ ) {

  AcBrEntity*pHitEntity = NULL;

  pHits[i].getEntityHit( pHitEntity );



  if( pHitEntity == NULL )

   continue;



  AcGePoint3d hitPt;

  pHits[i].getPoint(hitPt);



  if( !pHitEntity->isKindOf(AcBrBrep::desc()) ) {

   hitPoints.append( hitPt );

  }

  else

  {  

   acutPrintf(

    _T("\nIgnoring the point at (%f, %f, %f) with a %s"),

    hitPt.x, hitPt.y, hitPt.z, pHitEntity->isA()->name());

  }

  delete pHitEntity;

}



// Convert points from WCS to UCS

int nPts = hitPoints.length();

for( int i=0; i<nPts;i++ ) {

  ads_point pt;

  asPnt3d(pt) = hitPoints[i];

  acdbWcs2Ucs(pt,pt,0);

  hitPoints[i] = asPnt3d(pt);

}



// Tidy up

delete [] pHits;

delete pBrep;

delete pGeLine;



// end of function - everything must have worked

return Acad::eOk;

}[/code]

 

 

 

 

How to Intersect a line with a solid?‎如何将直线与实线相交?‎

该用户从未签到

主题

0

回帖

0

积分

管理员

积分
0
发表于 2024-7-28 09:28:43 | 显示全部楼层
  法拉利膜材作为一种高性能的建筑材料,在建筑、汽车及广告等多个领域有着广泛的应用。以下是对法拉利膜材型号、特点及优点的详细分析:
[img]http://www.mjgou.com/data/attachment/forum/202403/13/223041uiqmeujen4jjj6zv.jpg[/img]
[b]一、法拉利膜材型号[/b]
法拉利膜材有多种型号,包括但不限于以下几种:1302 S2 Flexlight Advanced:这是一种高性能IV型柔性复合膜材,以其卓越的透光性、耐久性和易维护性而受到青睐。942、1202 S2、1002 S2、902 S2、1212 S2、912 S2:这些型号同样属于法拉利膜材系列,各自具有不同的特性和适用范围,但具体特点需根据具体型号进一步分析。需要注意的是,法拉利膜材的型号可能随着产品更新换代而有所变化,具体型号及其特性请参考最新产品资料。
[img=860,1255]http://www.mjgou.com/data/attachment/forum/202403/13/223254bbblwlbvbvsbwlsl.jpg[/img]
[b]二、法拉利膜材特点[/b]
法拉利膜材的特点主要体现在以下几个方面:
1、高强度与耐用性:法拉利膜材采用高强度材料制成,具有良好的抗拉强度和撕裂强度,能够承受较大的外力作用而不易破损。耐用性强,能够在恶劣气候条件下保持稳定的性能,延长使用寿命。
2、透光性与美观性:部分型号如1302 S2 Flexlight Advanced具有高透光性,能够在保持室内光线充足的同时,提供清晰的视野。膜材表面平整光滑,色彩丰富多样,能够满足不同建筑和装饰需求,提升整体美观性。
3、轻质与灵活性:法拉利膜材重量较轻,便于运输和安装,能够降低施工成本和时间。膜材具有一定的柔韧性,能够适应各种复杂形状和结构的设计要求。
4、环保与可回收性:法拉利膜材符合环保要求,部分材料可回收利用,减少了对环境的影响。
[img]http://www.mjgou.com/data/attachment/forum/202403/13/223128owhn0099rrds5h5y.jpg[/img]
[b]三、法拉利膜材优点[/b]
法拉利膜材的优点主要体现在以下几个方面:
1、提升建筑性能:高强度与耐用性使得法拉利膜材能够提升建筑的稳定性和安全性,延长使用寿命。透光性与美观性使得建筑内部光线充足、视野开阔,同时提升整体美观度。
2、降低施工成本:轻质特性使得运输和安装成本降低,施工效率提高。膜材的柔韧性使得施工更加灵活多变,能够适应各种复杂地形和结构要求。
3、节能环保:部分材料可回收利用,符合环保要求,减少了对环境的影响。良好的透光性能够减少室内照明需求,降低能耗。
4、广泛应用领域:
法拉利膜材不仅适用于建筑领域(如体育设施、商业设施、文化设施、交通设施等),还广泛应用于汽车及广告领域(如高档车辆贴膜保护和装饰、广告招贴等),展现出其多功能的特性。

综上所述,法拉利膜材以其高强度、耐用性、透光性、美观性、轻质灵活性以及环保可回收性等优点,在建筑、汽车及广告等多个领域发挥着重要作用。具体型号的选择应根据实际需求和应用场景进行综合考虑。
[url=http://www.mjgou.com/forum-17-1.html][size=88876][color=Red]法拉利膜材中国代理商 - 膜结构网[/color][/size][/url]
How to Intersect a line with a solid?‎如何将直线与实线相交?‎

该用户从未签到

主题

0

回帖

2

积分

新手上路

积分
2
发表于 2024-8-6 10:42:43 | 显示全部楼层
泰克斯膜材作为一种高性能的纺织材料,在建筑、户外用品等多个领域有着广泛的应用。以下是对泰克斯膜材的详细分析:
[b]一、公司背景与实力[/b]
成立与发展:泰克斯膜材品牌成立于1990年代初期,总部位于中国广东省佛山市。公司自成立以来,逐步发展成为国内外知名的纺织品品牌,产品远销世界各地,深受客户好评。
产品线:泰克斯膜材主要致力于研究、开发、生产和销售各种功能性纺织材料,包括帐篷、遮阳篷、雨衣、冲锋衣等户外用品以及家居纺织品。
技术创新:泰克斯膜材拥有一支专业的技术研发团队,不断创新和优化生产工艺,为客户提供高品质、高性能的产品。
[b]二、产品特点[/b]
高性能材料:泰克斯膜材选用优质的原料,如涤纶、氨纶等,确保产品的耐用性。同时,通过特殊工艺处理,膜材具备出色的物理和化学性能。
自洁能力:泰克斯膜材具有卓越的自洁能力,雨水冲刷即可保持膜材表面的清洁,减少维护成本。
防污性:膜材表面经过特殊处理,具有良好的防污性能,能够有效抵抗污渍的附着。
透光性与节能性:泰克斯膜材对自然光的透射率较高,同时具有良好的隔热性能,有助于节省能源。
温控性:膜材还能提供舒适的温控效果,适应不同气候条件下的使用需求。
[b]三、技术应用[/b]
泰克斯膜材在技术应用方面也具有显著优势。例如,部分产品采用了新型氟化物涂层(如PVDF)技术,这种技术通过超亲水性和氧化分解作用大幅提升有机物的分解能力,从而保持膜材表面的清洁和性能稳定。这种技术的引入不仅提高了膜材的自洁性和耐久性,还延长了产品的使用寿命。
[b]四、应用领域[/b]
泰克斯膜材广泛应用于建筑、户外用品、家居装饰等多个领域。在建筑领域,它可用作膜结构建筑的覆盖材料;在户外用品方面,它则是帐篷、遮阳篷等产品的理想选择;在家居装饰领域,泰克斯膜材以其独特的性能和美观的外观受到消费者的青睐。
[b]五、市场前景与发展趋势[/b]
随着科技的进步和人们对高品质生活的追求,泰克斯膜材的市场前景十分广阔。未来,泰克斯膜材将继续发挥其技术优势和产品优势,不断拓展新的应用领域和市场空间。同时,公司也将继续加大研发投入和技术创新力度,推出更多符合市场需求的高性能膜材产品。
综上所述,泰克斯膜材以其卓越的性能和广泛的应用领域在市场上占据重要地位。随着技术的不断进步和市场的不断发展,泰克斯膜材的应用前景将更加广阔。

 

 

 

 

How to Intersect a line with a solid?‎如何将直线与实线相交?‎
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|中国膜结构网|中国膜结构协会|进口膜材|国产膜材|ETFE|PVDF|PTFE|设计|施工|安装|车棚|看台|污水池|中国膜结构网_中国空间膜结构协会

GMT+8, 2024-11-1 13:36 , Processed in 0.146805 second(s), 29 queries .

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表