将组件添加到容器

时间:2016-02-25 19:06:36

标签: layout codenameone

将代码中的一系列容器添加到GUI构建器中定义的容器时,屏幕宽度上会出现均匀间隔的水平线,与组件的任何边框无关。

app screenshot with horizontal lines behind components

这是我的代码:

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文件中定义的底部边框似乎导致奇怪的线条。当我评论那条线时,它们会消失。它不是仅在容器的底部进行渲染,而是在整个容器上进行渲染。我认为这是一个错误。

3 个答案:

答案 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文件中定义了代码。它似乎触发了一个错误,导致边框在整个容器中以均匀的间隔呈现,而不仅仅是在它的底部。