提供3000多款全球软件/控件产品
针对软件研发的各个阶段提供专业培训与技术咨询
根据客户需求提供定制化的软件开发服务
全球知名设计软件,显著提升设计质量
打造以经营为中心,实现生产过程透明化管理
帮助企业合理产能分配,提高资源利用率
快速打造数字化生产线,实现全流程追溯
生产过程精准追溯,满足企业合规要求
以六西格玛为理论基础,实现产品质量全数字化管理
通过大屏电子看板,实现车间透明化管理
对设备进行全生命周期管理,提高设备综合利用率
实现设备数据的实时采集与监控
利用数字化技术提升油气勘探的效率和成功率
钻井计划优化、实时监控和风险评估
提供业务洞察与决策支持实现数据驱动决策
转帖|使用教程|编辑:鲍佳佳|2021-07-27 10:00:03.177|阅读 588 次
概述:本文演示了如何在 Qt 3D 中渲染场景的 C++ 应用程序。
# 慧都年终大促·界面/图表报表/文档/IDE等千款热门软控件火热促销中 >>
Qt组件推荐
演示如何在 Qt 3D 中渲染场景的 C++ 应用程序。
Simple演示了如何在 Qt 3D 中渲染场景。
要从Qt Creator运行示例,请打开欢迎模式并从示例中选择示例。有关更多信息,请访问构建和运行示例。
我们在main.cpp文件中设置场景。
为了能够使用 Q3D Core、Q3D Render、Qt 3D Input 和 Qt 3D Extras 模块中的类和函数,我们必须包含这些类:
#include <Qt3DCore/QEntity> #include <Qt3DRender/QCamera> #include <Qt3DRender/QCameraLens> #include <Qt3DCore/QTransform> #include <Qt3DCore/QAspectEngine> #include <Qt3DInput/QInputAspect> #include <Qt3DRender/QRenderAspect> #include <Qt3DExtras/QForwardRenderer> #include <Qt3DExtras/QPhongMaterial> #include <Qt3DExtras/QCylinderMesh> #include <Qt3DExtras/QSphereMesh> #include <Qt3DExtras/QTorusMesh>
首先,我们设置场景并指定其根实体:
Qt3DCore :: QEntity * createScene() { Qt3DCore :: QEntity * rootEntity = new Qt3DCore :: QEntity ;
我们指定用于 Phong 渲染的材质:
Qt3DRender :: QMaterial * material = new Qt3DExtras :: QPhongMaterial (rootEntity);
根实体只是一个空壳,其行为由它引用的组件定义。我们指定圆环实体及其网格、变换和材质组件:
Qt3DCore :: QEntity * torusEntity = new Qt3DCore :: QEntity (rootEntity); Qt3DExtras :: QTorusMesh * torusMesh = new Qt3DExtras :: QTorusMesh ; torusMesh - > setRadius( 5 ); torusMesh - > setMinorRadius( 1 ); torusMesh - > setRings( 100 ); torusMesh - > setSlices( 20 ); Qt3DCore :: QTransform * torusTransform = new Qt3DCore :: QTransform ; torusTransform - > setScale3D(QVector3D( 1.5 , 1 , 0.5 )); torusTransform - > setRotation( QQuaternion :: fromAxisAndAngle(QVector3D( 1 , 0 , 0 ) , 45.0f )); torusEntity - > addComponent(torusMesh); torusEntity - > addComponent(torusTransform); torusEntity - > addComponent(material);
我们还指定了一个球体实体及其组件:
Qt3DCore::QEntity *sphereEntity = new Qt3DCore::QEntity(rootEntity); Qt3DExtras::QSphereMesh *sphereMesh = new Qt3DExtras::QSphereMesh; sphereMesh->setRadius(3); sphereMesh->setGenerateTangents(true); Qt3DCore::QTransform *sphereTransform = new Qt3DCore::QTransform; OrbitTransformController *controller = new OrbitTransformController(sphereTransform); controller->setTarget(sphereTransform); controller->setRadius(20.0f); QPropertyAnimation *sphereRotateTransformAnimation = new QPropertyAnimation(sphereTransform); sphereRotateTransformAnimation->setTargetObject(controller); sphereRotateTransformAnimation->setPropertyName("angle"); sphereRotateTransformAnimation->setStartValue(QVariant::fromValue(0)); sphereRotateTransformAnimation->setEndValue(QVariant::fromValue(360)); sphereRotateTransformAnimation->setDuration(10000); sphereRotateTransformAnimation->setLoopCount(-1); sphereRotateTransformAnimation->start(); sphereEntity->addComponent(sphereMesh); sphereEntity->addComponent(sphereTransform); sphereEntity->addComponent(material);
我们使用属性动画来为球体变换设置动画。
最后,我们初始化一个使用 Qt 3D 窗口的 Qt GUI 应用程序:
int main(int argc, char* argv[]) { QGuiApplication app(argc, argv); Qt3DExtras::Qt3DWindow view; Qt3DCore::QEntity *scene = createScene(); // Camera Qt3DRender::QCamera *camera = view.camera(); camera->lens()->setPerspectiveProjection(45.0f, 16.0f/9.0f, 0.1f, 1000.0f); camera->setPosition(QVector3D(0, 0, 40.0f)); camera->setViewCenter(QVector3D(0, 0, 0)); // For camera controls Qt3DExtras::QOrbitCameraController *camController = new Qt3DExtras::QOrbitCameraController(scene); camController->setLinearSpeed( 50.0f ); camController->setLookSpeed( 180.0f ); camController->setCamera(camera); view.setRootEntity(scene); view.show(); return app.exec(); }
================================================== ==
想要了解或购买Qt正版授权的朋友,欢迎
Qt技术交流交流群开通,QQ搜索群号“765444821”或者扫描二维码加入
本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@pclwef.cn
文章转载自:本文探讨 SQL Server 中 NULL 和空值之间的区别,并讨论如何有效地处理它们。
Unity 是一款功能极其丰富的游戏引擎,允许开发人员将各种媒体集成到他们的项目中。但是,它缺少最令人兴奋的功能之一 - 将 Web 内容(例如 HTML、CSS 和 JavaScript)直接渲染到 3D 场景中的纹理上的能力。在本文中,我们将介绍如何使用 DotNetBrowser 在 Unity3D 中将 Web 内容渲染为纹理。
DevExpress v24.2帮助文档正式发布上线了,请按版本按需下载~
本教程将向您展示如何用MyEclipse构建一个Web项目,欢迎下载最新版IDE体验!
服务电话
重庆/ 023-68661681
华东/ 13452821722
华南/ 18100878085
华北/ 17347785263
客户支持
技术支持咨询服务
服务热线:400-700-1020
邮箱:sales@pclwef.cn
关注我们
地址 : 重庆市九龙坡区火炬大道69号6幢