Qt——坐标轴相关

setAutoTicks(false)关闭底部标签自动生成

setSpecCurveParaDiag.h

#ifndef SETSPECCURVEPARADIALOG_H
#define SETSPECCURVEPARADIALOG_H

#include <QDialog>
#include "ui_setSpecCurveParaDiag.h"

class QSpinBox;
class QComboBox;
class QVBoxLayout;
class QFormLayout;

class setSpecCurveParaDiag : public QDialog, public Ui::setSpecCurveParaDiag
{
	Q_OBJECT

public:
	setSpecCurveParaDiag(QWidget *parent = 0);

private:
	QSpinBox *xAxisSBox;
	QSpinBox *yAxisSBox;
	QComboBox *dotStrategyCBox;
	QFormLayout *contentLayout;
	QVBoxLayout *DiagLayout;
	
	const int verticalSpacing;
	const int topMargin;

};


#endif



setSpecCurveParaDiag.cpp

//*********************************************************//
//
// 功能:光谱曲线参数对话框
//
//********************************************************//


#include <QtGui>
#include <QtWidgets/QSpinBox>
#include <QtWidgets/QComboBox>
#include <QtWidgets/QFormLayout>
#include <QtWidgets/QVBoxLayout>
#include "setSpecCurveParaDiag.h"


#if _MSC_VER >= 1600
#pragma execution_character_set("utf-8")
#endif


setSpecCurveParaDiag::setSpecCurveParaDiag(QWidget *parent)
<span style="white-space:pre">	</span>: QDialog(parent), verticalSpacing(30), topMargin(20)
{


<span style="white-space:pre">	</span>setupUi(this);


<span style="white-space:pre">	</span>xAxisSBox = new QSpinBox;
<span style="white-space:pre">	</span>yAxisSBox = new QSpinBox;
<span style="white-space:pre">	</span>dotStrategyCBox = new QComboBox;
<span style="white-space:pre">	</span>contentLayout = new QFormLayout;
<span style="white-space:pre">	</span>DiagLayout = new QVBoxLayout;
<span style="white-space:pre">	</span>
<span style="white-space:pre">	</span>contentLayout->addRow(tr("X轴最大值"),xAxisSBox);
<span style="white-space:pre">	</span>contentLayout->addRow(tr("Y轴最大值"),yAxisSBox);
<span style="white-space:pre">	</span>contentLayout->addRow(tr("选择策略"),dotStrategyCBox);
<span style="white-space:pre">	</span>contentLayout->setVerticalSpacing(verticalSpacing);


<span style="white-space:pre">	</span>DiagLayout->addSpacing(topMargin);
<span style="white-space:pre">	</span>DiagLayout->addLayout(contentLayout);
<span style="white-space:pre">	</span>DiagLayout->addLayout(buttonLayout);


<span style="white-space:pre">	</span>setLayout(DiagLayout);


}


该控件继承QWidget, 实现了左右上下四种形式的坐标轴控件。 可以设置固定间隔或自动选择间隔 可以设置最小间隔 开放一个槽来动态调整坐标轴的范围 处理了边缘刻度的显示 /************************************************************************ * 版权所有 (C) 2012-2015, liang1057@yahoo.com.cn 类声明: 坐标轴控件 ************************************************************************/ /** @brief 坐标轴控件 * * @details 坐标轴控件 只有刻度和数字,数字可以隐藏(用来显示其他需要显示的刻度值) */ class uiAxis : public QWidget { Q_OBJECT public: /** @brief 坐标轴类型 * * @details 坐标轴类型 */ enum AXISTYPE{ LEFT_AXIS = 0, TOP_AXIS, RIGHT_AXIS, BOTTOM_AXIS }; /** @brief 构造函数 */ uiAxis(AXISTYPE type = BOTTOM_AXIS, QWidget *parent = 0); /** @brief 析构函数 */ ~uiAxis(void); /** @brief 设置坐标轴的范围 */ void setScop(double minValue, double maxValue); /** @brief 获取坐标轴的范围 */ void getScop(double& minValue,double& maxValue); /** @brief 获取坐标轴的范围 */ double getMinValue(); double getMaxValue(); /** @brief 设置坐标轴的类型 */ void setAxisType(AXISTYPE type); /** @brief 坐标轴的类型 */ AXISTYPE getAxisType(); /** @brief 设置最小刻度(小刻度的最小间隔) */ void setMinInterval(double value); /** @brief 设置自动间隔 */ void setAutoScale(bool val=true); /** @brief 设置固定间隔 */ void setSettedScale(bool val=true); /** @brief 设置坐标轴的绘制范围, 像素值 */ void setBoundary(int left, int right, int top, int bottom); void getBoundary(int& left, int& right, int& top, int& bottom);
本资源为Qt绘图基础,世界坐标系转换为逻辑坐标系。世界坐标系原点在视图左上角,本例子通过世界坐标转换,将坐标原点定位在视图中央,Y轴向上,X轴向右,并绘制坐标轴,基于逻辑坐标系下的绘图,可将转换关系函数取消生效,对比世界坐标系下的绘图。 重写PainterEvent函数: void QtPixPainter::paintEvent(QPaintEvent* event) { QPainter painter(this); // 反走样 painter.setRenderHint(QPainter::Antialiasing, true); //物理坐标系与逻辑坐标系的转换,如果不转换,下面的绘图都是在世界坐标系下 setWorldTransform(painter); // 其他一些绘制矩形,多边形的例子,经过上面转换,都是在逻辑坐标系下 drawRectScale(painter); //draw_shearRect(painter); //利用rotate()函数进行比例变换,实现缩放效果 //draw_rotate_act(painter); //draw_by_save_restore(painter); //transform_draw_SinX(painter); transform_draw(painter); local_drawConvexPolygon(painter); } // 将世界坐标(原点左上角)转换为逻辑坐标(原点在屏幕中间) QPointF QtPixPainter::mapToScene(const QPointF& point) { QTransform transMatrix = _transform.inverted(); //翻转矩阵? return transMatrix.map(point); //将点piont映射到transMatrix定义的坐标系中来 } // 将鼠标的逻辑位置返回并以标签形式展示 void QtPixPainter::mouseMoveEvent(QMouseEvent* event) { QString msg; QPointF mouse_po = mapToScene(event->pos()); //总是返回屏幕物理坐标系 double x = mouse_po.x(); // 总是返回屏幕物理坐标系 double y = mouse_po.y(); QString str = "(" + QString::number(x) + "," + QString::number(y) + ")"; //qDebug()<<"world x = "<pos().x()<<",world y = "<pos().y(); m_mouse_lable->setText(str); }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值