首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Codename one - scrollable布局限制

Codename one - scrollable布局限制
EN

Stack Overflow用户
提问于 2017-07-31 21:38:00
回答 2查看 219关注 0票数 1

我已经完成了自己版本的PropertyCross演示(在他们的演示部分中提供)。

我目前面临的问题是“最近搜索”区域的大小。虽然我有一个不可滚动的容器,但我可以很容易地定义首选高度。由于Box布局遵循首选的大小,所以一切都很好,只有一个小问题:无法滚动它并看到多个结果:

recentSearchContainer = new Container(new BoxLayout(BoxLayout.Y_AXIS)); recentSearchContainer.setPreferredH((int)(this.getContentP‌​ane().getHeight() * 0.1f));

一旦我将容器设置为可滚动,首选的高度就会被覆盖,并占用它所需的空间,从它上面的BorderLayout中心部分占用了太多的空间。

如何控制可滚动组件的首选大小?

EN

回答 2

Stack Overflow用户

发布于 2017-08-01 13:22:59

您不会操纵首选的大小。Scrollables会占用更多的空间,所以如果你需要它们占用特定的空间,你需要使用正确的布局类型,在这种情况下可能不是边框布局……

边框布局给出了北/南元素的首选高度,这可能不是你想要的。您可能需要一个网格布局,它将划分高度50/50。你可能想要一个表格布局,你可以用百分比等来定义高度。

票数 1
EN

Stack Overflow用户

发布于 2017-08-02 21:13:06

对于那些感兴趣的人,这里是解决方案:

  1. 设置一个单列和任意多行的表格布局(类似于方框布局y轴或只有北、中、南的边框布局)。
  2. 将表格布局设置为不可滚动,因此默认设置为屏幕的100%。
  3. 添加的组件高度为屏幕的高度%。
  4. 这些组件可以滚动,并且仍将遵守高度约束!

//在form对象内部,设置布局设置tl = add(tl.createConstraint().heightPercentage(15),TableLayout(3,1);tl.setGrowHorizontally(true);setScrollable(false);setLayout(tl);... //并向其添加材料( add(tl.createConstraint().heightPercentage(50),compGroup);add(tl.createConstraint().heightPercentage(35),recentSearchContainer);

就像一种护身符!

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/45417511

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档