Qt开发技术:Q3D图表开发笔记(四):Q3DSurface三维曲面图颜色样式详解、Demo以及代码详解
前言
qt提供了q3d进行三维开发,虽然这个框架没有得到大量运用也不是那么成功,性能上也有很大的欠缺,但是普通的点到为止的应用展示还是可以的。
其中就包括华丽绚烂的三维图表,数据量不大的时候是可以使用的。
前面介绍了基础的q3d散点图、柱状图、三维曲面图,本片深入对三维曲面图支持的颜色表现方式进行探讨。
Demo:Q3DSurface散点图颜色演示效果
纯色、选中点的颜色
渐进色、选中点的颜色
按照y轴参与渐进色
Q3D提供的三维图表
依赖QtDataVisualization。在安装qt的时候要选择安装QtDataVisualization模块。
Q3DScatter散点图
Q3D的散点图,性能大约支撑1000个点可以不卡顿,具体依赖pc,1000个点是什么 概念,可以理解为:10x10x10的区域,每个区域一个数据点。
Q3DBars柱状图
Q3D的柱状图,性能跟散点图类似。
Q3DSurface平面凹凸图,平面纹理图,平面曲线图
Q3D的柱状图,性能跟散点图类似。
Q3DSurface平面曲线图
简介
Q3DSurface类提供了渲染3D曲面图的方法。该类使开发人员能够渲染3D表面图,并通过自由旋转场景来查看它们。可以通过QSurface3DSeries控制曲面的视觉,例如绘制模式和着色。
Q3DSurface通过在用户用鼠标左键点击的数据点上显示高亮显示的球(当使用默认输入处理程序时)或通过QSurface3DSeries进行选择来支持选择。选择指针附带一个标签,在默认情况下,该标签显示数据点的值和点的坐标。
轴上显示的值范围和标签格式可以通过QValue3DAxis进行控制。
要旋转图形,请按住鼠标右键并移动鼠标。缩放是使用鼠标滚轮完成的。两者都假设默认的输入处理程序正在使用中。
如果没有将任何轴明确设置为Q3DSurface,则会创建不带标签的临时默认轴。这些默认轴可以通过轴访问器进行修改,但只要明确设置了方向的任何轴,该方向的默认轴就会被破坏。
摄像机预制类型:CameraPreset
注意:所有的东西都不能低于最低的Y平面从下网上看。
枚举如下,在Demo中动态调整查看效果:
- CameraPresetNone:用于指示尚未设置预设或场景已自由旋转
- CameraPresetFrontLow:相机预设前低(实际y中间)
- CameraPresetFront:相机预设前(实际前面俯视图,约45°向下)
- CameraPresetFrontHigh:相机预设前高(实际前面俯视图,约60°向下)
- CameraPresetLeftLow:相机预设左低
- CameraPresetLeft:相机预设左
- CameraPresetLeftHigh:相机预设左高
- CameraPresetRightLow:相机预设右低
- CameraPresetRight:相机预设右
- CameraPresetRightHigh:相机预设右高
- CameraPresetBehindLow:相机预设后低
- CameraPresetBehind:相机预设后
- CameraPresetBehindHigh:相机预设后高
- CameraPresetIsometricLeft:相机预设左45°
- CameraPresetIsometricLeftHigh:相机预设左45°高
- CameraPresetIsometricRight:相机预设右45°
- CameraPresetIsometricRightHigh:相机预设右45°高
- CameraPresetDirectlyAbove:相机预设,中间往下看旋转Y
- CameraPresetDirectlyAboveCW45:相机预设,中间往下看正旋转Y45°度不同
- CameraPresetDirectlyAboveCCW45:相机预设,中间往下看逆旋转Y45°角度不同
- CameraPresetFrontBelow:相机预设前下
- CameraPresetLeftBelow:相机预设左下
- CameraPresetRightBelow:相机预设右下
- CameraPresetBehindBelow:相机预设直接在后下,实际与xz不能再往下了
- CameraPresetDirectlyBelow:相机预设直接在下,实际与xz不能再往下了,对于仅为正的条形,充当CameraPresetFrontLow。
颜色样式:colorStyle
注意:实测multiHightlightColor没测出来,多选的时候是这个颜色,但是设置选择模式无法一个曲面多选几个点,以下都是这样的测试结果。
- ColorStyleUniform:对象以单一颜色渲染。使用的颜色在baseColors、singleHighlightColor和multiHighlightColor属性中指定。
// 设置颜色样式
_pSurface3DSeries->setColorStyle(Q3DTheme::ColorStyleUniform);
// 设置颜色
_pSurface3DSeries->setBaseColor(Qt::red);
// 选中颜色
_pSurface3DSeries->setSingleHighlightColor(Qt::blue);
// 使用 _pQ3DSurface->setSelectionMode(QAbstract3DGraph::SelectionItem
// | QAbstract3DGraph::SelectionRow
// | QAbstract3DGraph::SelectionMultiSeries);
// 也未测试出来
_pSurface3DSeries->setMultiHighlightColor(Qt::green);
- ColorStyleObjectGradient:无论对象的高度如何,对象都将使用每个对象的全渐变进行着色。使用的渐变在baseGradients、singleHighlightGradient 和 multiHighlightGraduate 属性中指定。
// 设置颜色样式
_pSurface3DSeries->setColorStyle(Q3DTheme::ColorStyleObjectGradient);
// 渐变色
QLinearGradient linearGradient;
linearGradient.setColorAt(0.0, Qt::red);
linearGradient.setColorAt(0.333, Qt::blue);
linearGradient.setColorAt(0.667, Qt::green);
linearGradient.setColorAt(1.0, Qt::gray);
// 设置颜色
_pSurface3DSeries->setBaseGradient(linearGradient);
// 选中颜色
// 渐变色2
QLinearGradient linearGradient2;
linearGradient2.setColorAt(0.0, Qt::yellow);
linearGradient2.setColorAt(1.0, Qt::gray);
_pSurface3DSeries->setSingleHighlightGradient(linearGradient2);
_pSurface3DSeries->setSingleHighlightColor(Qt::red);
// _pSurface3DSeries->setMultiHighlightGraduate(Qt::green);
- ColorStyleRangeGradient : 使用由对象的高度及其在Y轴上的位置确定的完整渐变的一部分对对象进行着色。使用的渐变在baseGradients、singleHighlightGradient 和 multiHighlightGraduate属性中指定。
// 设置颜色样式
_pSurface3DSeries->setColorStyle(Q3DTheme::ColorStyleRangeGradient);
// 渐变色
QLinearGradient linearGradient;
linearGradient.setColorAt(0.0, Qt::red);
linearGradient.setColorAt(1.0, Qt::green);
// 设置颜色
_pSurface3DSeries->setBaseGradient(linearGradient);
// 选中颜色
// 渐变色2
QLinearGradient linearGradient2;
linearGradient2.setColorAt(0.0, Qt::yellow);
linearGradient2.setColorAt(1.0, Qt::gray);
_pSurface3DSeries->setSingleHighlightGradient(linearGradient2);
_pSurface3DSeries->setSingleHighlightColor(Qt::red);
// _pSurface3DSeries->setMultiHighlightGraduate(Qt::green);
Q3DDemo构建流程解析
步骤一:确认安装QtDataVisualization模块
如何确认,则是在帮助文件中查看是否有Q3dscatter类。一般是安装了模块才会有对应的帮助文件。没有则重新安装qt或者单独安装该模块。
步骤二:工程配置文件中加入模块
Q3d是在数据可视化模块中,需要在pro或者pri配置文件中添加。
QT += datavisualization
步骤三:添加使用到的头文件
使用到Q3DBar相关类中添加头文件,主要使用到Q3DBar、QBar3DSeries、QBarDataRow等等。
#include <Q3DBars>
#include <Q3DTheme>
#include <Q3DSurface>
#include <QVector3D>
步骤四:添加命名空间
这时候还是无法使用对应的类,需要添加命名空间才行:
using namespace QtDataVisualization;
步骤五:Q3D的图标基础构建框架
下面是包含注释的Q3DSurface基础构建流程
_pQ3DSurface = new Q3DSurface();
_pContainer = QWidget::createWindowContainer(_pQ3DSurface, this);
// 设置轴文本
{
// 注意笛卡尔坐标
_pQ3DSurface->axisX()->setTitle("经度(°)");
_pQ3DSurface->axisX()->setTitleVisible(true);
_pQ3DSurface->axisY()->setTitle("高度(m)");
_pQ3DSurface->axisY()->setTitleVisible(true);
_pQ3DSurface->axisZ()->setTitle("纬度(°)");
_pQ3DSurface->axisZ()->setTitleVisible(true);
}
// 设置轴范围
{
// 注意笛卡尔坐标
_pQ3DSurface->axisX()->setRange(0, 359);
_pQ3DSurface->axisY()->setRange(0, 100);
_pQ3DSurface->axisZ()->setRange(0, 359);
}
// 生成一个曲线
_pSurface3DSeries = new QSurface3DSeries(_pQ3DSurface);
// 设置渲染平滑
_pSurface3DSeries->setMeshSmooth(true);
// 设置渲染模式
// DrawWireframe : 绘制栅格
// DrawSurface : 绘制表面
// DrawSurfaceAndWireframe : 绘制栅格和图表面
_pSurface3DSeries->setDrawMode(QSurface3DSeries::DrawSurface);
#if 0
// 设置颜色样式
// ColorStyleUniform = 0 : 对象以单一颜色渲染。使用的颜色在baseColors、
// singleHighlightColor和multiHighlightColor属性中指定。
// ColorStyleObjectGradient : 无论对象的高度如何,对象都将使用每个对象的全渐变进行着色。
// 使用的渐变在baseGradients、singleHighlightGradient 和 multiHighlightGraduate 属性中指定。
// ColorStyleRangeGradient :
_pSurface3DSeries->setColorStyle(Q3DTheme::ColorStyleUniform);
// 设置颜色
_pSurface3DSeries->setBaseColor(Qt::red);
// 选中颜色
_pSurface3DSeries->setSingleHighlightColor(Qt::blue);
// 使用 _pQ3DSurface->setSelectionMode(QAbstract3DGraph::SelectionItem
// | QAbstract3DGraph::SelectionRow
// | QAbstract3DGraph::SelectionMultiSeries);
// 也未测试出来
_pSurface3DSeries->setMultiHighlightColor(Qt::green);
#endif
#if 0
// 设置颜色样式
// ColorStyleUniform = 0 : 对象以单一颜色渲染。使用的颜色在baseColors、
// singleHighlightColor和multiHighlightColor属性中指定。
// ColorStyleObjectGradient : 无论对象的高度如何,对象都将使用每个对象的全渐变进行着色。
// 使用的渐变在baseGradients、singleHighlightGradient 和 multiHighlightGraduate 属性中指定。
// ColorStyleRangeGradient :
_pSurface3DSeries->setColorStyle(Q3DTheme::ColorStyleObjectGradient);
// 渐变色
QLinearGradient linearGradient;
linearGradient.setColorAt(0.0, Qt::red);
linearGradient.setColorAt(0.333, Qt::blue);
linearGradient.setColorAt(0.667, Qt::green);
linearGradient.setColorAt(1.0, Qt::gray);
// 设置颜色
_pSurface3DSeries->setBaseGradient(linearGradient);
// 选中颜色
// 渐变色2
QLinearGradient linearGradient2;
linearGradient2.setColorAt(0.0, Qt::yellow);
linearGradient2.setColorAt(1.0, Qt::gray);
_pSurface3DSeries->setSingleHighlightGradient(linearGradient2);
_pSurface3DSeries->setSingleHighlightColor(Qt::red);
// _pSurface3DSeries->setMultiHighlightGraduate(Qt::green);
#endif
#if 1
// 设置颜色样式
// ColorStyleUniform = 0 : 对象以单一颜色渲染。使用的颜色在baseColors、
// singleHighlightColor和multiHighlightColor属性中指定。
// ColorStyleObjectGradient : 无论对象的高度如何,对象都将使用每个对象的全渐变进行着色。
// 使用的渐变在baseGradients、singleHighlightGradient 和 multiHighlightGraduate 属性中指定。
// ColorStyleRangeGradient : 使用由对象的高度及其在Y轴上的位置确定的完整渐变的一部分对对象进行着色。
// 使用的渐变在baseGradients、singleHighlightGradient 和 multiHighlightGraduate属性中指定。
_pSurface3DSeries->setColorStyle(Q3DTheme::ColorStyleRangeGradient);
// 渐变色
QLinearGradient linearGradient;
linearGradient.setColorAt(0.0, Qt::red);
linearGradient.setColorAt(1.0, Qt::green);
// 设置颜色
_pSurface3DSeries->setBaseGradient(linearGradient);
// 选中颜色
// 渐变色2
QLinearGradient linearGradient2;
linearGradient2.setColorAt(0.0, Qt::yellow);
linearGradient2.setColorAt(1.0, Qt::gray);
_pSurface3DSeries->setSingleHighlightGradient(linearGradient2);
_pSurface3DSeries->setSingleHighlightColor(Qt::red);
// _pSurface3DSeries->setMultiHighlightGraduate(Qt::green);
#endif
#if 0
// 设置渐进色
QLinearGradient *pLinearGradient = new QLinearGradient(0, 0,100,100);
pLinearGradient->setColorAt(0, Qt::red);
pLinearGradient->setColorAt(1.0, Qt::blue);
_pSurface3DSeries->setBaseGradient(*pLinearGradient);
#endif
// 视图添加该曲线
_pQ3DSurface->addSeries(_pSurface3DSeries);
// 设置阴影质量
_pQ3DSurface->setShadowQuality(QAbstract3DGraph::ShadowQualitySoftLow);
// 设置视角
_pQ3DSurface->scene()->activeCamera()->setCameraPreset(Q3DCamera::CameraPresetNone);
// 设置子网格
_pQ3DSurface->activeTheme()->setGridEnabled(true);
#if 1
// 添加模拟数据
QSurfaceDataArray *pSurfaceDataArray = new QSurfaceDataArray;
#if 1
#if 1
// 这是 z 纬度
for(int n = 0; n < 360; n++)
{
QSurfaceDataRow *pSurfaceDataRow = new QSurfaceDataRow;
// 这是 x 经度
for(int m = 0; m < 360; m++)
{
#if 0
// 注意与笛卡尔坐标进行映射
*pSurfaceDataRow << QVector3D(m, n / 7 + m / 7, n);
#else
// 注意与笛卡尔坐标进行映射(超过180的下沉)
*pSurfaceDataRow << QVector3D(m, n / 7 + m / 7 - (m > 180 ? n / 3 : 0), n);
#endif
}
*pSurfaceDataArray << pSurfaceDataRow;
}
#else
for(int n = 0; n < 360; n++)
{
QSurfaceDataRow *pSurfaceDataRow = new QSurfaceDataRow;
// 这是 x 经度
for(int m = 0; m < 360; m++)
{
// 注意与笛卡尔坐标进行映射
*pSurfaceDataRow << QVector3D(m, qrand() % 100, n);
LOG << n << m;
}
*pSurfaceDataArray << pSurfaceDataRow;
}
#endif
#else
QSurfaceDataRow *pSurfaceDataRow1 = new QSurfaceDataRow;
QSurfaceDataRow *pSurfaceDataRow2 = new QSurfaceDataRow;
QSurfaceDataRow *pSurfaceDataRow3 = new QSurfaceDataRow;
// 行与行之间,要形成一个四点成面
*pSurfaceDataRow1 << QVector3D(0, 0, 0) << QVector3D(359, 20, 0);
*pSurfaceDataRow2 << QVector3D(50, 20, 179) << QVector3D(359, 40, 179);
*pSurfaceDataRow3 << QVector3D(100, 80, 359) << QVector3D(359, 100, 359);
*pSurfaceDataArray << pSurfaceDataRow1 << pSurfaceDataRow2 << pSurfaceDataRow3;
#endif
// 添加数据(自动冲掉之前的数据)
_pSurface3DSeries->dataProxy()->resetArray(pSurfaceDataArray);
#endif
_pQ3DSurface->addSeries(_pSurface3DSeries);
_pQ3DSurface->show();
Demo源码
Q3dSurfaceColorWidget.h
#ifndef Q3DSURFACECOLORWIDGET_H
#define Q3DSURFACECOLORWIDGET_H
#include <QWidget>
#include <Q3DSurface>
#include <Q3DTheme>
#include <QSurface3DSeries>
#include <QVector3D>
using namespace QtDataVisualization;
namespace Ui {
class Q3dSurfaceColorWidget;
}
class Q3dSurfaceColorWidget : public QWidget
{
Q_OBJECT
public:
explicit Q3dSurfaceColorWidget(QWidget *parent = 0);
~Q3dSurfaceColorWidget();
public:
void setCameraPreset(Q3DCamera::CameraPreset cameraPreset);
protected:
void initControl();
protected:
void resizeEvent(QResizeEvent *event);
private slots:
void on_comboBox_cameraPreset_currentIndexChanged(int index);
private:
Ui::Q3dSurfaceColorWidget *ui;
private:
Q3DSurface *_pQ3DSurface; // q3d平面曲线图
QWidget *_pContainer; // q3d窗口容器
QSurface3DSeries *_pSurface3DSeries ; // q3d柱状图数据
};
#endif // Q3DSURFACECOLORWIDGET_H
Q3dSurfaceColorWidget.cpp
#include "Q3dSurfaceColorWidget.h"
#include "ui_Q3dSurfaceColorWidget.h"
#include <Q3DTheme>
#include <QDebug>
#include <QDateTime>
//#define LOG qDebug()<<__FILE__<<__LINE__
//#define LOG qDebug()<<__FILE__<<__LINE__<<__FUNCTION__
//#define LOG qDebug()<<__FILE__<<__LINE__<<QThread()::currentThread()
//#define LOG qDebug()<<__FILE__<<__LINE__<<QDateTime::currentDateTime().toString("yyyy-MM-dd")
#define LOG qDebug()<<__FILE__<<__LINE__<<QDateTime::currentDateTime().toString("yyyy-MM-dd hh:mm:ss:zzz")
Q3dSurfaceColorWidget::Q3dSurfaceColorWidget(QWidget *parent) :
QWidget(parent),
ui(new Ui::Q3dSurfaceColorWidget),
_pQ3DSurface(0),
_pContainer(0),
_pSurface3DSeries(0)
{
ui->setupUi(this);
QString version = "v1.0.0";
initControl();
}
Q3dSurfaceColorWidget::~Q3dSurfaceColorWidget()
{
delete ui;
}
void Q3dSurfaceColorWidget::setCameraPreset(Q3DCamera::CameraPreset cameraPreset)
{
// 设置视角
// CameraPresetNone = -1, : 用于指示尚未设置预设,或场景已自由旋转。
// CameraPresetFrontLow = 0, :
// CameraPresetFront, :
// CameraPresetFrontHigh, :
// CameraPresetLeftLow, :
// CameraPresetLeft, :
// CameraPresetLeftHigh, :
// CameraPresetRightLow, :
// CameraPresetRight, :
// CameraPresetRightHigh, :
// CameraPresetBehindLow, :
// CameraPresetBehind, :
// CameraPresetBehindHigh, :
// CameraPresetIsometricLeft, :
// CameraPresetIsometricLeftHigh, :
// CameraPresetIsometricRight, :
// CameraPresetIsometricRightHigh, :
// CameraPresetDirectlyAbove, :
// CameraPresetDirectlyAboveCW45, :
// CameraPresetDirectlyAboveCCW45, :
// CameraPresetFrontBelow, :
// CameraPresetLeftBelow, :
// CameraPresetRightBelow, :
// CameraPresetBehindBelow, :
// CameraPresetDirectlyBelow :
// 设置视角
if(_pQ3DSurface)
{
_pQ3DSurface->scene()->activeCamera()->setCameraPreset(cameraPreset);
}
}
void Q3dSurfaceColorWidget::initControl()
{
// 视角预置
{
// 设置视角
// CameraPresetNone = -1, : 用于指示尚未设置预设,或场景已自由旋转。
// CameraPresetFrontLow = 0, :
// CameraPresetFront, :
// CameraPresetFrontHigh, :
// CameraPresetLeftLow, :
// CameraPresetLeft, :
// CameraPresetLeftHigh, :
// CameraPresetRightLow, :
// CameraPresetRight, :
// CameraPresetRightHigh, :
// CameraPresetBehindLow, :
// CameraPresetBehind, :
// CameraPresetBehindHigh, :
// CameraPresetIsometricLeft, :
// CameraPresetIsometricLeftHigh, :
// CameraPresetIsometricRight, :
// CameraPresetIsometricRightHigh, :
// CameraPresetDirectlyAbove, :
// CameraPresetDirectlyAboveCW45, :
// CameraPresetDirectlyAboveCCW45, :
// CameraPresetFrontBelow, :
// CameraPresetLeftBelow, :
// CameraPresetRightBelow, :
// CameraPresetBehindBelow, :
// CameraPresetDirectlyBelow :
ui->comboBox_cameraPreset->clear();
ui->comboBox_cameraPreset->addItem("Q3DCamera::CameraPresetNone");
ui->comboBox_cameraPreset->addItem("Q3DCamera::CameraPresetFrontLow = 0");
ui->comboBox_cameraPreset->addItem("Q3DCamera::CameraPresetFront");
ui->comboBox_cameraPreset->addItem("Q3DCamera::CameraPresetFrontHigh");
ui->comboBox_cameraPreset->addItem("Q3DCamera::CameraPresetLeftLow");
ui->comboBox_cameraPreset->addItem("Q3DCamera::CameraPresetLeft");
ui->comboBox_cameraPreset->addItem("Q3DCamera::CameraPresetLeftHigh");
ui->comboBox_cameraPreset->addItem("Q3DCamera::CameraPresetRightLow");
ui->comboBox_cameraPreset->addItem("Q3DCamera::CameraPresetRight");
ui->comboBox_cameraPreset->addItem("Q3DCamera::CameraPresetRightHigh");
ui->comboBox_cameraPreset->addItem("Q3DCamera::CameraPresetBehindLow");
ui->comboBox_cameraPreset->addItem("Q3DCamera::CameraPresetBehind");
ui->comboBox_cameraPreset->addItem("Q3DCamera::CameraPresetBehindHigh");
ui->comboBox_cameraPreset->addItem("Q3DCamera::CameraPresetIsometricLeft");
ui->comboBox_cameraPreset->addItem("Q3DCamera::CameraPresetIsometricLeftHigh");
ui->comboBox_cameraPreset->addItem("Q3DCamera::CameraPresetIsometricRight");
ui->comboBox_cameraPreset->addItem("Q3DCamera::CameraPresetIsometricRightHigh");
ui->comboBox_cameraPreset->addItem("Q3DCamera::CameraPresetDirectlyAbove");
ui->comboBox_cameraPreset->addItem("Q3DCamera::CameraPresetDirectlyAboveCW45");
ui->comboBox_cameraPreset->addItem("Q3DCamera::CameraPresetDirectlyAboveCCW45");
ui->comboBox_cameraPreset->addItem("Q3DCamera::CameraPresetFrontBelow");
ui->comboBox_cameraPreset->addItem("Q3DCamera::CameraPresetLeftBelow");
ui->comboBox_cameraPreset->addItem("Q3DCamera::CameraPresetRightBelow");
ui->comboBox_cameraPreset->addItem("Q3DCamera::CameraPresetBehindBelow");
ui->comboBox_cameraPreset->addItem("Q3DCamera::CameraPresetDirectlyBelow");
ui->comboBox_cameraPreset->setCurrentText("Q3DCamera::CameraPresetNone");
}
_pQ3DSurface = new Q3DSurface();
_pContainer = QWidget::createWindowContainer(_pQ3DSurface, this);
// 设置轴文本
{
// 注意笛卡尔坐标
_pQ3DSurface->axisX()->setTitle("经度(°)");
_pQ3DSurface->axisX()->setTitleVisible(true);
_pQ3DSurface->axisY()->setTitle("高度(m)");
_pQ3DSurface->axisY()->setTitleVisible(true);
_pQ3DSurface->axisZ()->setTitle("纬度(°)");
_pQ3DSurface->axisZ()->setTitleVisible(true);
}
// 设置轴范围
{
// 注意笛卡尔坐标
_pQ3DSurface->axisX()->setRange(0, 359);
_pQ3DSurface->axisY()->setRange(0, 100);
_pQ3DSurface->axisZ()->setRange(0, 359);
}
// 生成一个曲线
_pSurface3DSeries = new QSurface3DSeries(_pQ3DSurface);
// 设置渲染平滑
_pSurface3DSeries->setMeshSmooth(true);
// 设置渲染模式
// DrawWireframe : 绘制栅格
// DrawSurface : 绘制表面
// DrawSurfaceAndWireframe : 绘制栅格和图表面
_pSurface3DSeries->setDrawMode(QSurface3DSeries::DrawSurface);
#if 0
// 设置颜色样式
// ColorStyleUniform = 0 : 对象以单一颜色渲染。使用的颜色在baseColors、
// singleHighlightColor和multiHighlightColor属性中指定。
// ColorStyleObjectGradient : 无论对象的高度如何,对象都将使用每个对象的全渐变进行着色。
// 使用的渐变在baseGradients、singleHighlightGradient 和 multiHighlightGraduate 属性中指定。
// ColorStyleRangeGradient :
_pSurface3DSeries->setColorStyle(Q3DTheme::ColorStyleUniform);
// 设置颜色
_pSurface3DSeries->setBaseColor(Qt::red);
// 选中颜色
_pSurface3DSeries->setSingleHighlightColor(Qt::blue);
// 使用 _pQ3DSurface->setSelectionMode(QAbstract3DGraph::SelectionItem
// | QAbstract3DGraph::SelectionRow
// | QAbstract3DGraph::SelectionMultiSeries);
// 也未测试出来
_pSurface3DSeries->setMultiHighlightColor(Qt::green);
#endif
#if 0
// 设置颜色样式
// ColorStyleUniform = 0 : 对象以单一颜色渲染。使用的颜色在baseColors、
// singleHighlightColor和multiHighlightColor属性中指定。
// ColorStyleObjectGradient : 无论对象的高度如何,对象都将使用每个对象的全渐变进行着色。
// 使用的渐变在baseGradients、singleHighlightGradient 和 multiHighlightGraduate 属性中指定。
// ColorStyleRangeGradient :
_pSurface3DSeries->setColorStyle(Q3DTheme::ColorStyleObjectGradient);
// 渐变色
QLinearGradient linearGradient;
linearGradient.setColorAt(0.0, Qt::red);
linearGradient.setColorAt(0.333, Qt::blue);
linearGradient.setColorAt(0.667, Qt::green);
linearGradient.setColorAt(1.0, Qt::gray);
// 设置颜色
_pSurface3DSeries->setBaseGradient(linearGradient);
// 选中颜色
// 渐变色2
QLinearGradient linearGradient2;
linearGradient2.setColorAt(0.0, Qt::yellow);
linearGradient2.setColorAt(1.0, Qt::gray);
_pSurface3DSeries->setSingleHighlightGradient(linearGradient2);
_pSurface3DSeries->setSingleHighlightColor(Qt::red);
// _pSurface3DSeries->setMultiHighlightGraduate(Qt::green);
#endif
#if 1
// 设置颜色样式
// ColorStyleUniform = 0 : 对象以单一颜色渲染。使用的颜色在baseColors、
// singleHighlightColor和multiHighlightColor属性中指定。
// ColorStyleObjectGradient : 无论对象的高度如何,对象都将使用每个对象的全渐变进行着色。
// 使用的渐变在baseGradients、singleHighlightGradient 和 multiHighlightGraduate 属性中指定。
// ColorStyleRangeGradient : 使用由对象的高度及其在Y轴上的位置确定的完整渐变的一部分对对象进行着色。
// 使用的渐变在baseGradients、singleHighlightGradient 和 multiHighlightGraduate属性中指定。
_pSurface3DSeries->setColorStyle(Q3DTheme::ColorStyleRangeGradient);
// 渐变色
QLinearGradient linearGradient;
linearGradient.setColorAt(0.0, Qt::red);
linearGradient.setColorAt(1.0, Qt::green);
// 设置颜色
_pSurface3DSeries->setBaseGradient(linearGradient);
// 选中颜色
// 渐变色2
QLinearGradient linearGradient2;
linearGradient2.setColorAt(0.0, Qt::yellow);
linearGradient2.setColorAt(1.0, Qt::gray);
_pSurface3DSeries->setSingleHighlightGradient(linearGradient2);
_pSurface3DSeries->setSingleHighlightColor(Qt::red);
// _pSurface3DSeries->setMultiHighlightGraduate(Qt::green);
#endif
#if 0
// 设置渐进色
QLinearGradient *pLinearGradient = new QLinearGradient(0, 0,100,100);
pLinearGradient->setColorAt(0, Qt::red);
pLinearGradient->setColorAt(1.0, Qt::blue);
_pSurface3DSeries->setBaseGradient(*pLinearGradient);
#endif
// 视图添加该曲线
_pQ3DSurface->addSeries(_pSurface3DSeries);
// 设置阴影质量
_pQ3DSurface->setShadowQuality(QAbstract3DGraph::ShadowQualitySoftLow);
// 设置视角
_pQ3DSurface->scene()->activeCamera()->setCameraPreset(Q3DCamera::CameraPresetNone);
// 设置子网格
_pQ3DSurface->activeTheme()->setGridEnabled(true);
#if 1
// 添加模拟数据
QSurfaceDataArray *pSurfaceDataArray = new QSurfaceDataArray;
#if 1
#if 1
// 这是 z 纬度
for(int n = 0; n < 360; n++)
{
QSurfaceDataRow *pSurfaceDataRow = new QSurfaceDataRow;
// 这是 x 经度
for(int m = 0; m < 360; m++)
{
#if 0
// 注意与笛卡尔坐标进行映射
*pSurfaceDataRow << QVector3D(m, n / 7 + m / 7, n);
#else
// 注意与笛卡尔坐标进行映射(超过180的下沉)
*pSurfaceDataRow << QVector3D(m, n / 7 + m / 7 - (m > 180 ? n / 3 : 0), n);
#endif
}
*pSurfaceDataArray << pSurfaceDataRow;
}
#else
for(int n = 0; n < 360; n++)
{
QSurfaceDataRow *pSurfaceDataRow = new QSurfaceDataRow;
// 这是 x 经度
for(int m = 0; m < 360; m++)
{
// 注意与笛卡尔坐标进行映射
*pSurfaceDataRow << QVector3D(m, qrand() % 100, n);
LOG << n << m;
}
*pSurfaceDataArray << pSurfaceDataRow;
}
#endif
#else
QSurfaceDataRow *pSurfaceDataRow1 = new QSurfaceDataRow;
QSurfaceDataRow *pSurfaceDataRow2 = new QSurfaceDataRow;
QSurfaceDataRow *pSurfaceDataRow3 = new QSurfaceDataRow;
// 行与行之间,要形成一个四点成面
*pSurfaceDataRow1 << QVector3D(0, 0, 0) << QVector3D(359, 20, 0);
*pSurfaceDataRow2 << QVector3D(50, 20, 179) << QVector3D(359, 40, 179);
*pSurfaceDataRow3 << QVector3D(100, 80, 359) << QVector3D(359, 100, 359);
*pSurfaceDataArray << pSurfaceDataRow1 << pSurfaceDataRow2 << pSurfaceDataRow3;
#endif
// 添加数据(自动冲掉之前的数据)
_pSurface3DSeries->dataProxy()->resetArray(pSurfaceDataArray);
#endif
_pQ3DSurface->addSeries(_pSurface3DSeries);
_pQ3DSurface->show();
}
void Q3dSurfaceColorWidget::resizeEvent(QResizeEvent *event)
{
#if 1
if(_pContainer)
{
_pContainer->setGeometry(0, 50, rect().width(), rect().height() - 50);
_pContainer->lower();
}
#endif
}
void Q3dSurfaceColorWidget::on_comboBox_cameraPreset_currentIndexChanged(int index)
{
setCameraPreset((Q3DCamera::CameraPreset)(index - 1));
}
工程模板v1.3.0
Qt开发技术:Q3D图表开发笔记(四):Q3DSurface三维曲面图颜色样式详解、Demo以及代码详解的更多相关文章
- Qt开发技术:Q3D图表开发笔记(三):Q3DSurface三维曲面图介绍、Demo以及代码详解
前言 qt提供了q3d进行三维开发,虽然这个框架没有得到大量运用也不是那么成功,性能上也有很大的欠缺,但是普通的点到为止的应用展示还是可以的. 其中就包括华丽绚烂的三维图表,数据量不大的时候是可 ...
- Qt开发技术:QCharts(三)QCharts样条曲线图介绍、Demo以及代码详解
若该文为原创文章,未经允许不得转载原博主博客地址:https://blog.csdn.net/qq21497936原博主博客导航:https://blog.csdn.net/qq21497936/ar ...
- Qt开发技术:Q3D图表开发笔记(一):Q3DScatter三维散点图介绍、Demo以及代码详解
前言 qt提供了q3d进行三维开发,虽然这个框架没有得到大量运用也不是那么成功,性能上也有很大的欠缺,但是普通的点到为止的应用展示还是可以的. 其中就包括华丽绚烂的三维图表,数据量不大的时候是可 ...
- Qwt开发笔记(二):Qwt基础框架介绍、折线图介绍、折线图Demo以及代码详解
前言 QWT开发笔记系列整理集合,这是目前使用最为广泛的Qt图表类(Qt的QWidget代码方向只有QtCharts,Qwt,QCustomPlot),使用多年,系统性的整理,本系列旨在系统解说并 ...
- 『开发技术』Docker开发教程(一)安装与测试(Windows 家庭版)
0.前言 针对其他系统和版本,Docker都很容易安装,可以参考官方教程:https://docs.docker.com/docker-hub/ 由于Windows10家庭版无法安装docker,因此 ...
- 混合模式为什么成为占有率最高的app开发技术
在企业移动战略布局中,app已成为连接业务与用户最主要的载体,同样其开发技术目前也处于十分成熟的阶段,而从技术实现的角度去考量,很多从业者可能并不知道,越是大企业.越是IT预算多的企业,他们的移动ap ...
- 快速全面了解QT软件界面开发技术
快速全面了解QT软件界面开发技术 目录 前言 一. 学习QT可能的目的是什么? 只想体验一下QT? 当前的项目选择了用QT. 为将来做QT技术储备. 二. QT的核心技术优势是什么? QT在软 ...
- Qt大型工程开发技术选型Part3:Qt调用C#编写的COM组件实例
Qt大型工程开发技术选型Part3:Qt调用C#编写的COM组件实例以及错误总结 ok,前面铺垫了那么多,现在来写一个开发实例,我会把其中隐藏的坑和陷阱简单谈谈,并在文章最后总结. 不愿意看长篇大论的 ...
- 《MFC游戏开发》笔记四 键盘响应和鼠标响应:让人物动起来
本系列文章由七十一雾央编写,转载请注明出处. http://blog.csdn.net/u011371356/article/details/9327377 作者:七十一雾央 新浪微博:http:// ...
- 《Android开发艺术探索》读书笔记 (13) 第13章 综合技术、第14章 JNI和NDK编程、第15章 Android性能优化
第13章 综合技术 13.1 使用CrashHandler来获取应用的Crash信息 (1)应用发生Crash在所难免,但是如何采集crash信息以供后续开发处理这类问题呢?利用Thread类的set ...
随机推荐
- python websocket 参数
websocket中就有建立连接connect.发送消息send等函数可供使用,但是websocket.WebSocketApp将这些都封装好了,只用在实例化的时候传入自定义函数即可,更方便.因此这里 ...
- DBJ,DB,CJJ,CECS 标准区别及全套下载教程
DBJ DBJ开头的标准是地方建筑标准:D--地方. B--标准. J--建筑. <中华人民共和国标准化法>将中国标准分为国家标准.行业标准.地方标准(DB).企业标准(Q/)四级.地方标 ...
- 浅谈sparse vec检索工程化实现
前面我们通过两篇文章: BGE M3-Embedding 模型介绍 和 Sparse稀疏检索介绍与实践 介绍了sparse 稀疏检索,今天我们来看看如何建立一个工程化的系统来实现sparse vec的 ...
- SnakeYaml反序列化分析
前言 SnakeYaml是Java中解析yaml的库,而yaml是一种人类可读的数据序列化语言,通常用于编写配置文件等.yaml真是到哪都有啊. 环境搭建 <dependency> < ...
- 字节面试:如何解决MQ消息积压问题?
MQ(Message Queue)消息积压问题指的是在消息队列中累积了大量未处理的消息,导致消息队列中的消息积压严重,超出系统处理能力,影响系统性能和稳定性的现象. 1.消息积压是哪个环节的问题? M ...
- Redis 数据类型list以及使用场景
简介: Redis 数据类型list以及使用场景 数据存储需求:存储多个数据,并对数据进入存储空间的顺序进行区分需要的存储结构:一个存储空间保存多个数据,且通过数据可以体现进入顺序list类型:保存多 ...
- 龙蜥社区开源 coolbpf,BPF 程序开发效率提升百倍 | 龙蜥技术
简介: coolbpf,可以酷玩的BPF!来看看让BPF加了双翅膀的它究竟有多硬核? 文/系统运维 SIG(Special Interest Group) 引言 BPF 是一个新的动态跟踪技术,目前这 ...
- Flink集成Iceberg在同程艺龙的实践
------------恢复内容开始------------ null ------------恢复内容结束------------
- 9.按需创建PV和PVC并使用
官方文档:https://kubernetes.io/zh-cn/docs/tasks/configure-pod-container/configure-persistent-volume-stor ...
- 什么是IPD项目管理模式?聊聊IPD下的产品研发流程
IPD(集成产品开发)涵盖了产品从创意提出到研发.生产.运营等,包含了产品开发到营销运营的整个过程.围绕产品(或项目)生命周期的过程的管理模式,是一套生产流程,更是时下国际先进的管理体系.IPD(集成 ...