当前位置:   article > 正文

鸿蒙HarmonyOS开发实战—Java UI框架(PositionLayout&&AdaptiveBoxLayout)_鸿蒙系统开发ohos:layout_margin

鸿蒙系统开发ohos:layout_margin

PositionLayout

在PositionLayout中,子组件通过指定准确的x/y坐标值在屏幕上显示。(0, 0)为左上角;当向下或向右移动时,坐标值变大;允许组件之间互相重叠。

PositionLayout示意图

布局方式

PositionLayout以坐标的形式控制组件的显示位置,允许组件相互重叠。

  • 在layout目录下的XML文件中创建PositionLayout并添加多个组件,并通过position_x和position_y属性设置子组件的坐标。

使用PositionLayout的布局效果

 示例代码

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <PositionLayout
  3. xmlns:ohos="http://schemas.huawei.com/res/ohos"
  4. ohos:id="$+id:position"
  5. ohos:height="match_parent"
  6. ohos:width="300vp"
  7. ohos:background_element="#3387CEFA">
  8. <Text
  9. ohos:id="$+id:position_text_1"
  10. ohos:height="50vp"
  11. ohos:width="200vp"
  12. ohos:background_element="#9987CEFA"
  13. ohos:position_x="50vp"
  14. ohos:position_y="8vp"
  15. ohos:text="Title"
  16. ohos:text_alignment="center"
  17. ohos:text_size="20fp"/>
  18. <Text
  19. ohos:id="$+id:position_text_2"
  20. ohos:height="200vp"
  21. ohos:width="200vp"
  22. ohos:background_element="#9987CEFA"
  23. ohos:position_x="8vp"
  24. ohos:position_y="64vp"
  25. ohos:text="Content"
  26. ohos:text_alignment="center"
  27. ohos:text_size="20fp"/>
  28. <Text
  29. ohos:id="$+id:position_text_3"
  30. ohos:height="200vp"
  31. ohos:width="200vp"
  32. ohos:background_element="#9987CEFA"
  33. ohos:position_x="92vp"
  34. ohos:position_y="188vp"
  35. ohos:text="Content"
  36. ohos:text_alignment="center"
  37. ohos:text_size="20fp"/>
  38. </PositionLayout>

复制

设置子组件的坐标时(position_x和position_y属性),除了上述示例中的XML方式,还可以在对应的AbilitySlice中通过setPosition(int x, int y)接口设置,Java示例代码如下:

  1. Text title = (Text)findComponentById(ResourceTable.Id_position_text_1);
  2. Text content1 = (Text)findComponentById(ResourceTable.Id_position_text_2);
  3. Text content2 = (Text)findComponentById(ResourceTable.Id_position_text_3);
  4. title.setPosition(vp2px(50), vp2px(8));
  5. content1.setPosition(vp2px(8), vp2px(64));
  6. content2.setPosition(vp2px(92), vp2px(188));

复制

单位转换的方法如下:

  1. private int vp2px(float vp){
  2. return AttrHelper.vp2px(vp,this);
  3. }

复制

  • 对于超过布局本身大小的组件,超出部分将不显示。

Right组件右侧超出部分将不显示

 示例代码:

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <PositionLayout
  3. ...>
  4. ...
  5. <Text
  6. ohos:id="$+id:position_text_4"
  7. ohos:height="120vp"
  8. ohos:width="120vp"
  9. ohos:background_element="#9987CEFA"
  10. ohos:position_x="212vp"
  11. ohos:position_y="64vp"
  12. ohos:text="Right"
  13. ohos:text_alignment="center"
  14. ohos:text_size="20fp"/>
  15. </PositionLayout>

复制

AdaptiveBoxLayout

AdaptiveBoxLayout是自适应盒子布局,该布局提供了在不同屏幕尺寸设备上的自适应布局能力,主要用于相同级别的多个组件需要在不同屏幕尺寸设备上自动调整列数的场景。

  1. 该布局中的每个子组件都用一个单独的“盒子”装起来,子组件设置的布局参数都是以盒子作为父布局生效,不以整个自适应布局为生效范围。
  2. 该布局中每个盒子的宽度固定为布局总宽度除以自适应得到的列数,高度为match_content,每一行中的所有盒子按高度最高的进行对齐。
  3. 该布局水平方向是自动分块,因此水平方向不支持match_content,布局水平宽度仅支持match_parent或固定宽度。
  4. 自适应仅在水平方向进行了自动分块,纵向没有做限制,因此如果某个子组件的高设置为match_parent类型,可能导致后续行无法显示。

AdaptiveBoxLayout示意图

常用方法

AdaptiveBoxLayout布局常用方法如下。

方法

功能

addAdaptiveRule(int minWidth, int maxWidth, int columns)

添加一个自适应盒子布局规则。

removeAdaptiveRule(int minWidth, int maxWidth, int columns)

移除一个自适应盒子布局规则。

clearAdaptiveRules()

移除所有自适应盒子布局规则。

场景示例

在AdaptiveBoxLayout中添加和删除自适应盒子布局规则的效果对比如下。

 XML布局示例代码:

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <DirectionalLayout
  3. xmlns:ohos="http://schemas.huawei.com/res/ohos"
  4. ohos:height="match_parent"
  5. ohos:width="match_parent"
  6. ohos:orientation="vertical">
  7. <AdaptiveBoxLayout
  8. xmlns:ohos="http://schemas.huawei.com/res/ohos"
  9. ohos:height="0vp"
  10. ohos:width="match_parent"
  11. ohos:weight="1"
  12. ohos:id="$+id:adaptive_box_layout">
  13. <Text
  14. ohos:height="40vp"
  15. ohos:width="80vp"
  16. ohos:background_element="#EC9DAA"
  17. ohos:margin="10vp"
  18. ohos:padding="10vp"
  19. ohos:text="NO 1"
  20. ohos:text_size="18fp" />
  21. <Text
  22. ohos:height="40vp"
  23. ohos:width="80vp"
  24. ohos:background_element="#EC9DAA"
  25. ohos:margin="10vp"
  26. ohos:padding="10vp"
  27. ohos:text="NO 2"
  28. ohos:text_size="18fp" />
  29. <Text
  30. ohos:height="match_content"
  31. ohos:width="match_content"
  32. ohos:background_element="#EC9DAA"
  33. ohos:margin="10vp"
  34. ohos:padding="10vp"
  35. ohos:multiple_lines="true"
  36. ohos:text="AdaptiveBoxLayout, where a number of boxes with the same width but varied heights are laid out. The height of a row is determined by the highest box."
  37. ohos:text_size="18fp" />
  38. <Text
  39. ohos:height="40vp"
  40. ohos:width="80vp"
  41. ohos:background_element="#EC9DAA"
  42. ohos:margin="10vp"
  43. ohos:padding="10vp"
  44. ohos:text="NO 4"
  45. ohos:text_size="18fp" />
  46. <Text
  47. ohos:height="40vp"
  48. ohos:width="match_parent"
  49. ohos:background_element="#EC9DAA"
  50. ohos:margin="10vp"
  51. ohos:padding="10vp"
  52. ohos:text="Add"
  53. ohos:text_size="18fp" />
  54. <Text
  55. ohos:height="40vp"
  56. ohos:width="80vp"
  57. ohos:background_element="#EC9DAA"
  58. ohos:margin="10vp"
  59. ohos:padding="10vp"
  60. ohos:text="NO 5"
  61. ohos:text_size="18fp" />
  62. <Text
  63. ohos:height="160vp"
  64. ohos:width="80vp"
  65. ohos:background_element="#EC9DAA"
  66. ohos:margin="10vp"
  67. ohos:padding="10vp"
  68. ohos:text="NO 6"
  69. ohos:text_size="18fp" />
  70. </AdaptiveBoxLayout>
  71. <Button
  72. ohos:id="$+id:add_rule_btn"
  73. ohos:layout_alignment="horizontal_center"
  74. ohos:top_margin="10vp"
  75. ohos:padding="10vp"
  76. ohos:background_element="#A9CFF0"
  77. ohos:height="match_content"
  78. ohos:width="match_content"
  79. ohos:text_size="22fp"
  80. ohos:text="adaptiveBoxLayout.addAdaptiveRule(100, 2000, 3);"/>
  81. <Button
  82. ohos:id="$+id:remove_rule_btn"
  83. ohos:padding="10vp"
  84. ohos:top_margin="10vp"
  85. ohos:layout_alignment="horizontal_center"
  86. ohos:bottom_margin="10vp"
  87. ohos:background_element="#D5D5D5"
  88. ohos:height="match_content"
  89. ohos:width="match_content"
  90. ohos:text_size="22fp"
  91. ohos:text="adaptiveBoxLayout.removeAdaptiveRule(100, 2000, 3);"/>
  92. </DirectionalLayout>

复制

Java关键代码:

  1. AdaptiveBoxLayout adaptiveBoxLayout = (AdaptiveBoxLayout)findComponentById(ResourceTable.Id_adaptive_box_layout);
  2. findComponentById(ResourceTable.Id_add_rule_btn).setClickedListener((component-> {
  3. // 添加规则
  4. adaptiveBoxLayout.addAdaptiveRule(100, 2000, 3);
  5. // 更新布局
  6. adaptiveBoxLayout.postLayout();
  7. }));
  8. findComponentById(ResourceTable.Id_remove_rule_btn).setClickedListener((component-> {
  9. // 移除规则
  10. adaptiveBoxLayout.removeAdaptiveRule(100, 2000, 3);
  11. // 更新布局
  12. adaptiveBoxLayout.postLayout();
  13. }));

为了能够让大家跟上互联网时代的技术迭代,赶上互联网开发人员寒冬期间一波红利,在这里跟大家分享一下我自己近期学习心得以及参考网上资料整理出的一份最新版的鸿蒙学习提升资料,有需要的小伙伴自行领取,限时开源,先到先得~~~~

纯血版鸿蒙 HarmonyOS 4.0 视频学习资料

 需要以上视频学习资料小伙伴

请点击→纯血版全套鸿蒙HarmonyOS学习资料


《纯血版华为鸿蒙 (Harmony OS)开发手册》

这份手册涵盖了当前鸿蒙 (Harmony OS) 开发技术必掌握的核心知识点

纯血版鸿蒙 (Harmony OS)开发手册部分精彩内容

HarmonyOS 概念:

  • 系统定义
  • 技术架构
  • 技术特性
  • 系统安全

如何快速入门?

  • 基本概念
  • 构建第一个ArkTS应用
  • 构建第一个JS应用
  • ……


开发基础知识: 

  • 应用基础知识
  • 配置文件
  • 应用数据管理
  • 应用安全管理
  • 应用隐私保护
  • 三方应用调用管控机制
  • 资源分类与访问
  • 学习ArkTS语言
  • ……

基于ArkTS 开发:

  • Ability开发
  • UI开发
  • 公共事件与通知
  • 窗口管理
  • 媒体
  • 安全
  • 网络与链接
  • 电话服务
  • 数据管理
  • 后台任务(Background Task)管理
  • 设备管理
  • 设备使用信息统计
  • DFX
  • 国际化开发
  • 折叠屏系列
  • .……

获取以上文中提到的这份纯血版鸿蒙 (Harmony OS) 开发资料的小伙伴 

请点击→纯血版全套鸿蒙HarmonyOS学习资料


声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/繁依Fanyi0/article/detail/252633

推荐阅读
相关标签