CloudCompare二次开发之如何设计界面ui与功能实现?

这篇具有很好参考价值的文章主要介绍了CloudCompare二次开发之如何设计界面ui与功能实现?。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

0.引言

  CloudCompare源代码编译成功后,即可进行二次开发,可以通过修改源码实现二次开发,二次开发基础功能见(CloudCompare如何进行二次开发?),若想要实现更多自定义功能,可以自定义界面ui,并操作CloudCompare程序处理数据。本文讲解界面ui设计,修改相应的文件,使CloudCompare能够被扩展的ui界面进行克隆点云操作。

1.创建界面ui相关文件

  (1)在CloudCompare工程源码文件下新建Qt工程
  CloudCompare二次开发之如何设计界面ui与功能实现?

  本文在E:\CloudCompare-2.10.x\qCC\文件夹下创建初始Qt文件(如何在VS中使用Qt创建Qt工程详见:Visual Studio如何使用Qt开发桌面软件?)。
  CloudCompare二次开发之如何设计界面ui与功能实现?

  本文根据创建的Qt文件,主要使用的文件目录为:E:\CloudCompare-2.10.x\qCC\MyForm\MyForm\
  将该目录包含进CloudCompare搜索路径:CloudCompare工程→属性→配置属性→VC++目录→包含目录和库目录。
  CloudCompare二次开发之如何设计界面ui与功能实现?

2.添加界面ui相关文件到CloudCompare工程

  (1)用Visual Studio打开CloudCompare源码工程,添加MyForm项目的文件.ui、.h、.cpp
  ①工程新建一个筛选器存放MyForm相关文件
  CloudCompare二次开发之如何设计界面ui与功能实现?

  ②添加文件
  CloudCompare二次开发之如何设计界面ui与功能实现?

  (2)设计界面
  CloudCompare二次开发之如何设计界面ui与功能实现?

3.修改工程相关文件

  (1)修改MyForm相关文件
  ①修改MyForm.ui属性,并编译
  CloudCompare二次开发之如何设计界面ui与功能实现?

//命令行:填入以下内容
setlocal  
D:\Qt\Qt5.9.6\5.9.6\msvc2015\bin\uic.exe -o E:\CloudCompare-2.10.x\qCC\MyForm\MyForm\ui_MyForm.h E:\CloudCompare-2.10.x\qCC\MyForm\MyForm\MyForm.ui  
if %errorlevel% neq 0 goto :cmEnd  
:cmEnd  
endlocal & call :cmErrorLevel %errorlevel% & goto :cmDone  
:cmErrorLevel  
exit /b %1  
:cmDone  
if %errorlevel% neq 0 goto :VCEnd  
  
//说明:填入以下内容  
Generating ui_MyForm.h  
  
//输出:填入以下内容  
E:\CloudCompare-2.10.x\qCC\MyForm\MyForm\ui_MyForm.h

  CloudCompare二次开发之如何设计界面ui与功能实现?

  将生成的ui_MyForm.h加入工程。
  CloudCompare二次开发之如何设计界面ui与功能实现?

  ②修改MyForm.h属性,并编译
  CloudCompare二次开发之如何设计界面ui与功能实现?

//命令行:填入以下内容
setlocal  
D:\Qt\Qt5.9.6\5.9.6\msvc2015\bin\moc.exe E:\CloudCompare-2.10.x\qCC\MyForm\MyForm\MyForm.h -o E:\CloudCompare-2.10.x\qCC\MyForm\MyForm\moc_MyForm.cpp  
if %errorlevel% neq 0 goto :cmEnd  
:cmEnd  
endlocal & call :cmErrorLevel %errorlevel% & goto :cmDone  
:cmErrorLevel  
exit /b %1  
:cmDone  
if %errorlevel% neq 0 goto :VCEnd  
  
//说明:填入以下内容  
Generating moc_MyForm.cpp  
  
//输出:填入以下内容  
moc_MyForm.cpp  
  
//附加依赖项:填入以下内容  
‪moc.exe;MyForm.h

  CloudCompare二次开发之如何设计界面ui与功能实现?

  将生成的moc_MyForm.cpp加入工程。
  CloudCompare二次开发之如何设计界面ui与功能实现?

  ③修改MyForm.h代码
  CloudCompare二次开发之如何设计界面ui与功能实现?

#pragma once
#include "ccOverlayDialog.h"  
#include "ui_MyForm.h"  
  
class QMdiSubWindow;  
class ccGenericPointCloud;  
class ccPointCloud;  
class MainWindow;  
  
class MyForm :public ccOverlayDialog  
{  
    Q_OBJECT  
public:  
    //MyFirstQt(QWidget *parent = Q_NULLPTR);  
    explicit MyForm(QWidget* parent, ccPointCloud* pc);  
    virtual ~MyForm() override;  
    bool start() override;  
    public slots:  
    void onClone();   //点云克隆  
    void GetSelectedCloud();  
    void onClear();  
    void closeForm();//关闭窗体  
private:  
    Ui::MyFormClass* m_ui = nullptr;  //功能界面  
    ccPointCloud* m_cloud = nullptr;  //DB-Tree中被选中的点云  
    MainWindow* m_app = nullptr;   //主窗体单例  
};

  ④修改MyForm.cpp代码

#pragma once
#include "MyForm.h"  
#include "ccGLWindow.h"  
#include <ccGLWidget.h>  
#include <QMdiSubWindow>  
#include "ccPointCloud.h"  
#include "mainwindow.h"  
#include "ccDBRoot.h"  
#include "ccConsole.h"  
  
MyForm::MyForm(QWidget* parent, ccPointCloud* pc)  
    :ccOverlayDialog(parent)  
    , m_ui(new Ui::MyFormClass)  
    , m_cloud(pc)  
  
{  
    //m_ui->setupUi(this);  
    m_ui->setupUi(this);  
    //获取主窗体单例  
    m_app = MainWindow::TheInstance();  
    //信号槽连接  
    connect(m_ui->pushButton, &amp;QAbstractButton::clicked, this, &amp;MyForm::onClone);  
    connect(m_ui->pushButton_2, &amp;QAbstractButton::clicked, this, &amp;MyForm::closeForm);  
}  
MyForm::~MyForm()  
{  
    if (m_ui) {  
        delete m_ui;  
        m_ui = nullptr;  
    }  
    if (m_cloud) {  
        delete m_cloud;  
        m_cloud = nullptr;  
    }  
}  
  
bool MyForm::start()  
{  
    ccOverlayDialog::start();  
    m_processing = false;  
    return true;  
}  
  
void MyForm::GetSelectedCloud()  
{  
    if (m_cloud)  
    {  
        //设置取消选中上一块点云,同时包围盒消失  
        m_cloud->setSelected(false);  
    }  
    //DB-Tree中所有被选中的实体存入container  
    ccHObject::Container container;  
    m_app->db()->getSelectedEntities(container);  
    if (container.size())  
    {  
        //拿到第一个被选中的实体  
        ccHObject* ent = container[0];  
        if (!ent->isKindOf(CC_TYPES::POINT_CLOUD))  
        {  
            ccConsole::Error(QStringLiteral("选择的对象不是点云类型!"));  
            return;  
        }  
        ccGenericPointCloud* cloud = ccHObjectCaster::ToGenericPointCloud(ent);  
        m_cloud = static_cast<ccPointCloud*>(cloud);  
    //设置选中当前点云,同时显示包围盒  
    m_cloud->setSelected(true);  
    }  
    //刷新  
    m_app->RefreshAllGLWindow();  
}  
  
void MyForm::onClear()  
{  
    m_cloud->clear();  
    m_cloud = nullptr;  
}  
  
void MyForm::onClone()  
{  
    if (!m_cloud)  
    {  
        return;  
    }  
    //法一(点到点的克隆)  
    ccPointCloud* pc = new ccPointCloud(m_cloud->getName() + QString("-Clone"));  
    //为克隆对象分配内存  
    pc->reserve(m_cloud->size());  
    size_t pointSize = m_cloud->size();  
    for (size_t i = 0; i < pointSize; ++i)  
    {  
        pc->addPoint(*m_cloud->getPoint(i));  
    }  
    //法二(调用ccPointCloud的接口克隆)  
    //ccPointCloud* pc = new ccPointCloud(m_cloud->getName() + QString("-Clone"));  
    //m_cloud->clone(pc);  
    //将克隆点云pc添加到与m_cloud相同的目录下,并选中。  
    m_cloud->getParent()->addChild(pc);  
    m_app->db()->selectEntity(pc);  
    m_app->addToDB(pc);  
    m_app->UpdateUI();  
}  
  
void MyForm::closeForm()  
{  
    this->close();  
}

  (2)修改mainwindow源文件
  ①修改mainwindow.h代码
  CloudCompare二次开发之如何设计界面ui与功能实现?

  ②修改mainwindow.cpp代码
  CloudCompare二次开发之如何设计界面ui与功能实现?

void MainWindow::doclone()
{  
    //判断DB-Tree内是否选中对象  
    if (!haveOneSelection())  
    {  
        ccConsole::Error(QStringLiteral("请在 DB Tree 内选择点云实体对象!"));  
        return;  
    }  
    //获取当前DB-Tree中选择的实体对象  
    ccHObject* ent = m_selectedEntities[0];  
    //判断是否为点云对象(这里也可能是矢量栅格对象)  
    if (!ent->isKindOf(CC_TYPES::POINT_CLOUD))  
    {  
        ccConsole::Error(QStringLiteral("选择的对象不是点云类型!"));  
        return;  
    }  
    //将实体对象ent转换成ccGenericPointCloud对象  
    ccGenericPointCloud* gCloud = ccHObjectCaster::ToGenericPointCloud(ent);  
    //ccGenericPointCloud是抽象类,不能被实例化,所以向下转换成子类对象ccPointCloud,我们可以通过ccPointCloud来操作点云  
    ccPointCloud* pCloud = static_cast<ccPointCloud*>(gCloud);  
    //Qt MDI框架  
    QMdiSubWindow* qWin = m_mdiArea->activeSubWindow();  
    if (!qWin)  
        return;  
    if (!myForm)  
    {  
        //自定义对象m_colorDlg传入点云pCloud  
        myForm = new MyForm(qWin, pCloud);  
    //连接信号槽:使得后台可以实时获取用户在DB-Tree内所选中的点云  
    connect(m_ccRoot, &amp;ccDBRoot::selectionChanged, myForm, &amp;MyForm::GetSelectedCloud);  
    //当DB-Tree为空时,清空点云  
    connect(m_ccRoot, &amp;ccDBRoot::dbIsEmpty, myForm, &amp;MyForm::onClear);  
    //使得m_colorDlg能够停靠在点云显示窗口的右上角  
    registerOverlayDialog(myForm, Qt::TopRightCorner);  
    }  
    //显示m_colorDlg  
    myForm->start();  
    updateOverlayDialogsPlacement();  
}

(3)生成CloudCompare
  CloudCompare二次开发之如何设计界面ui与功能实现?

4.结果展示

  CloudCompare二次开发之如何设计界面ui与功能实现?

参考资料:
[1] cacrle. Visual Studio如何使用Qt开发桌面软件?; 2023-04-18 [accessed 2023-04-19].
[2] cacrle. CloudCompare如何进行二次开发?; 2023-04-19 [accessed 2023-04-19].
[3] 问也去. CloudCompare实现点选点云功能; 2021-09-23 [accessed 2023-04-17].
[4] 进击の小黑. CloudCompare简单二次开发教程 上(界面设计与ui文件编译); 2020-12-17 [accessed 2023-04-17].
[5] 进击の小黑. CloudCompare简单二次开发 下(功能实现); 2020-12-18 [accessed 2023-04-17].
[6] shaomq2187. VS2019已有项目中添加Qt; 2021-11-08 [accessed 2023-04-19].
[7] wb175208. VS2013 在配置中手动添加宏定义; 2018-04-08 [accessed 2023-04-19].文章来源地址https://www.toymoban.com/news/detail-419084.html

到了这里,关于CloudCompare二次开发之如何设计界面ui与功能实现?的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • CloudCompare 二次开发(26)——RANSAC分割多个平面

      使用CloudCompare与PCL编程实现的RANSAC分割多个平面。具体计算原理见:PCL RANSAC分割多个平面。 1、 mainwindow.h 文件 public 中添加: 2、 mainwindow.cpp 文件 void MainWindow::connectActions() 函数中添加:

    2024年01月25日
    浏览(31)
  • UG\NX二次开发 改变Block UI界面的尺寸

     1.设置“Dialog-DialogSizing”为Allow Resize;  2.添加滚动窗口控件,设置Width、Height的值,例如宽度500、高度5,可改变UI界面大小   3.在滚动窗口控件节点下添加其他的UI块。例如,添加 树控件。

    2024年02月13日
    浏览(31)
  • QGIS二次开发六:VS不借助QT插件创建UI界面

    上一篇博客我们说了在VS中如何使用QT插件来创建UI界面,但是我们二次开发QGIS的第一篇博客就说了,最好使用OSGeo4W中自动下载的QT进行QGIS二次开发,这样兼容性是最好的,那么该如何在VS中不使用外部安装的QT以及QT的VS插件情况下进行UI界面的创建和使用呢? 如果你仔细看完

    2024年02月13日
    浏览(29)
  • 如何在pycharm里边配置pyqt5、qt5-applications,使用拖拽功能设计UI界面

    安装pyqt5和qt5-applications 网上很多说要安装pyqt5-tools,但是里边并没有找到designer.exe这个文件,最终是在qt5-applications里边的Qt/bin找到了designer.exe文件。 在pycharm中配置designer working directory可以自己手动配置工程目录,也可以直接点击后面的按钮选择$ProjectFileDir$ 在pycharm中配置p

    2024年02月02日
    浏览(32)
  • Android开发之实现简单的用户登录及登陆界面的UI设计(五)

    登陆界面的UI设计 编写Java代码,进行简单的用户账号和密码判断

    2024年02月11日
    浏览(26)
  • CloudCompare 二次开发(6)——插件中拖拽添加Qt窗口(区域生长算法为例)

    本文由CSDN点云侠原创,原文链接。爬虫网站自重。   手动拖拽的方式搭建Qt对话框界面的制作流程,以PCL中的点云区域生长算法为例进行制作。 1、将 ....pluginsexample 路径下的 ExamplePlugin 复制一份并修改名字为 CCPointCloudProcess 。 2、创建窗口UI文件 使用任意Qt工程新建对话

    2023年04月11日
    浏览(42)
  • CloudCompare如何使用基础功能?

      CloudCompare是一款优秀的开源点云处理软件,在研究点云的过程中,会用到其中一些点云处理功能。为快速熟悉软件的基础功能,本文介绍相应的功能按键的作用。         (1)Open:打开文件,可以打开如下点云格式      (2)Open Recent… :打开最近的文件   

    2024年02月08日
    浏览(27)
  • 【Unity】实用功能开发(一)实现在UI中用RawImage实时展示3D模型(背景透明,并通过UI防止3D场景遮挡)并可以通过分层完成:游戏中的人物状态展示界面,小地图,人物实时头像状态等功能

    有时由于项目效果需要,部分功能的实现受到阻碍,这里收集一些已实现的思路和方法,每次会记录大致需求和遇到的问题,如果有更好的想法,欢迎评论区讨论!!! 目录 功能描述: 需求描述: 实现步骤: ①为需要展示的内容区分层级: ②在场景中添加一个摄像机,并

    2024年02月04日
    浏览(35)
  • Android开发-UI界面--类微信页面设计

    一、功能说明 二、开发技术 ​ 本次用到了 layout.xml、控件、监听、fragment layout(布局) ​ 定义了用户界面的可视化结构,主要有4种布局: ConstrainLayout (约束布局):一个使用“相对定位”灵活地确定微件的位置和大小的一个布局 LinearLayout (线性布局):按照水平或垂直

    2024年02月10日
    浏览(27)
  • 安卓开发 微信ui界面设计 (Android Studio)

    功能: 开发一个类似微信的主页面框架,UI布局为上中下结构,包含4个tab界面: 开发技术为: layout xml、控件、监听,fragment; 设计流程: 创建项目 改下项目名,编程语言为java UI界面 UI界面由多个xml组成,头部标题为微信,中间留空白,底部分为四个(微信,联系人,发现,

    2024年02月15日
    浏览(48)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包