ToB企服应用市场:ToB评测及商务社交产业平台

标题: 鸿蒙Harmony应用开发—ArkTS声明式开发(通用属性:位置设置) [打印本页]

作者: 宝塔山    时间: 2024-7-21 04:41
标题: 鸿蒙Harmony应用开发—ArkTS声明式开发(通用属性:位置设置)
设置组件的对齐方式、结构方向和显示位置。
   阐明:
  从API Version 7开始支持。后续版本如有新增内容,则接纳上角标单独标记该内容的起始版本。
  align

align(value: Alignment)
设置容器元素绘制地区内的子元素的对齐方式。
卡片能力: 从API version 9开始,该接口支持在ArkTS卡片中使用。
体系能力: SystemCapability.ArkUI.ArkUI.Full
参数:
参数名类型必填阐明valueAlignment是设置容器元素绘制地区内的子元素的对齐方式。
只在Stack、Button、Marquee、StepperItem、text、TextArea、TextInput、FolderStack中生效,此中和文本相关的组件Marquee、text、TextArea、TextInput的align效果参考textAlign。
不支持textAlign属性的组件则无法设置程度方向的文字对齐。
默认值:Alignment.Center direction

direction(value: Direction)
设置容器元素内主轴方向上的结构。
卡片能力: 从API version 9开始,该接口支持在ArkTS卡片中使用。
体系能力: SystemCapability.ArkUI.ArkUI.Full
参数:
参数名类型必填阐明valueDirection是设置容器元素内主轴方向上的结构。
例:Column组件的主轴为纵轴。
默认值:Direction.Auto position

position(value: Position)
绝对定位,设置子元素左上角相对于父容器左上角偏移位置。
卡片能力: 从API version 9开始,该接口支持在ArkTS卡片中使用。
体系能力: SystemCapability.ArkUI.ArkUI.Full
参数:
参数名类型必填阐明valuePosition是绝对定位,设置子元素左上角相对于父容器左上角偏移位置。在结构容器中,设置该属性不参与父容器结构,即不占位,仅在绘制时举行位置调解。
适用于置顶显示、悬浮按钮等组件在父容器中位置固定的场景。 markAnchor

markAnchor(value: Position)
设置子元素在位置定位时的锚点。
卡片能力: 从API version 9开始,该接口支持在ArkTS卡片中使用。
体系能力: SystemCapability.ArkUI.ArkUI.Full
参数:
参数名类型必填阐明valuePosition是设置子元素在位置定位时的锚点,以元素左上角作为基准点举行偏移。通常配合position和offset属性使用,单独使用时,效果类似offset
API version 9及以前,默认值为:
{
x: 0,
y: 0
}
API version 10:无默认值。 offset

offset(value: Position)
相对定位,设置子元素相对于自身的额外偏移量。
卡片能力: 从API version 9开始,该接口支持在ArkTS卡片中使用。
体系能力: SystemCapability.ArkUI.ArkUI.Full
参数:
参数名类型必填阐明valuePosition是相对定位,设置子元素相对于自身的额外偏移量。设置该属性后,子组件正常参与父容器结构,依然会占位,在绘制时基于父容器给予的offset做一次额外的偏移。
API version 9及以前,默认值为:
{
x: 0,
y: 0
}
API version 10:无默认值。 alignRules9+

alignRules(value: AlignRuleOption)
指定设置在相对容器中子组件的对齐规则,仅当父容器为RelativeContainer时生效。
卡片能力: 从API version 9开始,该接口支持在ArkTS卡片中使用。
体系能力: SystemCapability.ArkUI.ArkUI.Full
参数:
参数名类型必填阐明valueAlignRuleOption是指定设置在相对容器中子组件的对齐规则。 AlignRuleOption对象阐明

从API version 9开始,该接口支持在ArkTS卡片中使用。
名称类型描述left{ anchor: string, align: HorizontalAlign }设置左对齐参数。
- anchor:设置作为锚点的组件的id值。
- align:设置相对于锚点组件的对齐方式。right{ anchor: string, align: HorizontalAlign }设置右对齐参数。
- anchor:设置作为锚点的组件的id值。
- align:设置相对于锚点组件的对齐方式。middle{ anchor: string, align: HorizontalAlign }设置横向居中对齐方式的参数。
- anchor:设置作为锚点的组件的id值。
- align:设置相对于锚点组件的对齐方式。top{ anchor: string, align: VerticalAlign }设置顶部对齐的参数。
- anchor:设置作为锚点的组件的id值。
- align:设置相对于锚点组件的对齐方式。bottom{ anchor: string, align: VerticalAlign }设置底部对齐的参数。
- anchor:设置作为锚点的组件的id值。
- align:设置相对于锚点组件的对齐方式。center{ anchor: string, align: VerticalAlign }设置纵向居中对齐方式的参数。bias{ horizontal: number, vertical: number }设置组件在锚点束缚下的偏移参数,其值为到左/上侧锚点的隔断与锚点间总隔断的比值。
- horizontal:程度方向上的bias值。
- vertical:垂直方向上的bias值。
- 当子组件的width可以确定并且有2个程度方向的锚点时生效。
- 当子组件的height可以确定并且有2个垂直方向的锚点时生效。
默认值:{
horizontal: 0.5,
vertical: 0.5
}。 示例

示例1

  1. // xxx.ets
  2. @Entry
  3. @Component
  4. struct PositionExample1 {
  5.   build() {
  6.     Column() {
  7.       Column({ space: 10 }) {
  8.         // 元素内容<元素宽高,设置内容在与元素内的对齐方式
  9.         Text('align').fontSize(9).fontColor(0xCCCCCC).width('90%')
  10.         Stack() {
  11.           Text('First show in bottom end').height('65%').backgroundColor(0xD2B48C)
  12.           Text('Second show in bottom end').backgroundColor(0xF5DEB3).opacity(0.9)
  13.         }.width('90%').height(50).margin({ top: 5 }).backgroundColor(0xFFE4C4)
  14.         .align(Alignment.BottomEnd)
  15.         Stack() {
  16.           Text('top start')
  17.         }.width('90%').height(50).margin({ top: 5 }).backgroundColor(0xFFE4C4)
  18.         .align(Alignment.TopStart)
  19.         // 父容器设置direction为Direction.Ltr,子元素从左到右排列
  20.         Text('direction').fontSize(9).fontColor(0xCCCCCC).width('90%')
  21.         Row() {
  22.           Text('1').height(50).width('25%').fontSize(16).backgroundColor(0xF5DEB3)
  23.           Text('2').height(50).width('25%').fontSize(16).backgroundColor(0xD2B48C)
  24.           Text('3').height(50).width('25%').fontSize(16).backgroundColor(0xF5DEB3)
  25.           Text('4').height(50).width('25%').fontSize(16).backgroundColor(0xD2B48C)
  26.         }
  27.         .width('90%')
  28.         .direction(Direction.Ltr)
  29.         // 父容器设置direction为Direction.Rtl,子元素从右到左排列
  30.         Row() {
  31.           Text('1').height(50).width('25%').fontSize(16).backgroundColor(0xF5DEB3).textAlign(TextAlign.End)
  32.           Text('2').height(50).width('25%').fontSize(16).backgroundColor(0xD2B48C).textAlign(TextAlign.End)
  33.           Text('3').height(50).width('25%').fontSize(16).backgroundColor(0xF5DEB3).textAlign(TextAlign.End)
  34.           Text('4').height(50).width('25%').fontSize(16).backgroundColor(0xD2B48C).textAlign(TextAlign.End)
  35.         }
  36.         .width('90%')
  37.         .direction(Direction.Rtl)
  38.       }
  39.     }
  40.     .width('100%').margin({ top: 5 })
  41.   }
  42. }
复制代码


示例2

  1. // xxx.ets
  2. @Entry
  3. @Component
  4. struct PositionExample2 {
  5.   build() {
  6.     Column({ space: 20 }) {
  7.       // 设置子组件左上角相对于父组件左上角的偏移位置
  8.       Text('position').fontSize(12).fontColor(0xCCCCCC).width('90%')
  9.       Row() {
  10.         Text('1').size({ width: '30%', height: '50' }).backgroundColor(0xdeb887).border({ width: 1 }).fontSize(16)
  11.           .textAlign(TextAlign.Center)
  12.         Text('2 position(30, 10)')
  13.           .size({ width: '60%', height: '30' })
  14.           .backgroundColor(0xbbb2cb)
  15.           .border({ width: 1 })
  16.           .fontSize(16)
  17.           .align(Alignment.Start)
  18.           .position({ x: 30, y: 10 })
  19.         Text('3').size({ width: '45%', height: '50' }).backgroundColor(0xdeb887).border({ width: 1 }).fontSize(16)
  20.           .textAlign(TextAlign.Center)
  21.         Text('4 position(50%, 70%)')
  22.           .size({ width: '50%', height: '50' })
  23.           .backgroundColor(0xbbb2cb)
  24.           .border({ width: 1 })
  25.           .fontSize(16)
  26.           .position({ x: '50%', y: '70%' })
  27.       }.width('90%').height(100).border({ width: 1, style: BorderStyle.Dashed })
  28.       // 相对于起点偏移,其中x为最终定位点距离起点水平方向间距,x>0往左,反之向右。
  29.       // y为最终定位点距离起点垂直方向间距,y>0向上,反之向下
  30.       Text('markAnchor').fontSize(12).fontColor(0xCCCCCC).width('90%')
  31.       Stack({ alignContent: Alignment.TopStart }) {
  32.         Row()
  33.           .size({ width: '100', height: '100' })
  34.           .backgroundColor(0xdeb887)
  35.         Text('text')
  36.           .fontSize('30px')
  37.           .textAlign(TextAlign.Center)
  38.           .size({ width: 25, height: 25 })
  39.           .backgroundColor(Color.Green)
  40.           .markAnchor({ x: 25, y: 25 })
  41.         Text('text')
  42.           .fontSize('30px')
  43.           .textAlign(TextAlign.Center)
  44.           .size({ width: 25, height: 25 })
  45.           .backgroundColor(Color.Green)
  46.           .markAnchor({ x: -100, y: -25 })
  47.         Text('text')
  48.           .fontSize('30px')
  49.           .textAlign(TextAlign.Center)
  50.           .size({ width: 25, height: 25 })
  51.           .backgroundColor(Color.Green)
  52.           .markAnchor({ x: 25, y: -25 })
  53.       }.margin({ top: 25 }).border({ width: 1, style: BorderStyle.Dashed })
  54.       // 相对定位,x>0向右偏移,反之向左,y>0向下偏移,反之向上
  55.       Text('offset').fontSize(12).fontColor(0xCCCCCC).width('90%')
  56.       Row() {
  57.         Text('1').size({ width: '15%', height: '50' }).backgroundColor(0xdeb887).border({ width: 1 }).fontSize(16)
  58.           .textAlign(TextAlign.Center)
  59.         Text('2  offset(15, 30)')
  60.           .size({ width: 120, height: '50' })
  61.           .backgroundColor(0xbbb2cb)
  62.           .border({ width: 1 })
  63.           .fontSize(16)
  64.           .align(Alignment.Start)
  65.           .offset({ x: 15, y: 30 })
  66.         Text('3').size({ width: '15%', height: '50' }).backgroundColor(0xdeb887).border({ width: 1 }).fontSize(16)
  67.           .textAlign(TextAlign.Center)
  68.         Text('4 offset(-5%, 20%)')
  69.           .size({ width: 100, height: '50' })
  70.           .backgroundColor(0xbbb2cb)
  71.           .border({ width: 1 })
  72.           .fontSize(16)
  73.           .offset({ x: '-5%', y: '20%' })
  74.       }.width('90%').height(100).border({ width: 1, style: BorderStyle.Dashed })
  75.     }
  76.     .width('100%').margin({ top: 25 })
  77.   }
  78. }
复制代码


末了,有很多小伙伴不知道学习哪些鸿蒙开发技术?不知道必要重点把握哪些鸿蒙应用开发知识点?而且学习时频仍踩坑,终极浪费大量时间。以是有一份实用的鸿蒙(Harmony NEXT)资料用来跟着学习是非常有必要的。 
这份鸿蒙(Harmony NEXT)资料包含了鸿蒙开发必把握的焦点知识要点,内容包含了ArkTS、ArkUI开发组件、Stage模子、多端摆设、分布式应用开发、音频、视频、WebGL、OpenHarmony多媒体技术、Napi组件、OpenHarmony内核、Harmony南向开发、鸿蒙项目实战等等)鸿蒙(Harmony NEXT)技术知识点。
盼望这一份鸿蒙学习资料可以或许给各人带来资助,有必要的小伙伴自行领取,限时开源,先到先得~无套路领取!!
 获取这份完整版高清学习路线,请点击→纯血版全套鸿蒙HarmonyOS学习资料
鸿蒙(Harmony NEXT)最新学习路线












有了路线图,怎么能没有学习资料呢,小编也预备了一份联合鸿蒙官方发布条记整理收纳的一套体系性的鸿蒙(OpenHarmony )学习手册(共计1236页)鸿蒙(OpenHarmony )开发入门教学视频,内容包含:ArkTS、ArkUI、Web开发、应用模子、资源分类…等知识点。
获取以上完整版高清学习路线,请点击→纯血版全套鸿蒙HarmonyOS学习资料
《鸿蒙 (OpenHarmony)开发入门教学视频》


《鸿蒙生态应用开发V2.0白皮书》


《鸿蒙 (OpenHarmony)开发基础到实战手册》

OpenHarmony北向、南向开发环境搭建

 《鸿蒙开发基础》



 《鸿蒙开发进阶》



《鸿蒙进阶实战》



 获取以上完整鸿蒙HarmonyOS学习资料,请点击→纯血版全套鸿蒙HarmonyOS学习资料
总结

总的来说,华为鸿蒙不再兼容安卓,对中年程序员来说是一个挑衅,也是一个机会。只有积极应对厘革,不断学习和提拔自己,他们才华在这个厘革的时代中立于不败之地。 


免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。




欢迎光临 ToB企服应用市场:ToB评测及商务社交产业平台 (https://dis.qidao123.com/) Powered by Discuz! X3.4