NXopen C++ 装配体部件遍历 体积质量计算 NewMassProperties

news2025/1/11 17:06:53

打开装配体,逐一遍历部件测量体积,最后计算出装配体的总的体积和质量 NX1953+VS2019

//1、模板文件添加头文件*
#include <NXOpen/UnitCollection.hxx>
#include <NXOpen/ScCollectorCollection.hxx>
#include <NXOpen/Unit.hxx>
#include <NXOpen/BodyDumbRule.hxx>
#include <NXOpen/MeasureBodies.hxx>
#include <NXOpen/ScCollectorCollection.hxx>
#include <NXOpen/ScRuleFactory.hxx>
//**2、主程序**
    NXOpen::Session* theSession = NXOpen::Session::GetSession();
	theSession->ListingWindow()->Open();
	NXOpen::BasePart* basePart1;
	NXOpen::PartLoadStatus* partLoadStatus1;
	basePart1 = theSession->Parts()->OpenActiveDisplay("D:\\CSDN\\CreatFile\\_asm1.prt", NXOpen::DisplayPartOptionAllowAdditional, &partLoadStatus1);//打开装配体模型

	NXOpen::Part* AssemPart(theSession->Parts()->Work());
	NXOpen::Part* displayPart(theSession->Parts()->Display());
	delete partLoadStatus1;
	theSession->ApplicationSwitchImmediate("UG_APP_MODELING");

	Assemblies::ComponentAssembly* compAssy = AssemPart->ComponentAssembly();
	Assemblies::Component* rootcomponent = compAssy->RootComponent();//获取根部件

	std::vector< NXOpen::Assemblies::Component* > childcomponents;
	childcomponents = rootcomponent->GetChildren();//获取子部件
	char msg[256];

	double TotalMass = 0.0;
	double TotalVolume = 0.0;

	for (int i = 0; i < childcomponents.size(); i++)
	{
		NXOpen::Assemblies::Component* componenti = childcomponents[i];
		if (componenti->IsOccurrence() == 1)//判断是否为事例
		{
			NXOpen::INXObject* Parti = componenti->Prototype();//通过事例获取相应零件几何模型part
			NXOpen::Part* part1(dynamic_cast<NXOpen::Part*>(Parti));

			NXOpen::PartLoadStatus* partLoadStatus2;
			partLoadStatus2 = part1->LoadThisPartFully();//将几何模型载入,相当于变换到零件模型并设置其为工作部件
			//必须载入,否则装配环境下无法测量机和实体
			NXOpen::BodyCollection* bodys = part1->Bodies();//遍历零件part中几何实体
			std::vector<NXOpen::Body*> BodyVecotor;
			for (NXOpen::BodyCollection::iterator itebody = bodys->begin(); itebody != bodys->end(); itebody++)
			{
				Body* bodyi = (*itebody);
				BodyVecotor.push_back(bodyi);

			}

			std::vector<Unit*> massUnits1(5);//定义质量属性的测量单位
			Unit* unit1(dynamic_cast<Unit*>(part1->UnitCollection()->FindObject("SquareMilliMeter")));
			massUnits1[0] = unit1;
			Unit* unit2(dynamic_cast<Unit*>(part1->UnitCollection()->FindObject("CubicMilliMeter")));
			massUnits1[1] = unit2;
			Unit* unit3(dynamic_cast<Unit*>(part1->UnitCollection()->FindObject("Kilogram")));
			massUnits1[2] = unit3;
			Unit* unit4(dynamic_cast<Unit*>(part1->UnitCollection()->FindObject("MilliMeter")));
			massUnits1[3] = unit4;
			Unit* unit5(dynamic_cast<Unit*>(part1->UnitCollection()->FindObject("Newton")));
			massUnits1[4] = unit5;

			NXOpen::ScCollector* scCollector1;//定义测量体收集器,存放测量体
			scCollector1 = part1->ScCollectors()->CreateCollector();
			std::vector<NXOpen::Body*> bodies1(1);
			bodies1[0] = BodyVecotor[0];
			NXOpen::BodyDumbRule* bodyDumbRule1;
			bodyDumbRule1 = part1->ScRuleFactory()->CreateRuleBodyDumb(bodies1);

			std::vector<NXOpen::SelectionIntentRule*> rules1(1);
			rules1[0] = bodyDumbRule1;
			scCollector1->ReplaceRules(rules1, false);

			NXOpen::MeasureBodies* MeasureBodies1;
			MeasureBodies1 = part1->MeasureManager()->NewMassProperties(massUnits1, 0.99, scCollector1);
			
			double BlockVolume = MeasureBodies1->Volume();//获取体积
			double BlockMass = MeasureBodies1->Mass();//获取质量
			TotalVolume = TotalVolume + BlockVolume;
			TotalMass = TotalMass + BlockMass;
		}
	}
	sprintf(msg, "装配体总的体积:%f", TotalVolume);
	theSession->ListingWindow()->WriteLine(msg);
	sprintf(msg, "装配体总的质量:%f", TotalMass);
	theSession->ListingWindow()->WriteLine(msg);

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1596316.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

github 双因素验证

环境 华为手机 下载app 华为应用市场下载 输入对应验证码&#xff0c;然后一路下一步即可 联系方式 手机&#xff1a;13822161573 微信&#xff1a;txsolarterms QQ&#xff1a;419396409

实验一:配置IP地址

实验环境 主机A和主机B通过一根网线相连 需求描述 为两台主机配置IP地址&#xff0c;验证IP地址是否生效&#xff0c;验证同一网段的两台主机可以互通&#xff0c;不同网段的主机不能直接互通 一.实验拓扑 二.推荐步骤 1.为两台主机配置P地址&#xff0c;主机A为192.168.1.…

多无人机集群协同避障

matlab2020a正常运行 场景1规划结果 场景2规划结果 场景3规划结果 代码地址&#xff1a; 多无人机集群协同避障效果&#xff08;5架&#xff09;资源-CSDN文库

解决Ant Design Vue使用Modal对话框无法关闭的问题,本地可以关闭对话框但是打包后不能关闭对话框的问题。

首先说为什么会导致这个问题&#xff1a;因为现在vue官方的最新版本是3.4.x&#xff0c;可能是vue最新版本的部分代码与Ant Design不兼容导致的。 解决&#xff1a;所以将vue版本固定在vue3.4以下&#xff0c;就可以了。 1.删除node_modules和package-lock.json&#xff08;如…

8.基础乐理-纯八度

一个音听上去是高还是低&#xff0c;是由音的振动频率决定的&#xff0c;也就是每一秒多少 Hz 所决定的&#xff0c;Hz数越小音听上去就越低&#xff0c;Hz数越大音听上去就越大&#xff0c;钢琴从左到右&#xff0c;Hz数 在逐渐增大&#xff0c;当两个音的振动频率数越接近简单…

VSCode插件分享--免费的ER工具

首先在VSCode里面下载插件 再将插件导入后&#xff0c;添加文本修改后缀名&#xff08;将后缀名修改为.drawio&#xff09;就可以使用了

【CLR】《Cyclical Learning Rates for Training Neural Networks》

WACV-2017 IEEE Winter Conference on Applications of Computer Vision 文章目录 1 Background and Motivation2 Related Work3 Advantages / Contributions4 Method5 Experiments5.1 Datasets and Metrics5.2 CIFAR-10 and CIFAR-1005.3 ImageNet 6 Conclusion&#xff08;o…

Python机器学习实战教程

一、引言 机器学习是人工智能的一个子集&#xff0c;它使用算法来让计算机系统从数据中“学习”并改进其性能&#xff0c;而无需进行明确的编程。Python因其易于学习、强大的库和广泛的应用场景&#xff0c;成为了机器学习的首选语言。本教程旨在帮助读者从零开始学习Python机…

(六)C++自制植物大战僵尸游戏关卡数据讲解

植物大战僵尸游戏开发教程专栏地址http://t.csdnimg.cn/xjvbb 游戏关卡数据文件定义了游戏中每一个关卡的数据&#xff0c;包括游戏类型、关卡通关奖励的金币数量、僵尸出现的波数、每一波出现僵尸数量、每一波僵尸出现的类型等。根据不同的游戏类型&#xff0c;定义了不同的通…

顶顶通呼叫中心中间件-回铃音补偿(mod_cti基于FreeSWITCH)

顶顶通呼叫中心中间件-回铃音补偿(mod_cti基于FreeSWITCH) 回铃音的用处 回铃音&#xff1a; 当别人打电话给你时&#xff0c;你的电话响铃了&#xff0c;而他听到的声音叫做回铃音。回铃音是被叫方向主叫方传送&#xff0c;也是彩铃功能的基础。我们平时打电话听到的“嘟 嘟…

掌握CRM+邮箱技巧:销售速度与客户信任双丰收

在千行百业都在谈提效的今天&#xff0c;如果您的销售团队效率较低&#xff0c;恐怕很难过好2024。销售团队提效是个大话题&#xff0c;总的说来就是销售团队需要在正确的时间做正确的事。如何做到&#xff1f;自然要借助CRM工具。过去我们也讲了不少CRM如何辅助销售团队提效的…

外贸高手写的开发信为什么回复率很高

关于开发信这个主题&#xff0c;其实已经算是个烂大街的话题。但是在效仿、参考、摸索开发信这一课题的路上&#xff0c;很多小白还是没摸准要旨&#xff0c;走了不少弯路。这也是为什么小编老话题重提的原因。以下整理了外贸高手写开发信用到的技巧和规律&#xff0c;希望能给…

华为配置通过流策略实现流量统计

配置通过流策略实现流量统计示例 组网图形 图1 配置流策略实现流量统计组网图 设备 接口 接口所属VLAN 对应的三层接口 IP地址 SwitchA GigabitEthernet1/0/1 VLAN 10 - - GigabitEthernet1/0/2 VLAN 20 - - GigabitEthernet1/0/3 VLAN 10、VLAN 20 - - S…

公众号文章的制作方法和步骤分享,纯干货!

无论是个人还是企业&#xff0c;都需要通过公众号来传递自己的声音和价值。如何制作一篇高质量的公众号文章呢&#xff1f;本文伯乐网络传媒将详细介绍公众号文章的制作方法和步骤。 一、文章类型概述 1. 图文教程&#xff1a;以图文结合的方式&#xff0c;向读者传授知识和技…

网络协议——BGP(边界网关协议)全网最详解

1. 什么是AS&#xff1f; AS: 指的是在同一个组织管理下&#xff0c;使用统一选路策略的设备集合&#xff0c;AS取值范围四字节&#xff08; 0~43亿&#xff09; 2. BGP概念 BGP是边界网关协议&#xff0c;用于自治系统间的动态协议路径矢量。基于TCP中应用层协议&#xff0c…

Stable Diffusion超详细教程!从0-1入门到进阶

一、本地部署 Stable Diffusion 前言 目前市面上比较权威&#xff0c;并能用于工作中的AI绘画软件其实就两款。一个叫Midjourney&#xff08;简称MJ&#xff09;&#xff0c;另一个叫Stable-Diffusion&#xff08;简称SD&#xff09;。MJ需要付费使用&#xff0c;而SD开源免费…

内网渗透-Windows内网渗透

内网渗透-Windows内网渗透 文章目录 内网渗透-Windows内网渗透前言一、信息收集 1.1、SPN1.2、端口连接1.3、配置文件1.4、用户信息1.6、会话收集1.7、凭据收集 navicat&#xff1a;SecureCRT&#xff1a;Xshell&#xff1a;WinSCP&#xff1a;VNC: 1.8、DPAPI1.9、域信任1.10、…

现代数据中心中智能网卡/DPU的演进

数据中心是一个大型的连接服务器和存储系统池&#xff0c;通常由组织用于远程存储、处理或分发大量数据。组织可以拥有和管理其数据中心&#xff0c;也可以租用由第三方&#xff08;亚马逊或谷歌云等云服务提供商&#xff09;管理的基础设施&#xff0c;并通过互联网访问资源。…

【SpringBoot】配置swagger

pom.xml 安装插件 <dependency><groupId>io.springfox</groupId><artifactId>springfox-boot-starter</artifactId><version>3.0.0</version></dependency>创建swagger配置类 import org.springframework.context.annotation.…