当前位置: 首页 > news >正文

甘肃省住房与建设厅网站杭州网站建设推荐q479185700上墙

甘肃省住房与建设厅网站,杭州网站建设推荐q479185700上墙,社区电商小程序模板包含哪些,在线做图表网站1. 说明#xff1a; OPenGL一般在 QtWidget 中使用#xff0c;但目前使用 QML 做界面开发是一种趋势#xff0c;同时在QML中使用OPenGL进行渲染也是十分必要#xff0c;文章简单介绍如何在QML中使用 OPenGL#xff0c;搭建了一种基本的框架。整体思路和在 QtWidget 中类似…1. 说明 OPenGL一般在 QtWidget 中使用但目前使用 QML 做界面开发是一种趋势同时在QML中使用OPenGL进行渲染也是十分必要文章简单介绍如何在QML中使用 OPenGL搭建了一种基本的框架。整体思路和在 QtWidget 中类似只不过在 QML 中需要定义一个中间辅助类这个类是用来注册到QML中进行使用的同时这个类也会去加载自定义的 OPenGL 类从而实现 OPenGL 在 QML 中的显示。 2. 步骤一 创建自定义 OPenGL 类此时的自定义类不再继承QOpenGLWidget而是继承QQuickFramebufferObject::Renderer同时需要重写父类的 render() 虚函数相当于重写paintGL()函数自定义类命名为OpenGLRender相应代码如下 OPenGLRender.h: #ifndef OPENGLRENDER_H #define OPENGLRENDER_H#include QtQuick/QQuickFramebufferObject #include QtGui/QOpenGLFunctions_3_3_Coreclass OpenGLRender:public QQuickFramebufferObject::Renderer,protected QOpenGLFunctions_3_3_Core { public:OpenGLRender();//重写父类虚函数 render() 此步骤相当于重写paintGL()函数void render() override; }; #endif // OPENGLRENDER_HOPenGLRender.cpp: #include openglrender.hOpenGLRender::OpenGLRender() {//在构造函数中对opengl背景进行初始化initializeOpenGLFunctions(); }void OpenGLRender::render() {//设置背景颜色glClearColor(0.5f,0.9f,0.4f,1.0f);glClear(GL_COLOR_BUFFER_BIT); }3. 步骤二 定义中间辅助类命名为OPenGLItem并继承 QQuickFramebufferObject从写父类中的 createRenderer()函数这个函数的返回对象类型为 Render是在QML中渲染所需要的在 createRenderer() 函数中返回步骤一中自定义的 openglRender 对象。即中间辅助类只负责向 QML 界面提供一个”渲染器“这个渲染器本质上还是要用opengl来实现。相应代码如下 OPenGLItem.h: #ifndef OPENGLITEM_H #define OPENGLITEM_H#include QObject #include QQuickItem #include QtQuick/QQuickFramebufferObjectclass OpenGLItem : public QQuickFramebufferObject {Q_OBJECT public:OpenGLItem(QQuickItem* parent nullptr);//用于生成一个 openglRender 对象提供给QML界面使用QQuickFramebufferObject::Renderer *createRenderer() const override;signals:}; #endif // OPENGLITEM_HOPenGLItem.cpp: #include openglitem.h //引入 openglrender.h 头文件真正的图形渲染是在其中的 render() 函数进行的 #include openglrender.hOpenGLItem::OpenGLItem(QQuickItem *parent):QQuickFramebufferObject(parent) {//上下翻转这样就和OpenGL的坐标系一致了setMirrorVertically(true); }QQuickFramebufferObject::Renderer *OpenGLItem::createRenderer() const {//在这里返回一个 openglRender 对象return new OpenGLRender(); }4. 步骤三 在 main.cpp 中将上面步骤二的自定义辅助类 OPenGLItem 注册到 QML 中供其调用如下所示 #include QGuiApplication #include QQmlApplicationEngine #include openglitem.hint main(int argc, char *argv[]) {QCoreApplication::setAttribute(Qt::AA_EnableHighDpiScaling);QGuiApplication app(argc, argv);//注册 OpenGLItem 类到 QML 中使用qmlRegisterTypeOpenGLItem(self.OpenGlItem,1,0,OpenGLItem);QQmlApplicationEngine engine;const QUrl url(QStringLiteral(qrc:/main.qml));QObject::connect(engine, QQmlApplicationEngine::objectCreated,app, [url](QObject *obj, const QUrl objUrl) {if (!obj url objUrl)QCoreApplication::exit(-1);}, Qt::QueuedConnection);engine.load(url);return app.exec(); }5. 步骤四 在 QML 中使用是可以像其它控件一样随意指定尺寸和位置代码如下 main.qml: import QtQuick 2.9 import QtQuick.Window 2.2//导入自定义类 import self.OpenGlItem 1.0Window {visible: truewidth: 640height: 480title: qsTr(OpenGL In QQuick)//使用自定义的opengl小控件OpenGLItem{anchors.top: parent.topanchors.topMargin: 20anchors.horizontalCenter: parent.horizontalCenterwidth: 100height: 100}OpenGLItem{anchors.centerIn: parentwidth: 100height: 100} }6. 实际效果 在顶部中间会显示两个绿色矩形因为在 render()函数里只是更改了背景颜色没有绘制图形所以此处没有物体显示只有绿色的背景后期在 render() 函数内加入渲染代码后会正常显示。 持续更新中请大家多多关注…
http://www.hkea.cn/news/14560941/

相关文章:

  • wordpress设置网站地图网站利用微信拉取用户做登录页
  • 大城 网站成都工程建设项目网站
  • 移动网站打不开物流企业的网站模板
  • 动态域名网站wordpress轻系统
  • 响应式网站搭建网站数据库访问
  • 网站开发在无形资产中面向网站开发的相关知识
  • 承德微网站开发wordpress 界面
  • dedecms网站地图怎么做做外贸收费的服装网站
  • 网站界面设计专利专业的网站制作公司哪家好
  • 腾虎广州网站建设南宁seo营销推广
  • 做网站的项目流程订阅号怎么弄
  • 平台运营的主要工作内容长沙关键词优化服务
  • 无锡网站制作那些做网站阳泉
  • 模板设计建站建e网全屋设计效果图
  • 哈尔滨站建好了吗河南省汝州市建设网站
  • 登录广东省建设监理协会网站首页千家美家装体验馆
  • 微信如何建设网站个人页面网页设计
  • 成都网站建设推广wordpress 邀请码插件
  • 汽车html静态网站快速开发平台开发
  • 深圳福田建网站宣传片制作费用报价表
  • 网页制作与网站建设的发展趋势设想中小型企业网站建设的资金流动
  • 网站中客户的权限设置wordpress php 模板
  • 品牌设计网站建设wordpress 安装 数据库连接错误
  • 如何维护自己公司网站高端网站建设好的公司
  • 最好的自助建站系统电商网站如何做引流
  • wordpress 设置端口东莞seo优化seo关键词
  • 慈溪市建设局网站表格下载免费网站推荐货源
  • 制作软件的网站设计说明模板300字
  • 商城网站开发公司免费发布信息平台网
  • 在什么网站上可以做免费广告怎么建造自己的网站