如何创建与BlackBerry facebook相同风格的列表字段?

时间:2010-05-31 19:42:08

标签: blackberry user-interface

如何创建与Black Berry facebook相同风格的列表字段? RIM列表字段只包含文本,我想创建列表字段,可以包含其他字段,如图像,文本区域和href链接。

我设法创建它,它工作正常,但列表项中的字段永远不会获得焦点,任何想法如何做?

public class RichListField extends ListField implements ListFieldCallback {
private Vector rows;


public RichListField(String emtpyString, RichListItem[] items) {
    super(0, ListField.MULTI_SELECT);
    setRowHeight(80);
    setEmptyString(emtpyString, DrawStyle.HCENTER);
    setCallback(this);

    rows = new Vector();

    for (int i = 0; i < items.length; i++) {
        TableRowManager row = new TableRowManager();

        row.add(new BitmapField(items[i].getBitmap()));

        LabelField itemLabel = new LabelField(items[i].getLabel(),
                DrawStyle.ELLIPSIS);
        // mark selected
        // itemLabel.setFont(Font.getDefault().derive(
        // Font.BOLD | Font.UNDERLINED));

        itemLabel.setFont(Font.getDefault().derive(Font.BOLD));
        row.add(itemLabel);

        // SET THE LIST Item description
        row.add(new LabelField(items[i].getDescription(),
                DrawStyle.ELLIPSIS) {
            protected void paint(Graphics graphics) {
                graphics.setColor(0x00878787);
                super.paint(graphics);
            }
        });


        row.add(items[i].getLink());
        rows.addElement(row);
    }
    setSize(rows.size());

}


public void drawListRow(ListField listField, Graphics g, int index, int y,
        int width) {
    RichListField list = (RichListField) listField;
    TableRowManager rowManager = (TableRowManager) list.rows
            .elementAt(index);
    rowManager.drawRow(g, 0, y, width, list.getRowHeight());
}

private class TableRowManager extends Manager {
    public TableRowManager() {
        super(0);
    }


    public void drawRow(Graphics g, int x, int y, int width, int height) {
        // Arrange the cell fields within this row manager.
        layout(width, height);

        setPosition(x, y);


        g.pushRegion(getExtent());

        subpaint(g);

        g.setColor(0x00CACACA);
        g.drawLine(0, 0, getPreferredWidth(), 0);

        // Restore the graphics context.
        g.popContext();
    }



    protected void sublayout(int width, int height) {
        // set the size and position of each field.
        int fontHeight = Font.getDefault().getHeight();
        int preferredWidth = getPreferredWidth();

        // start with the Bitmap Field of the priority icon
        Field field = getField(0);
        layoutChild(field, 32, 32);
        setPositionChild(field, 0, 0);

        // set the   label field
        field = getField(1);
        layoutChild(field, preferredWidth - 16, fontHeight + 1);
        setPositionChild(field, 34, 3);

        // set the description label field
        field = getField(2);
        layoutChild(field, preferredWidth, fontHeight + 1);
        setPositionChild(field, 34, fontHeight + 6);

        // set the Href field
        field = getField(3);
        layoutChild(field, 150, fontHeight + 1);
        setPositionChild(field, preferredWidth - 152, fontHeight + 6);

        //To set the required dimensions for the field
        setExtent(preferredWidth, getPreferredHeight());
    }


    public int getPreferredWidth() {
        return Display.getWidth();
    }

    public int getPreferredHeight() {
        return getRowHeight();
    }
}

public Object get(ListField listField, int index) {

    return null;
}

public int getPreferredWidth(ListField listField) {

    return 0;
}

public int indexOfList(ListField listField, String prefix, int start) {

    return 0;
}

}

公共类RichListItem {     私有字符串标签;     私有位图位图;     私有字符串描述;     私人HrefField链接;

public String getLabel() {
    return label;
}

public void setLabel(String label) {
    this.label = label;
}

public Bitmap getBitmap() {
    return bitmap;
}

public void setBitmap(Bitmap bitmap) {
    this.bitmap = bitmap;
}

public String getDescription() {
    return description;
}

public void setDescription(String description) {
    this.description = description;
}

public HrefField getLink() {
    return link;
}

public void setLink(HrefField link) {
    this.link = link;
}

public RichListItem(String label, Bitmap bitmap, String description,
        HrefField link) {
    super();
    this.label = label;
    this.bitmap = bitmap;
    this.description = description;
    this.link = link;
}

}

2 个答案:

答案 0 :(得分:2)

当实现接口drawListRow时,您只需在ListFieldCallback添加2行代码。

if (g.isDrawingStyleSet(Graphics.DRAWSTYLE_FOCUS)) rowColor = Color.RED;
else rowColor = Color.GRAY

答案 1 :(得分:0)

如果您想要做的就是在行有焦点时更改颜色,您可以覆盖ListField.drawFocus():

protected void drawFocus(Graphics graphics, boolean on) {
    if (on) {
        graphics.setColor(focusColor);
        graphics.setBackgroundColor(focusBackgroundColor);
        super.drawFocus(graphics, on);
        /**
          You may have to play with the call to super.drawFocus() depending on
          what it actually does. For example:
          super.drawFocus(graphics, false); 
          may work better. Or you may have to draw the field yourself.
        */
    }
}