有人知道多列 VBox 示例吗?
只是想知道是否有人知道那里的示例,或者我可以添加到我的应用程序中的类,该类的性能类似于 VBox 但具有 2 列或更多列?
我从循环中向 VBox 添加项目,效果很好,但我希望将其分成两列:
_________________
| | |
| Item 1 | Item 2 |
| Item 3 | Item 4 |
| Item 5 | |
|________|________|
现在我只需并排设置 2 个 VBox,并将奇数项目分配给其中一个,然后即使对于另一个,但如果有一个控件自动执行此操作就好了。
编辑
请停止给我解决方法。我已经有了一个实用的解决方法。但是,如果您已经编写了一个这样做的课程,或者知道我可以在网上找到一个课程,我将非常感激。 谢谢
Just wondering if anyone knows of an example out there, or class I can add to my app that would perform like a VBox but with 2 or more columns?
I'm adding items to a VBox from a loop, and that works fine, but I want to have it split into two columns:
_________________
| | |
| Item 1 | Item 2 |
| Item 3 | Item 4 |
| Item 5 | |
|________|________|
For now I'm just going to set 2 VBoxes side by side and assign odd items to one, and even to the other, but it would be nice to have a control do this automatically.
EDIT
Please stop giving me work arounds. I already have a functional work around. But if you have already written a class that does this, or know where I can find one online I would really appreciate it.
Thanks
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
发布评论
评论(7)
我自己也有类似的问题。这就是我最终使用的:
package {
import mx.containers.HBox;
import mx.containers.VBox;
import mx.events.FlexEvent;
public class MultiColumnVBox extends HBox {
// public properties
public var columnWidth:int;
public var verticalGap:int;
public var adjustForScrollbar:Boolean;
public function MultiColumnVBox() {
super();
this.addEventListener(FlexEvent.CREATION_COMPLETE, rearrangeChildren);
}
private function rearrangeChildren(evtObj:FlexEvent):void {
// height will change whilst rearranging children, as will the Children Array
// we store them once at the start
var myHeight:int = this.height;
var children:Array = this.getChildren();
var lastIndex:int = 0;
var vBoxIndex:int = 0;
var vBox:VBox;
var totalHeight:int = -this.verticalGap + (this.adjustForScrollbar ? 16 : 0);
for(var i:int=0; i<children.length; i++) {
// resize each child and measure the height
// if you don't want it resized to the columnWidth, set the maxWidth property
children[i].width = this.columnWidth;
children[i].validateSize();
totalHeight += children[i].measuredHeight + this.verticalGap;
// if we're too tall, or we've reached the last element, move them into a VBox
if(totalHeight > myHeight || i == children.length-1) {
vBox = new VBox();
vBox.setStyle("verticalGap", this.verticalGap);
vBox.width = this.columnWidth;
// include last child if there is room
for(var j:int=lastIndex; j<(totalHeight > myHeight ? i : i+1); j++) {
vBox.addChild(children[j]);
}
this.addChildAt(vBox, vBoxIndex);
vBoxIndex += 1;
lastIndex = i;
totalHeight = -this.verticalGap + (this.adjustForScrollbar ? 16 : 0);
}
}
}
}
}
但是,最终结果略有不同。它不是将子项移动到交替的列,而是无限期地填充第一列的高度,然后是第二列,然后是第三列,依此类推。
如果您计划创建我们的类,正如您所说,类似的方法应该有效:等待 CREATION_COMPLETE 事件,然后将子级重新排列到两个 VBox 控件中。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
flexlib (http://code.google.com/p/flexlib/) 有一个可爱的 FlowContainer 容器控件将完全满足您的需求。
flexlib (http://code.google.com/p/flexlib/) has a lovely FlowContainer container control that will do exactly what you need.