【UG\NX二次开发】获取体上所有面的总面积

/*获取选择的面的面积*/
double GetFaceArea(tag_t t_Face)
{
	Session* theSession = Session::GetSession();
	Part* workPart(theSession->Parts()->Work());
	Part* displayPart(theSession->Parts()->Display());
	Face* face = dynamic_cast<Face*>(NXObjectManager::Get(t_Face));

	NXOpen::MeasureFaces* measureFaces1;
	std::vector<NXOpen::IParameterizedSurface*> faceArea(1, face);

	NXOpen::UnitCollection* uniCol = workPart->UnitCollection();
	NXOpen::Unit* unit1 = *uniCol->end();
	measureFaces1 = workPart->MeasureManager()->NewFaceProperties(unit1, unit1, 0.2, faceArea);
	double dis = measureFaces1->Area();
	return dis;
}

/*获取体上所有面的总面积*/
double GetBodyAllFaceArea(tag_t bodyTag)
{
	uf_list_p_t face_list;
	UF_MODL_ask_body_faces(bodyTag, &face_list);
	int face_count = 0;
	UF_MODL_ask_list_count(face_list, &face_count);
	double all_Area = 0.0;
	for (int i = 0; i < face_count; ++i)
	{
		tag_t tmpface;
		UF_MODL_ask_list_item(face_list, i, &tmpface);
		all_Area += GetFaceArea(tmpface);
	}
	return all_Area;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

社恐猫

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值