![Hello HarmonyOS!:鸿蒙应用开发从入门到精通](https://wfqqreader-1252317822.image.myqcloud.com/cover/437/43738437/b_43738437.jpg)
上QQ阅读APP看本书,新人免费读10天
设备和账号都新为新人
2.2.6 AdaptiveBoxLayout
AdaptiveBoxLayout 是自适应盒子布局,可以根据所盛放的组件大小进行自适应,使用起来非常灵活,在一定程度上可以用于解决不同尺寸、不同分辨率设备上的页面适配问题。不同的设备由于尺寸、分辨率不同,如果使用同一套布局往往会产生意想不到的效果。
![](https://epubservercos.yuewen.com/0FFABF/23020655009774306/epubprivate/OEBPS/Images/42868_117_2.jpg?sign=1739342516-asVp0jziVvFgl06cB5zMKBsULbQwdYSg-0-3459cac5bdf33c13df0af48497cbf9ab)
图2-29 PositionLayout的示例
下面实现一个 AdaptiveBoxLayout,分别在电视和手机上进行显示。
<?xml version="1.0" encoding="utf-8"?>
![](https://epubservercos.yuewen.com/0FFABF/23020655009774306/epubprivate/OEBPS/Images/42868_118_1.jpg?sign=1739342516-uylGJRpmiiZEvGTT2PJIg8wQBIAkM4su-0-f464230bd9ec48ca97165e43860eafb9)
![](https://epubservercos.yuewen.com/0FFABF/23020655009774306/epubprivate/OEBPS/Images/42868_119_1.jpg?sign=1739342516-CsD1I8oL4EZCLYeuTGsFeDcY4cCnG1lZ-0-d3b2d38d898bde841bf50c1fe9d970d5)
在电视和手机上的预览效果如图2-30所示。
![](https://epubservercos.yuewen.com/0FFABF/23020655009774306/epubprivate/OEBPS/Images/42868_119_2.jpg?sign=1739342516-niMCxgXwgeTFARtLQzkjRZVZGYNOK24L-0-705298bdd58725eff47699661779111a)
图2-30 自适应盒子布局在不同设备上的显示效果
从图2-30中可以看到,对于不同尺寸的屏幕,AdaptiveBoxLayout在水平方向上的显示变得不同,在水平方向屏幕比较宽的电视上,自适应盒子布局变成了两列,而在水平方向屏幕比较窄的手机上,则显示为1列。
在不同尺寸的屏幕上,水平方向有多少个盒子是由 AdaptiveBoxLayout 自动计算得到的。在布局中,每个盒子的宽度固定由布局总宽度除以列数得到。因为盒子的宽度是自动计算得到的,所以组件的宽度不支持match_content,但支持match_parent,即计算出来的盒子的宽度。计算规则可以自己来设定。
实现自适应盒子布局的Java代码如下。
![](https://epubservercos.yuewen.com/0FFABF/23020655009774306/epubprivate/OEBPS/Images/42868_120_1.jpg?sign=1739342516-EpTgscYma3QHOeY2F4cglSzhx7xpvcUX-0-6b9b080aa08894a1a3828aa5437fa91e)