首页 > 其他分享 >【鸿蒙 HarmonyOS】尺寸设置:size/layoutWeight/constraintSize

【鸿蒙 HarmonyOS】尺寸设置:size/layoutWeight/constraintSize

时间:2024-06-22 20:56:25浏览次数:23  
标签:constraintSize width height HarmonyOS 尺寸 layoutWeight 文本 size

一、背景

常见尺寸:width(宽度)、height(高度)、padding(内边距)、margin(外边距)

主要整理下size(设置高宽尺寸)、layoutWeight(对子组件进行重新布局)、constraintSize(设置约束尺寸,组件布局时,进行尺寸范围限制)

二、size:设置高宽尺寸

可以通过size来设置宽高尺寸,当然也可以直接给组件设置宽和高尺寸

Row().size({ width: '100%', height: '100%' }).backgroundColor(Color.Yellow)

三、layoutWeight:对子组件进行重新布局

父容器尺寸确定时,设置了layoutWeight属性的子元素与兄弟元素占主轴尺寸按照权重进行分配,忽略元素本身尺寸设置,表示自适应占满剩余空间。

默认值:0

说明:

仅在Row/Column/Flex布局中生效。

可选值为大于等于0的数字,或者可以转换为数字的字符串。

3.1、示例代码 

@Entry
@Component
struct SizeExample {
  build() {
    Row() {
      // 权重1,占主轴剩余空间1/3
      Text('好物推荐')
        .size({ width: '30%', height: 110 }).backgroundColor(0xFFEFD5).textAlign(TextAlign.Center)
        .layoutWeight(1)
      // 权重2,占主轴剩余空间2/3
      Text('每周更新')
        .size({ width: '30%', height: 110 }).backgroundColor(0xF5DEB3).textAlign(TextAlign.Center)
        .layoutWeight(2)
      // 未设置layoutWeight属性,组件按照自身尺寸渲染
      Text('清仓5折起')
        .size({ width: '30%', height: 110 }).backgroundColor(0xD2B48C).textAlign(TextAlign.Center)
    }.size({ width: '90%', height: 140 }).backgroundColor(0xAFEEEE)
  }
}

3.2、实现效果:

 

四、constraintSize:设置约束尺寸,组件布局时,进行尺寸范围限制

4.1、使用场景

在固定容器内包含文本和图标,图标跟在文本后面一行展示,其中文本的内容不是固定的,当文本内容少时文本和图标会在固定容器内,但当文本内容多时整体会挤出固定容器外。

需要实现的效果是:不管文本内容多少,文本和图标都能在容器内,不操出

4.1.1、场景一:当文本少时,文本和图标都在固定容器内

4.1.2、场景二:当文本多时,文本和图标会操出固定容器外

4.2、示例代码:

@Entry
@Component
struct SizeExample {
  build() {
    Row() {
      Text('jkdjksjdkshhhkdhjsdhkshdsjkdhjs')
        .maxLines(1)
        .textOverflow({ overflow: TextOverflow.Ellipsis })
      Image($r('app.media.startIcon')).width(20).margin({ left: 10 })
    }.backgroundColor(Color.Orange).width(150).margin(50).padding(10)
  }
}

4.3、使用场景解决方法

不管文本内容多少,文本和图标都能在容器内;给Text添加constraintSize属性

设置约束尺寸。constraintSize的优先级高于Width和Height。取值结果参考constraintSize取值对width/height影响。

默认值:

{ minWidth: 0,maxWidth: Infinity,minHeight: 0,maxHeight: Infinity }

单位:vp

标签:constraintSize,width,height,HarmonyOS,尺寸,layoutWeight,文本,size
From: https://blog.csdn.net/weixin_71403100/article/details/139887501

相关文章

  • HarmonyOS简介
    随着万物互联时代的开启,应用的设备底座将从几十亿手机扩展到数百亿IoT设备。全新的全场景设备体验,正深入改变消费者的使用习惯。同时应用开发者也面临设备底座从手机单设备到全场景多设备的转变,通过全场景多设备作为全新的底座,为消费者带来万物互联时代更为高效、便捷的体验。......
  • 【鸿蒙实战开发】HarmonyOS-ArkUI教程@link装饰器双向数据传递的使用
    前言2024年可谓至关重要,而生态建设的前提,就是要有足够的开发人才。与之对应的,今年春招市场上与鸿蒙相关岗位和人才旺盛的热度,一方面反应了鸿蒙生态的逐渐壮大,另一方面也让人们对鸿蒙下一阶段的发展更具信心。随着鸿蒙市场份额的不断提升,相应的岗位也会迎来一个爆发式的......
  • 【鸿蒙实战教程】HarmonyOS中的动态import和静态import的概念与区别
    什么是import鸿蒙核心语言是ArkTs,基于TS的扩展,所以里边少不了JS引擎的影子。    对于鸿蒙而言,我们在文件中引入其他文件时,会涉及到两个概念,静态import和动态import。    什么是引入其他文件呢?例如:import{TestA}from'./TestA'import{hilog}from'@kit......
  • HarmonyOS期末项目——作业清单(四)通用工具类
    系列文章目录HarmonyOS期末项目——作业清单(一)项目介绍和应用主页面设计https://blog.csdn.net/Ababx/article/details/139802283?spm=1001.2014.3001.5501HarmonyOS期末项目——作业清单(二)任务创建与编辑https://blog.csdn.net/Ababx/article/details/139807656?spm=1001.20......
  • 2024-06-20 HarmonyOs开发初体验
    2024华为开发者大会将于东莞松山湖举行,为此,特写此文。记录自己第一天入坑鸿蒙开发。鸿蒙开发简述:鸿蒙开发是指针对华为开发的一款全场景分布式操作系统的应用、服务和功能的开发工作,该操作系统名为鸿蒙,英文名为HarmonyOs。官网地址:https://hmxt.org/开发工具下载:https://hmxt.......
  • HarmonyOS NEXT - 从TypeScript到ArkTS的适配指导
    一:ArkTS语法适配背景二:从TypeScript到ArkTS的适配规则三:适配指导案例ArkTS语法适配背景 ArkTS在保持TypeScript(简称TS)基本语法风格的基础上,进一步通过规范强化静态检查和分析,使得在程序开发期能检测更多错误,提升程序稳定性,并实现更好的运行性能。本文将进一步解释为什么......
  • HarmonyOS NEXT - ArkTS语言 - 模块、关键字、空安全
    模块程序可划分为多组编译单元或模块。每个模块都有其自己的作用域,即,在模块中创建的任何声明(变量、函数、类等)在该模块之外都不可见,除非它们被显式导出。与此相对,从另一个模块导出的变量、函数、类、接口等必须首先导入到模块中。导出可以使用关键字export导出顶层的声明......
  • HarmonyOS个人项目第一周遇到的问题(第二周发的,忘记得发博客了)
    项目介绍:在浏览官方文档的时候看到可以将图片旋转,所以在考虑是不是可以做一个类似于拼图的小游戏(不是不想做难的,主要是菜,边学边做)问题描述看的官方文档不会用,因为一开始看到的不是图片的属性是一个看不懂的东西里面的原因分析:就是单纯找错命令了解决方案:在百度......
  • HarmonyOS开发从入门到跨平台系列:深入了解鸿蒙项目的核心结构
    前言深圳已经发了2024年关于鸿蒙软件生态的规划,如果目标达到,过几年很有可能出现iOSAndroid鸿蒙三足鼎立的情况,因此我们客户端程序员有必要储备一下鸿蒙知识。接下来我将分几篇文章介绍鸿蒙开发的入门、实战和跨平台相关知识,今天这篇文章作为开篇,主要介绍一下鸿蒙开......
  • 【鸿蒙开发教程】详解HarmonyOS Next UI开发技巧
    前言根据研究机构CounterpointResearch发布的最新数据,2024年第一季度,鸿蒙OS份额由去年一季度的8%上涨至17%,iOS份额则从20%下降至16%。这意味着,华为鸿蒙OS在中国市场的份额超越苹果iOS,已成中国第二大操作系统随着鸿蒙市场份额的不断提升,相应的岗位也会迎来一个爆发式的......