Qt仿QQ截图之QTextEdit宽高自适应

之前用Qt做了个截图工具,最值得一写的就是在图片中添加文字时,如何让QTextEdit自适应文本的宽高
值得参考的是这篇博客:https://blog.csdn.net/kaida1234/article/details/80094175
但也只是做到了宽度自适应,高度并没有

一.效果

二.原理

这里的核心函数是void QTextDocument::adjustSize(),它他可以跟随文本的变动调整大小,然后通QSizeF QTextDocument::size()可以获取准确的文本尺寸,接着根据此尺寸调整编辑框的宽高,从而实现自适应。但是,当编辑框中的文本有自动换行时,经adjustSize()调整后文本的宽度和高度是随机的,只是总面积不变,正因如此,在具体实现的时候还得加上其他的判断才行。
QTextEdit的setLineWrapMode方法就是一个不错的辅助,当不需要自动换行时(宽度自适应),可将其参数设QTextEdit::NoWrap;当编辑框的宽度达到最大值时,可将其参数设为QTextEdit::WidgetWidth,这样文本就会自动换行(高度自适应),当然此时需将编辑框的宽度

  • 4
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 5
    评论
QTextEditQt框架中的一个文本编辑器控件,它可以用于显示和编辑文本内容。要实现QTextEdit自适应高度,可以通过以下步骤进行操作: 1. 设置QTextEdit的文本内容自动换行:可以使用`setWordWrapMode`函数将文本内容设置为自动换行模式,这样当文本内容超出QTextEdit的宽度时,会自动换行显示。 2. 监听QTextEdit的文本内容变化:可以使用`textChanged`信号来监听QTextEdit的文本内容变化。当文本内容发生变化时,可以根据文本内容的长度来调整QTextEdit高度。 3. 调整QTextEdit高度:可以使用`setFixedHeight`函数来设置QTextEdit的固定高度,根据文本内容的行数和每行的高度来计算出合适的高度值,并将其设置为QTextEdit高度。 下面是一个示例代码,演示了如何实现QTextEdit自适应高度: ```cpp // 设置QTextEdit自适应高度 void setAdaptiveHeight(QTextEdit* textEdit) { // 设置文本内容自动换行 textEdit->setWordWrapMode(QTextOption::WrapAtWordBoundaryOrAnywhere); // 监听文本内容变化 QObject::connect(textEdit, &QTextEdit::textChanged, [=]() { // 获取文本内容 QString text = textEdit->toPlainText(); // 获取每行的高度 int lineHeight = textEdit->fontMetrics().lineSpacing(); // 计算文本内容的行数 int lineCount = text.count('\n') + 1; // 计算合适的高度值 int height = lineCount * lineHeight; // 设置QTextEdit高度 textEdit->setFixedHeight(height); }); } ``` 使用上述代码,可以将`setAdaptiveHeight`函数应用到需要自适应高度QTextEdit控件上,当文本内容发生变化时,QTextEdit高度会自动调整以适应文本内容的显示。
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

草上爬

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值