C++ Qt/VTK装配体组成联动连接杆

效果

在这里插入图片描述

关键代码

#include "View3D.h"
#include "Axis.h"#include <vtkActor.h>
#include <vtkAppendPolyData.h >
#include <vtkAreaPicker.h>
#include <vtkAxesActor.h>
#include <vtkBox.h>
#include <vtkCamera.h>
#include <vtkCaptionActor2D.h>
#include <vtkCellArray.h>
#include <vtkCleanPolyData.h >
#include <vtkContourFilter.h>
#include <vtkCubeSource.h>
#include <vtkCylinder.h>
#include <vtkCylinderSource.h>
#include <vtkDataSet.h>
#include <vtkGenericOpenGLRenderWindow.h>
#include <vtkImplicitBoolean.h>
#include <vtkInteractorStyleTrackballCamera.h>
#include <vtkLine.h>
#include <vtkMinimalStandardRandomSequence.h>
#include <vtkNamedColors.h>
#include <vtkObjectFactory.h>
#include <vtkOrientationMarkerWidget.h>
#include <vtkPlane.h>
#include <vtkPolyDataMapper.h>
#include <vtkPolyDataNormals.h>
#include <vtkPropPicker.h>
#include <vtkProperty.h>
#include <vtkRenderWindow.h>
#include <vtkRenderWindowInteractor.h>
#include <vtkRenderer.h>
#include <vtkRendererCollection.h>
#include <vtkReverseSense.h>
#include <vtkSTLReader.h>
#include <vtkSampleFunction.h>
#include <vtkSmartPointer.h>
#include <vtkSphere.h>
#include <vtkTransform.h>
#include <vtkTransformPolyDataFilter.h>// 主体为长方体,端部两个半圆,半圆的圆心是空洞
decltype(auto) View3D::buildBoard(double r, double g, double b)
{// 创建长方体vtkNew<vtkCubeSource> cube;// 长度1,宽度0.2,厚度0.05cube->SetXLength(1);cube->SetYLength(0.05);cube->SetZLength(0.2);cube->Update();// 创建半圆vtkNew<vtkCylinderSource> cy;// 半径0.1,高度0.05,圆心0.5,0,0cy->SetRadius(0.1);cy->SetHeight(0.05);cy->SetCenter(0.5, 0, 0);cy->SetResolution(100);cy->Update();// 创建独立的对称半圆vtkNew<vtkCylinderSource> cy1;// 半径0.1,高度0.05,圆心-0.5,0,0cy1->SetRadius(0.1);cy1->SetHeight(0.05);cy1->SetResolution(100);cy1->SetCenter(-0.5, 0, 0);cy1->Update();// 小圆柱vtkNew<vtkCylinderSource> cy2;cy2->SetRadius(0.05);cy2->SetHeight(0.06);cy2->SetResolution(100);cy2->SetCenter(0.5, 0, 0);cy2->Update();// 小圆柱vtkNew<vtkCylinderSource> cy3;cy3->SetRadius(0.05);cy3->SetHeight(0.06);cy3->SetResolution(100);cy3->SetCenter(-0.5, 0, 0);cy3->Update();// 创建长方体和半圆的合体vtkNew<vtkAssembly> assembly;// cube actorvtkNew<vtkPolyDataMapper> cudeMapper;cudeMapper->SetInputConnection(cube->GetOutputPort());vtkNew<vtkActor> cudeActor;cudeActor->SetMapper(cudeMapper);cudeActor->GetProperty()->SetColor(r, g, b);assembly->AddPart(cudeActor);vtkNew<vtkPolyDataMapper> cyMapper;cyMapper->SetInputConnection(cy->GetOutputPort());vtkNew<vtkActor> cyActor;cyActor->SetMapper(cyMapper);cyActor->GetProperty()->SetColor(r, g, b);assembly->AddPart(cyActor);vtkNew<vtkPolyDataMapper> cy1Mapper;cy1Mapper->SetInputConnection(cy1->GetOutputPort());vtkNew<vtkActor> cy1Actor;cy1Actor->SetMapper(cy1Mapper);cy1Actor->GetProperty()->SetColor(r, g, b);assembly->AddPart(cy1Actor);vtkNew<vtkPolyDataMapper> cy2Mapper;cy2Mapper->SetInputConnection(cy2->GetOutputPort());vtkNew<vtkActor> cy2Actor;cy2Actor->SetMapper(cy2Mapper);cy2Actor->GetProperty()->SetColor(0.8, 0, 0);assembly->AddPart(cy2Actor);vtkNew<vtkPolyDataMapper> cy3Mapper;cy3Mapper->SetInputConnection(cy3->GetOutputPort());vtkNew<vtkActor> cy3Actor;cy3Actor->SetMapper(cy3Mapper);cy3Actor->GetProperty()->SetColor(0.8, 0, 0);assembly->AddPart(cy3Actor);return assembly;
}decltype(auto) View3D::buildConnectRod()
{// 淡绿色auto actor1 = buildBoard(0.5, 1, 0.5);// 淡黄色auto actor2 = buildBoard(1, 1, 0.5);// 淡蓝色auto actor3 = buildBoard(0.5, 1, 1);// 平移actoractor1->AddPosition(0.5, 0, 0);actor2->AddPosition(1.5, 0.05, 0);actor3->AddPosition(2.5, 0.1, 0);vtkNew<vtkAssembly> assembly1, assembly2, assembly3;assembly1->AddPart(actor1);assembly1->AddPart(assembly2);assembly2->AddPart(actor2);assembly2->AddPart(assembly3);assembly3->AddPart(actor3);assembly2->SetOrigin(1, 0.05, 0);assembly3->SetOrigin(2, 0, 0);return std::make_tuple(vtkSmartPointer<vtkAssembly>(assembly1),vtkSmartPointer<vtkAssembly>(assembly2),vtkSmartPointer<vtkAssembly>(assembly3));
}View3D::View3D(QWidget* parent): QVTKOpenGLNativeWidget(parent)
{vtkNew<vtkRenderer> renderer;this->renderWindow()->AddRenderer(renderer);renderer->AddActor(baseAxes = getBaseAxes());addGuideLine(3, 0.2);connectRods = buildConnectRod();auto&& [actor1, actor2, actor3] = connectRods;renderer->AddActor(actor1);// 水平旋转renderer->GetActiveCamera()->Azimuth(90);renderer->GetActiveCamera()->SetRoll(-90);renderer->GetActiveCamera()->Azimuth(45);renderer->GetActiveCamera()->Elevation(15);renderer->GetActiveCamera()->SetPosition(3, 3, 1);vtkSmartPointer<vtkOrientationMarkerWidget> widget = vtkSmartPointer<vtkOrientationMarkerWidget>::New();;this->borderWidget = widget;vtkSmartPointer<vtkAxesActor> widgetAxesActor = vtkSmartPointer<vtkAxesActor>::New();widgetAxesActor->SetPosition(0, 0, 0);widgetAxesActor->SetShaftType(0);widgetAxesActor->SetCylinderRadius(0.02);// 设置大小widgetAxesActor->SetTotalLength(2, 2, 2);widget->SetOrientationMarker(widgetAxesActor);widget->SetInteractor(this->interactor());widget->SetEnabled(1);widget->InteractiveOn();// 连接信号槽connect(this, &View3D::rotateBased, this, &View3D::rotateBaseSlot);connect(this, &View3D::rotateBigArmed, this, &View3D::rotateBigArmSlot);connect(this, &View3D::rotateMiddleArmed, this, &View3D::rotateMiddleArmSlot);connect(this, &View3D::rotateSmallArmed, this, &View3D::rotateSmallArmSlot);
}void View3D::addAxis(const Axis& axis)
{vtkNew<vtkTransform> transform;transform->Translate(axis.xyz.x(), axis.xyz.y(), axis.xyz.z());vtkAxesActor* axes = vtkAxesActor::New();transform->RotateX(axis.xyzR.x());transform->RotateY(axis.xyzR.y());transform->RotateZ(axis.xyzR.z());axes->SetUserTransform(transform);// 设置大小axes->SetTotalLength(axis.xyzL.x(), axis.xyzL.y(), axis.xyzL.z());// 设置箭头大小axes->SetConeRadius(axis.xyzL[0] * 0.1);axes->SetCylinderRadius(axis.xyzL[0] * 0.1);axes->SetConeResolution(100);axes->SetCylinderResolution(100);axes->SetXAxisLabelText(axis.labels[0].toStdString().c_str());axes->SetYAxisLabelText(axis.labels[1].toStdString().c_str());axes->SetZAxisLabelText(axis.labels[2].toStdString().c_str());auto xLabelProperty = axes->GetXAxisCaptionActor2D();// 缩小xLabelProperty->SetWidth(axis.xyzL.x() * 0.1);auto yLabelProperty = axes->GetYAxisCaptionActor2D();yLabelProperty->SetWidth(axis.xyzL.y() * 0.1);auto zLabelProperty = axes->GetZAxisCaptionActor2D();zLabelProperty->SetWidth(axis.xyzL.z() * 0.1);// 添加到第一个renderthis->renderWindow()->GetRenderers()->GetFirstRenderer()->AddActor(axes);this->renderWindow()->Render();
}void View3D::rotateBaseSlot(double angle)
{auto&& [a, b, c] = connectRods;// a世界坐标系旋转角归零a->SetOrientation(0, 0, 0);// a 绕世界坐标系旋转到anglea->RotateWXYZ(angle, 0, 0, 1);refresh();
}void View3D::rotateBigArmSlot(double angle)
{auto&& [a, b, c] = connectRods;a->RotateY(angle - a->GetOrientation()[1]);refresh();
}void View3D::rotateMiddleArmSlot(double angle)
{auto&& [a, b, c] = connectRods;b->RotateY(angle - b->GetOrientation()[1]);refresh();
}void View3D::rotateSmallArmSlot(double angle)
{auto&& [a, b, c] = connectRods;c->RotateY(angle - c->GetOrientation()[1]);refresh();
}void View3D::addGuideLine(float r, float space)
{// 创建网格线,间距space,范围-r~rvtkNew<vtkCellArray> lines;vtkNew<vtkPoints> points;for (size_t i = 0; i <= static_cast<unsigned long long>(r / space) * 2; i++) {points->InsertNextPoint(-r, r - space * i, 0);points->InsertNextPoint(r, r - space * i, 0);points->InsertNextPoint(-r + space * i, r, 0);points->InsertNextPoint(-r + space * i, -r, 0);}for (size_t i = 0; i <= static_cast<unsigned long long>(r / space) * 4 + 1; i++) {vtkNew<vtkLine> line;line->GetPointIds()->SetId(0, i * 2);line->GetPointIds()->SetId(1, i * 2 + 1);lines->InsertNextCell(line);}vtkNew<vtkPolyData> linesPolyData;linesPolyData->SetPoints(points);linesPolyData->SetLines(lines);vtkNew<vtkPolyDataMapper> mapper;mapper->SetInputData(linesPolyData);vtkNew<vtkActor> actor;actor->SetMapper(mapper);// 设置透明度actor->GetProperty()->SetOpacity(0.5);this->renderWindow()->GetRenderers()->GetFirstRenderer()->AddActor(actor);this->renderWindow()->Render();
}vtkNew<vtkAxesActor> View3D::getBaseAxes()
{vtkNew<vtkAxesActor> axes;axes->SetTotalLength(1.0, 1.0, 1.0);axes->SetPosition(0, 0, 0);axes->SetShaftType(0);axes->SetConeResolution(100);axes->SetCylinderResolution(100);axes->SetConeRadius(0.1);axes->SetCylinderRadius(0.01);return axes;
}void View3D::refresh()
{this->renderWindow()->Render();
}

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

开源3D激光(视觉)SLAM算法汇总(持续更新)

原文连接 目录 一、Cartographer 二、hdl_graph_slam 三、LOAM 四、LeGO-LOAM 五、LIO-SAM 六、S-LOAM 七、M-LOAM 八、livox-loam 九、Livox-Mapping 十、LIO-Livox 十一、FAST-LIO2 十二、LVI-SAM 十三、FAST-Livo 十四、R3LIVE 十五、ImMesh 十六、Point-LIO 一、Cartograph…

辅助驾驶功能开发-功能规范篇(22)-3-L2级辅助驾驶方案功能规范

1.3.3 TLA系统功能定义 1.3.3.1 状态机 1.3.3.2 状态迁移图 1.3.3.3 功能定义 1.3.3.3.1 信号需求列表 1.3.3.3.2 系统开启关闭 1)初始化 车辆上电后,交通灯辅助系统(TLA)进行初始化,控制器需在 220ms 内发出第一帧报文,并在 3s 内完成内部自检,同时上电 3s 内不进行…

VR数字党建:红色文化展厅和爱国主义教育线上线下联动

伴随着党建思想的加深&#xff0c;很多政府单位都有打造VR党建展厅的想法&#xff0c;而党建基地也是激发爱国热情、凝聚人民力量、培养民族精神的重要场所。现如今&#xff0c;伴随着5G、VR等技术的成熟&#xff0c;VR数字党建积极推动运用VR技术&#xff0c;推动红色文化展厅…

PyTorch中grid_sample的使用方法

官方文档首先Pytorch中grid_sample函数的接口声明如下&#xff1a; torch.nn.functional.grid_sample(input, grid, modebilinear, padding_modezeros, align_cornersNone)input : 输入tensor&#xff0c; shape为 [N, C, H_in, W_in]grid: 一个field flow&#xff0c; shape为…

美颜SDK集成指南:为应用添加视频美颜功能

随着社交媒体和直播应用的兴起&#xff0c;视频美颜功能已成为用户追求的一项热门特性。用户希望能够在拍摄照片或进行实时视频直播时&#xff0c;使用美颜功能来增强其外观。为了满足这一需求&#xff0c;开发者可以考虑集成美颜SDK&#xff0c;为其应用增加这一吸引人的功能。…

Qt实现卡牌对对碰游戏

效果 闲来无事&#xff0c;实现一个对对碰游戏&#xff0c;卡牌样式是火影动漫。 先上效果&#xff1a; 卡牌对对碰_火影主题 玩法 启动游戏&#xff0c;进入第一关卡&#xff0c;所有卡牌都为未翻开状态&#xff0c;即背面朝上&#xff1b;点击卡牌&#xff0c;则将卡牌翻开…

常用排序算法

目录 直接插入排序 希尔排序 ​编辑 选择排序 堆排序 冒泡排序 快速排序 hoare版 挖坑法 前后指针法 非递归 归并排序 非递归 计数排序 直接插入排序 直接插入排序跟依次模扑克牌一样&#xff0c;将最后一张牌依次与前面的牌比较&#xff0c;最后将牌插入到指定位…

Python深度学习实战-基于tensorflow原生代码搭建BP神经网络实现分类任务(附源码和实现效果)

实现功能 前面两篇文章分别介绍了两种搭建神经网络模型的方法&#xff0c;一种是基于tensorflow的keras框架&#xff0c;另一种是继承父类自定义class类&#xff0c;本篇文章将编写原生代码搭建BP神经网络。 实现代码 import tensorflow as tf from sklearn.datasets import…

【数据库】

文章目录 1. 聚合函数练习&#xff1a; 2. 子查询 1. 聚合函数 where中过滤条件中不能写聚合函数&#xff0c;有聚合函数需要写到Having中 方式一效率高&#xff1a; Select执行流程 练习&#xff1a; 2. 第七题&#xff1a;count(*)有问题&#xff0c;原因是左外连接后…

【继承练习题--多态-- 动态绑定-- 重写】

文章目录 继承的练习题&#xff1a;多态多态实现条件 动态绑定什么是重写Override 注解重写的条件&#xff08;缺一不可&#xff09;有一种特殊的重写&#xff1a;叫协变类型重写的设计原则快捷键生成重写重写和重载的区别object类是所有类的父类 总结 继承的练习题&#xff1a…

支付宝证书到期更新完整过程

如果用户收到 支付宝公钥证书 到期通知后&#xff0c;可以根据如下指引更新证书 确认上传成功后就会生成新的证书&#xff0c;把新的证书替换到生产环境就可以了

标准ACL,扩展ACL,基本ACL,高级ACL

其实标准ACL&#xff0c;扩展ACL&#xff0c;基本ACL&#xff0c;高级ACL是同一个概念的不同名称&#xff0c;区别在于: 思科路由器支持标准ACL和扩展ACL两种类型的访问控制列表&#xff0c;没有”基本ACL“和”高级ACL“的概念&#xff0c;而华为路由器都支持 编号范围&…

基于鸟群算法的无人机航迹规划-附代码

基于鸟群算法的无人机航迹规划 文章目录 基于鸟群算法的无人机航迹规划1.鸟群搜索算法2.无人机飞行环境建模3.无人机航迹规划建模4.实验结果4.1地图创建4.2 航迹规划 5.参考文献6.Matlab代码 摘要&#xff1a;本文主要介绍利用鸟群算法来优化无人机航迹规划。 1.鸟群搜索算法 …

[java/力扣110]平衡二叉树——优化前后的两种方法

分析 根据平衡二叉树的定义&#xff0c;只需要满足&#xff1a;1、根节点两个子树的高度差不超过1&#xff1b;2、左右子树都为平衡二叉树 代码 public class BalancedBinaryTree {public class TreeNode{int val;TreeNode left;TreeNode right;TreeNode(){}TreeNode(int va…

springboot第44集:Kafka集群和Lua脚本

servers&#xff1a;Kafka服务器的地址。这是Kafka集群的地址&#xff0c;生产者将使用它来发送消息。retries&#xff1a;在消息发送失败时&#xff0c;生产者将尝试重新发送消息的次数。这个属性指定了重试次数。batchSize&#xff1a;指定了生产者在发送消息之前累积的消息大…

2.flink编码第一步(maven工程创建)

概述 万里第一步&#xff0c;要进行flink代码开发&#xff0c;第一步先整个 flink 代码工程 flink相关文章链接 flink官方文档 两种方式 一种命令行 mvn 创建&#xff0c;另一种直接在 idea 中创建一个工程&#xff0c;使用 mvn 的一些配置 mvn命令行创建 mvn 创建flink工程&…

基于SpringBoot的工厂车间管理系统设计与实现

目录 前言 一、技术栈 二、系统功能介绍 管理员功能实现 人员管理 看板信息管理 设备信息管理 生产开立管理 人员功能实现 生产开立管理 生产工序管理 生产流程管理 三、核心代码 1、登录模块 2、文件上传模块 3、代码封装 前言 社会发展日新月异&#xff0c;用计…

6.scala辅助构造器与为构造函数提供默认值(一)

概述 本文主要说明: 辅助构造器 与 为构造函数提供默认值 的使用 辅助构造器为构造函数提供默认值 相关链接 阅读之前&#xff0c;可以浏览一下 scala相关文章 辅助构造器 可以通过定义名为this的方法来定义辅助Scala类构造函数。只有几个规则需要了解&#xff1a; 每个辅助…

冯诺依曼体系结构、进程、环境变量

冯诺依曼体系结构、进程、环境变量 一、冯诺依曼体系结构1、结构图2、示例3、CPU与数据 二、进程1、概念2、查看进程&#xff08;1&#xff09;通过/proc系统文件夹&#xff08;2&#xff09;通过top和ps用户级工具&#xff08;3&#xff09;通过系统调用 3、通过系统调用创建进…

会声会影2024这款视频剪辑软件怎么样?

众所周知&#xff0c;每每有新兴行业逐渐崛起壮大的时候&#xff0c;随机而来的就是这个行业创造出的衍生行业&#xff0c;比如说现在的短视频平台或者是视频剪辑行业&#xff0c;都是很明显的例子&#xff0c;今天我们就针对剪辑软件来和大家聊一聊&#xff0c;会声会影2024这…