QtCharts之坐标轴标签换行等显示问题

记录一下。虽然方法网上都有,但是搜起来太费时间了。

若标签不是很长,但就是无法显示

这可能是因为折线图所在布局的位置比较局限。可从控件上进行调整。
或者参考Qt使用QChart绘图时横坐标文字过多显示不全怎么设置?中的回答,对坐标轴的角度进行调整。其中0代表水平方向。

m_xAxis->setLabelsAngle(0);

或者从根源上解决显示问题,参考在这里记录一下 QChart解决X时间轴太长显示不完全的问题,设置上下左右边距。(我自己传参数0.1,1,3都试过了,都能全部显示。但没有这一段代码就无法显示。暂时没研究清楚参数具体含义)

    QMargins q;
    q.setBottom(1);
    m_chart->setMargins(q);

或者可以根据实际情况调整字体、文字大小等。

若标签很长

我遇到的需求是显示年月日时分秒,上述方法就算显示全了也显得坐标轴标题很细长。因此考虑中间换行。即对setFormat(QString)方法中的QString处理。我尝试过在中间插入"\n"换行符,或者使用append()方法附加换行符,都失败了。后来参考QString字符串换行并设置不同颜色成功了。

    QString xtime = "yy年mm月dd日";
    xtime.append("<br>");
    xtime.append("hh:mm:ss");
    m_xAxis->setFormat(xtime);
    m_xAxis->setLabelsAngle(45);

这是效果:
图片效果

该控件继承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);
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值