将代码中的一系列容器添加到GUI构建器中定义的容器时,屏幕宽度上会出现均匀间隔的水平线,与组件的任何边框无关。
这是我的代码:
public Container[] renderArticles(ArrayList<HashMap<String, Object>> articles){
Container[] artArray = new Container[articles.size()];
for (int i = 0; i < articles.size(); i++) {
final HashMap<String, Object> art = articles.get(i);
Container artCon = mStateMachine.createContainer(mStateMachine.res, "DocArticleItem");
ActionListener listen = new ActionListener() {
public void actionPerformed(ActionEvent evt) {
mStateMachine.currentArticleId = (String) art.get("id");
mStateMachine.showForm("Article", null);
}
};
Button artPic = mStateMachine.findArticlePic(artCon);
artPic.addActionListener(listen);
artPic.setIcon(mStateMachine.makeImageFromRaw((String)art.get("picture_data")));
SpanButton caption = (SpanButton)mStateMachine.findArticleTitle(artCon);
caption.setText((String) art.get("title"));
caption.addActionListener(listen);
artArray[i] = artCon;
}
return artArray;
}
public Container[] renderTips(ArrayList<HashMap<String, Object>> tips){
Container[] contArray = new Container[tips.size()];
for (int i = 0; i < tips.size(); i++) {
HashMap<String, Object> tip = tips.get(i);
Container tipCont = mStateMachine.createContainer(mStateMachine.res, "DocTipItem");
SpanLabel tipTitle = mStateMachine.findDocTipTitle(tipCont);
tipTitle.setText((String)tip.get("title"));
SpanLabel tipText = mStateMachine.findDocTipText(tipCont);
tipText.setText((String)tip.get("info"));
contArray[i] = tipCont;
}
// remove divider from last tip
Container last = contArray[contArray.length - 1];
Container line = (Container)last.getComponentAt(last.getComponentCount() - 1);
last.removeComponent(line);
return contArray;
}
final HashMap<String, Object> map = mStateMachine.expertCardInfo;
// populate tips
if (map.containsKey("tips")){
tipContainers = renderTips((ArrayList) map.get("tips"));
}else{
f.removeComponent(mStateMachine.findExpertTipsHeader(f));
f.removeComponent(mStateMachine.findExpertTipsContainer(f));
}
// populate articles
if (map.containsKey("articles")) {
articleContainers = renderArticles((ArrayList)map.get("articles"));
} else {
f.removeComponent(mStateMachine.findExpertArticlesHeader(f));
f.removeComponent(mStateMachine.findExpertArticlesContainer(f));
}
在StateMachine
:
@Override
protected void onDoctorDetails_ExpertTipsHeaderAction(Component c, ActionEvent event) {
Container cnt = findExpertTipsContainer(c.getComponentForm());
if(cnt.getComponentCount() > 0){
cnt.removeAll();
}else{
for (int i = 0;i < expRenderer.tipContainers.length;i++){
cnt.add(expRenderer.tipContainers[i]);
}
c.getComponentForm().scrollComponentToVisible(cnt);
}
}
tl; dr :它是Component.setHidden()
的手动实现,由于某种原因导致效果不佳。我根据从服务器获取的数据创建了一堆Container
,将它们粘贴在一个数组中,当单击该按钮以显示它们时,我迭代数组并添加Container
s (每个人基本上都是一个列表项)给父母Container
。
非常感谢任何正确方向的推动。
UI层次结构如下所示:
Form (BoxLayout Y)
|
- Container (FlowLayout)
|
- Container (TableLayout)
|
- Container (TableLayout)
|
- Button
|
- Label
|
- Button (populates following container)
|
- Container (BoxLayout Y - doesn't show lines)
|
- Button (populates following container)
|
- Container (BoxLayout Y - shows lines)
|
- Button (populates following container)
|
- Container (BoxLayout Y - shows lines)
最后三个容器都具有相同的UIID,它们派生自Container
并仅修改边距。不同之处在于添加到它们的容器。对于第一个我添加了一系列SpanButton
s(并且不会出现这些行)。对于另外两个,我添加了一系列预装配的容器,里面有一些内容(并且出现了线条)。后一种情况下添加的容器具有以下样式属性:
cn1-derive: Container;
margin: 0;
border-bottom: thin solid gray
我在css文件中定义的底部边框似乎导致奇怪的线条。当我评论那条线时,它们会消失。它不是仅在容器的底部进行渲染,而是在整个容器上进行渲染。我认为这是一个错误。
答案 0 :(得分:1)
在GUI Builder中检查您的容器UIID是否没有背景图像样式,以及您的表单。
答案 1 :(得分:0)
我猜你所看到的是上面代码中的“line”条目。 split = cont.IndexOf("val2:");
int val2 = Int32.Parse(cont.Substring(split + 5, 1));
只会最小化组件请求的空间,而不会实际隐藏它。使用setHidden()
真正隐藏组件。
答案 2 :(得分:0)
我在代码中添加了border-bottom
集,在css文件中定义了代码。它似乎触发了一个错误,导致边框在整个容器中以均匀的间隔呈现,而不仅仅是在它的底部。