QTextEdit设计的几个知识点

   这几天在设计QTextEdit的样式时,遇到了不小的困难,网上查找相关资料也很困难,通过老大的硬核指导和QT文档的学习,找到了一些方法,记录下来与诸君共勉。
   在实际设计中,常常遇到QTextEdit内文本需要设置内边距的情况,如果文本区域不需要设置滚动条,比较简单,直接在样式表中通过以下语句设置即可:
   padding-top:20px;
   padding-left:20px;
   padding-right:20px;
   padding-bottom:20px;

这样可以设计出文本与内边框的距离;当然这样的做的缺点是在你的文本区域需要设计滚动条的时候,你会发现,滚动条也相应的向内缩进了20px,这个原因是因为,滚动条默认设计在文本内容层的右边,padding以后就挤了进来,这样就使得带有滚动条以后的文本框特别丑,而且达不到界面设计的效果,所以就放弃padding这种设计方式。
QTextCursor textStyleCursor = ui.textEdit->textCursor();
QTextBlock textStyleBlock = textStyleCursor.block();
textStyleCursor.beginEditBlock();
QTextBlockFormat textStyleFormat = textStyleCursor.blockFormat();
textStyleFormat.setLineHeight(lineH, QTextBlockFormat::FixedHeight); //设置行高
textStyleFormat.setTextIndent(textIn); //首行缩进
textStyleFormat.setLeftMargin(leftM); //左侧需要缩进的距离
textStyleFormat.setRightMargin(rightM); //右侧需要缩进的距离
textStyleCursor.setBlockFormat(textStyleFormat);
textStyleCursor.insertText(val); //传进来对应的文本参数
textStyleCursor.movePosition(QTextCursor::Start); //使内容从文本开始处开始展示
textStyleCursor.endEditBlock();
ui.textEdit->setTextCursor(textStyleCursor);
这样初始化后展示的文本左右都有缩进, 并且滚动条在最右侧,缺点是上下设置间距无反应,由于滚动区域是自动扩展的,所以还在继续探索完善,如果大家有合适的建议请在评论区赐教,感激不尽。

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值