【Qt QML入门】Text

news2024/11/24 18:54:24
Text组件在场景中添加格式化文本, 提供的是只读文本。文本项可以显示纯文本和富文本。

Text {
    id: txt
    text: "Hello World!"
    font.family: "Helvetica"
    font.pointSize: 24
    color: "red"
}

也可以支持部分Html格式标签

Text {
    id: txt1
    font.pointSize: 24
    text: "<b>Hello</b> <i>World!</i>"
}

implicitWidth/implicitHeight: 在没有指定width和height的时候,系统会默认使用

implicitWidth/implicitHeight,大多数Item的默认隐式大小为0x0,但Image和Text不可重写这个值

隐式宽高定义了控件中真实内容的大小,一个控件的width/height在控件初始化的时候已指定,而

implicitWidth/implicitHeight是跟随着控件包含的内容变化而变化的

contentWidth/contentHeight: 内容的宽、高

elide: 控制单行普通文本与宽度的匹配关系:

        Text.ElideLeft: 超出宽度省略左边部分

        Text.ElideRight: 超出宽度省略右边部分

        Text.ElideMiddle: 超出宽度省略中间部分

        Text {
            id: txt2
            text: "这是一段测试文本"
            width: 50         //控件的宽度
            elide: Text.ElideMiddle
            Component.onCompleted: {
                console.log("txt2.width=", txt2.width)
                console.log("txt2.implicitWidth=", txt2.implicitWidth)
                console.log("txt2.contentWidth=", txt2.contentWidth)                //只读属性:文本内容的宽度
                console.log("txt2.height=", txt2.height)
                console.log("txt2.implicitHeight=", txt2.implicitHeight)
                console.log("txt2.contentHeight=", txt2.contentHeight)              //只读属性:文本内容的高度
            }
        }

        Text {
            id: txt3
            text: "这是一段测试文本"
            width: 50         //控件的宽度
            elide: Text.ElideLeft
            Component.onCompleted: {
                console.log("txt3.width=", txt3.width)
                console.log("txt3.implicitWidth=", txt3.implicitWidth)
                console.log("txt3.contentWidth=", txt3.contentWidth)                //只读属性:文本内容的宽度
                console.log("txt3.height=", txt3.height)
                console.log("txt3.implicitHeight=", txt3.implicitHeight)
                console.log("txt3.contentHeight=", txt3.contentHeight)              //只读属性:文本内容的高度
            }
        }

        Text {
            id: txt4
            text: "这是一段测试文本"
            width: 50         //控件的宽度
            elide: Text.ElideRight
            Component.onCompleted: {
                console.log("txt4.width=", txt4.width)
                console.log("txt4.implicitWidth=", txt4.implicitWidth)
                console.log("txt4.contentWidth=", txt4.contentWidth)                //只读属性:文本内容的宽度
                console.log("txt4.height=", txt4.height)
                console.log("txt4.implicitHeight=", txt4.implicitHeight)
                console.log("txt4.contentHeight=", txt4.contentHeight)              //只读属性:文本内容的高度
            }
        }

leftPadding/rightPadding/bottomPadding/topPadding:contentWidth和contentHeight 之外的

填充空间

为了方便演示,我们给文本加一个边框:

        Text {
            id: txt5
            text: "这是一段测试文本"
            font.pointSize: 24
            leftPadding: 10
            rightPadding: 10
            bottomPadding: 10
            topPadding: 10
            Rectangle {
                anchors.fill: parent
                color: "transparent"
                border.width: 1
                border.color: "red"
            }
        }

effectiveHorizontalAlignment: 查询文本的对齐方式

horizontalAlignment:
    Text.AlignLeft:
    Text.AlignRight:
    Text.AlignHCenter:
    Text.AlignJustify:

verticalAlignment:
    Text.AlignTop:
    Text.AlignBottom:
    Text.AlignVCenter:

对于单行文本,文本的大小是文本的面积。在这种常见情况下,所有对齐都是等效的。如果您想让

文本居中,那么您需要修改Item::anchor,

或者将horizontalAlignment设置为Text.AlignHCenter并将宽度绑定到父元素的宽度

文本居中

文本左对齐

文本右对齐

文本水平居中

文本顶部对齐

文本底部对齐

文本垂直居中

        Rectangle {
            width: 300
            height: 100
            color: "transparent"
            border.width: 1
            border.color: "red"

            Text {
                id: txt6
                text: "这是一段测试文本"
                font.pointSize: 24
                width: parent.width
                height: parent.height
//                anchors.centerIn: parent                   //基于父控件居中
                horizontalAlignment: Text.AlignLeft      //左对齐
//                horizontalAlignment: Text.AlignHCenter   //水平居中对齐
                //horizontalAlignment: Text.AlignJustify     //自适应
//                verticalAlignment: Text.AlignTop           //顶部对齐
//                verticalAlignment: Text.AlignBottom          //底部对齐
//                verticalAlignment: Text.AlignVCenter         //垂直居中
                Component.onCompleted: {
                    console.log("effectiveHorizontalAlignment=", effectiveHorizontalAlignment) 
                }
            }
        }
                      

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/745568.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

python_day6_异常与包机制

异常 try:可能出现异常的代码 except:若出现异常执行的代码 try:f open("D:/linux.txt", "r", encoding"utf-8")f.readlines() except:print("出现异常了&#xff0c;文件不存在&#xff0c;更换模式w")# f open("D:/linux.txt…

欧姆龙以太网口怎么和电脑连接

捷米特JM-ETH-CP以太网通讯处理器用于欧姆龙 CP1L/ CP1E/ CP1H 系列 PLC 的以太网数据采集&#xff0c;捷米特JM-ETH-CP以太网模块不占用 PLC 通讯口&#xff0c;即编程软件/上位机软件通过以太网对 PLC 数据监控的同时&#xff0c;触摸屏可以通过复用接口与 PLC 进行通讯。支持…

【国密】SM3密码杂凑算法(附源码分析)

一、前言 SM3 算法是中国国家密码管理局于 2010 年发布的一种密码杂凑算法&#xff0c;广泛地应用于数据的完整性校验、数字签名、消息认证码、密钥交换和数据加密等。密码杂凑算法需要满足三种基本属性&#xff1a;抗原像攻击、抗第二原像攻击、抗碰撞攻击&#xff0c;这三种…

【动手学习深度学习--逐行代码解析合集】14多输入多输出通道

【动手学习深度学习】逐行代码解析合集 14多输入多输出通道 视频链接&#xff1a;动手学习深度学习–多输入多输出通道 课程主页&#xff1a;https://courses.d2l.ai/zh-v2/ 教材&#xff1a;https://zh-v2.d2l.ai/ 1、多输入通道 import torch from d2l import torch as d2l …

[C语言][小游戏][猜拳游戏]

C语言的奇妙旅行 一、模块化编程二、游戏基本设计2.1 确定计算机要出的手势2.2 显示“石头剪刀布”&#xff0c;然后玩家输入自己要出的手势2.3进行输赢判断&#xff0c;显示结果2.4询问是否继续2.5 基本程序 三、游戏实现的过程3.1将玩家的手势和电脑的手势显示出来 三、总代码…

复习java基础

复习一天有点忘了的知识&#xff1a; 结构化编程 结构化程式设计(英语:Structured programming)是1960年代开始发展起来的一种编程典范。它采用子程序、程式码区块、for循环以及while循环等结构来取代传统的goto。 指导思想 自顶向下、逐步求精、模块化 编程过程 流程图是…

CVPR 2023 | OVSeg: Open-Vocabulary Semantic Segmentation with Mask-adapted CLIP

CVPR 2023 | OVSeg: Open-Vocabulary Semantic Segmentation with Mask-adapted CLIP 论文&#xff1a;https://arxiv.org/abs/2210.04150代码&#xff1a;https://github.com/facebookresearch/ov-seg 架构设计 类别无关的 mask proposal generator&#xff1a;MaskFormer手动…

linux端口被占用 关闭端口

1.查看端口是否被占用 netstat -anp |grep [端口号]2.查看占用的进程 lsof -i:[端口号]3.关闭进程 kill -9 [进程PID]LISTEN 表示被占用&#xff0c;3061/java 分别是&#xff1a;进程PID/进程 通过进程PID关闭进程

桥接模式:解耦抽象与实现

桥接模式是一种结构型设计模式&#xff0c;它将抽象部分与实现部分分离&#xff0c;使它们可以独立地变化。本文将深入探讨桥接模式的原理、结构和使用方法&#xff0c;并通过详细的 Java 示例代码来说明。 1. 桥接模式的定义 桥接模式是一种将抽象部分与实现部分分离的设计模…

数字信号处理复习知识点

目录 第一章&#xff1a;时域离散系统 1.什么是因果性和稳定性 2.模拟频率&#xff0c;模拟角频率&#xff0c; 数字频率之间的关系 3.什么是频谱混叠&#xff1f; 第二章&#xff1a;时域离散信号和系统的频域分析 1.时域离散信号傅立叶变换的定义 2.如何用模拟信号的傅立…

电信青年员工踏上三千里数字化追梦之旅,数字员工为电信高质量发展注智赋能

导语&#xff1a; 近年来&#xff0c;广西电信紧紧围绕集团战略&#xff0c;聚焦产业数字化发展机遇&#xff0c;加强前瞻性技术研究和人工智能产业应用研究&#xff0c;为夯实高质量发展增添科技动力。 在数字中国建设的大背景下&#xff0c;广西电信全资子公司广西壮族自治区…

推荐一款适合前端宝宝体质的数据库文档工具

先看效果 首页 安心食用 npx dbshowlatest按照提示输入相关信息 Welcome to the DB Show! v0.0.7? Use config from local? no ? Select a database type MySQL ? Enter the host name localhost ? Enter the port number 3306 ? Enter the user name root ? Ente…

Linux slab 分配器源码解析

文章目录 前言一、slab分配器1.1 简介1.2 高速缓存描述符1.3 架构图 二、相关结构体2.1 struct array_cache2.2 struct kmem_list32.3 struct slab2.3.1 简介2.3.2 OFF_SLAB 三、创建和释放slab3.1 创建slab3.1.1 kmem_getpages3.1.2 alloc_slabmgmt3.1.3 slab_map_pages 3.2 释…

常用数据分类算法原理介绍、优缺点分析与代码实现[LR/RF/DT/SVM/NavieBayes/GBDT/XGBoost/DNN/LightGBM等]

本文的主要目的是总结记录日常学习工作中常用到的一些数据分类算法&#xff0c;对其原理简单总结记录&#xff0c;同时分析对应的优缺点&#xff0c;以后需要的时候可以直接翻看&#xff0c;避免每次都要查询浪费时间&#xff0c;欢迎补充。 机器学习领域中常用的分类模型包括以…

分布式事物【Seata实现、下载启动Seata服务、搭建聚合父工程构建】(四)-全面详解(学习总结---从入门到深化)

目录 分布式事物解决方案_XA方案 分布式事物解决方案_Seata实现 Seata提供XA模式实现分布式事务_业务说明 Seata提供XA模式实现分布式事务_下载启动Seata服务 Seata提供XA模式实现分布式事务_搭建聚合父工程构建 创建工程distribute-transaction 字符编码 注解生效激活 Jav…

three js模型旋转

如何让立方体模型旋转到指定的面 父页面 <b-modal ref"modal_mini" size"lg" centered static :hide-footer"true":dialog-class"[modal_mini]":content-class"position-static":body-class"p-0":header-class…

上海亚商投顾:沪指放量调整 两市超4000只个股下跌

上海亚商投顾前言&#xff1a;无惧大盘涨跌&#xff0c;解密龙虎榜资金&#xff0c;跟踪一线游资和机构资金动向&#xff0c;识别短期热点和强势个股。 市场情绪 沪指今日震荡调整&#xff0c;深成指、创业板指午后跌超1%。AI概念股集体下挫&#xff0c;CPO、算力等方向领跌&am…

感知网络安全态势是什么?感知网络安全态势如何实施

网络安全是当今社会中一个非常重要的话题。随着互联网的普及和信息技术的发展&#xff0c;网络安全问题日益突出。为了有效应对各种网络威胁和攻击&#xff0c;网络安全态势感知成为了一种关键的技术手段。 网络安全态势感知的定义 网络安全态势感知是指通过对网络环境中的各种…

2023-07-11力扣每日一题

链接&#xff1a; https://leetcode.cn/problems/maximum-alternating-subsequence-sum/ 题意&#xff1a; 给定一个数组&#xff0c;求一个子序列&#xff0c;使这个子序列的奇数位和-偶数位和最大&#xff08;下标从1开始的话|反正第一个数是&#xff09; 解&#xff1a;…

基于linux下的高并发服务器开发(第一章)-Linux环境开发搭建1.1

1、安装虚拟机 2、在虚拟机中安装Linux系统 &#xff08;1&#xff09;新建虚拟机向导 点击虚拟机设置&#xff0c;使用ISO映像文件(M) &#xff08;2&#xff09;Ubuntu18安装 点击现在安装 点击继续 静静地接下来的安装即可 安装好后&#xff0c;安装VMware Tools 将压缩…