Search code examples
javablackberryblackberry-simulator

ListField selected row breaks height of other rows


I have a ListField behaving weirdly, I don't have a lot of BB development experience but with a lot of searching on the internet I ended up with the following. I used this tutorial to do a lot of the ListField stuff.

This is the screenshot when I open the screen the first time and don't do anything else:

Screen A

This is the screenshot when I scroll down one, this has the same effect for all fields:

enter image description here

This is my implementation adjusted for my needs based on the tutorial mentioned above:

private Bitmap p1;
TableRowManager row;
Vector rows;

public ImageListField(List list) {
    /* Init & Declaration */
    setEmptyString("This ListField has No Data", DrawStyle.HCENTER);
    setCallback(this);
    setRowHeight(50);
    Font.getDefault();
    p1 = Bitmap.getBitmapResource("no-image.png");
    rows = new Vector();
    for (int x = 0; x < list.size(); ++x) {
        Event e = (Event)list.getAt(x);

        row = new TableRowManager();

        BitmapField myImageField = new BitmapField(p1);
        row.add(myImageField);
        row.add(new LabelField(e.Name,
                DrawStyle.ELLIPSIS | FOCUSABLE){

            public void paint(Graphics g) {
                g.setBackgroundColor(Color.BLACK);
                g.fillRect(0, 0, getWidth(), getHeight());
                g.setColor(Color.WHITE);
                g.clear();
                super.paint(g);
            }

        });

        if(e.DateFrom.compareTo(e.DateTo) == 0)
        {
            row.add(new LabelField(e.DateFrom,
                    DrawStyle.ELLIPSIS | FOCUSABLE){

                public void paint(Graphics g) {
                    g.setBackgroundColor(Color.BLACK);
                    g.fillRect(0, 0, getWidth(), getHeight());
                    g.setColor(Color.WHITE);
                    g.clear();
                    super.paint(g);
                }

            });
        }
        else
        {
            row.add(new LabelField(e.DateFrom + " - " + e.DateTo,
                    DrawStyle.ELLIPSIS | FOCUSABLE){

                public void paint(Graphics g) {
                    g.setBackgroundColor(Color.BLACK);
                    g.fillRect(0, 0, getWidth(), getHeight());
                    g.setColor(Color.WHITE);
                    g.clear();
                    super.paint(g);
                }

            });
        }

        if(e.TimeFrom.compareTo(e.TimeTo) == 0)
        {
            row.add(new LabelField(e.TimeFrom,
                    DrawStyle.ELLIPSIS | FOCUSABLE){

                public void paint(Graphics g) {
                    g.setBackgroundColor(Color.BLACK);
                    g.fillRect(0, 0, getWidth(), getHeight());
                    g.setColor(Color.WHITE);
                    g.clear();
                    super.paint(g);
                }

            });
        }
        else
        {
            row.add(new LabelField(e.TimeFrom + " - " + e.TimeTo,
                    DrawStyle.ELLIPSIS | FOCUSABLE){

                public void paint(Graphics g) {
                    g.setBackgroundColor(Color.BLACK);
                    g.fillRect(0, 0, getWidth(), getHeight());
                    g.setColor(Color.WHITE);
                    g.clear();
                    super.paint(g);
                }

            });
        }

        row.add(new LabelField(e.Address,
                DrawStyle.ELLIPSIS | FOCUSABLE){

            public void paint(Graphics g) {
                g.setBackgroundColor(Color.BLACK);
                g.fillRect(0, 0, getWidth(), getHeight());
                g.setColor(Color.WHITE);
                g.clear();
                super.paint(g);
            }

        });

        row.add(new LabelField("R " + e.EntranceFee,
                DrawStyle.ELLIPSIS | FOCUSABLE){

            public void paint(Graphics g) {
                g.setBackgroundColor(Color.BLACK);
                g.fillRect(0, 0, getWidth(), getHeight());
                g.setColor(Color.WHITE);
                g.clear();
                super.paint(g);
            }

        });

        rows.addElement(row);
    }
    setSize(rows.size());
}

public void drawListRow(ListField listField, Graphics graphics, int index,
        int y, int width) {
    // TODO Auto-generated method stub
    ImageListField list = (ImageListField) listField;
    TableRowManager rowManager = (TableRowManager) list.rows
            .elementAt(index);
    rowManager.drawRow(graphics, 0, y, width, 119);
}

public Object get(ListField listField, int index) {
    // TODO Auto-generated method stub
    return rows.elementAt(index).toString();
}

public int getPreferredWidth(ListField listField) {
    // TODO Auto-generated method stub
    return Graphics.getScreenWidth();
}

public int getRowHeight() {
    // TODO Auto-generated method stub
    return 119;
}

public int getRowHeight(int arg0) {
    // TODO Auto-generated method stub
    return 119;
}

public int indexOfList(ListField listField, String prefix, int start) {
    // TODO Auto-generated method stub
    return -1;
}

protected boolean trackwheelClick(int status, int time) {
    int index = getSelectedIndex();
    Dialog.inform(Integer.toString(index));
    return true;
}

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

    // Causes the fields within this row manager to be layed out then
    // painted.
    public void drawRow(Graphics g, int x, int y, int width, int height) {
        // Arrange the cell fields within this row manager.
        layout(width, height);
        // Place this row manager within its enclosing list.
        setPosition(x, y);
        // Apply a translating/clipping transformation to the graphics
        // context so that this row paints in the right area.
        g.pushRegion(getExtent());
        // Paint this manager's controlled fields.
        subpaint(g);
        g.setColor(0xFF0000);
        g.drawLine(0, height - 1, getPreferredWidth(), height - 1);
        g.drawLine(40, 0, 40, getPreferredHeight());
        // Restore the graphics context.
        g.popContext();
    }

    // Arrages this manager's controlled fields from left to right within
    // the enclosing table's columns.
    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, 75, 75);
        setPositionChild(field, 5, 5);
        // set the task name label field
        field = getField(1);
        layoutChild(field, preferredWidth, fontHeight + 2);
        setPositionChild(field, 85, 5);
        // set the list name label field
        field = getField(2);
        layoutChild(field, preferredWidth, fontHeight + 2);
        setPositionChild(field, 85, fontHeight + 6 + 5);
        // set the due time name label field
        field = getField(3);
        layoutChild(field, preferredWidth, fontHeight + 2);
        setPositionChild(field, 100, fontHeight + fontHeight + 8 + 5);

        field = getField(4);
        layoutChild(field, preferredWidth, fontHeight + 2);
        setPositionChild(field, 100, fontHeight + fontHeight + fontHeight + 10 + 5);

        field = getField(5);
        layoutChild(field, preferredWidth, fontHeight + 2);
        setPositionChild(field, 100, fontHeight + fontHeight + fontHeight + fontHeight + 12 + 5);

        setExtent(preferredWidth, getPreferredHeight());
    }

    // The preferred width of a row is defined by the list renderer.
    public int getPreferredWidth() {
        return Graphics.getScreenWidth();
    }

    // The preferred height of a row is the "row height" as defined in the
    // enclosing list.
    public int getPreferredHeight() {
        return 119;// getRowHeight();
    }


}

Any advise regarding the changing of row heights and positions would be appreciated.

BTW this is in the simulator.


Solution

  • Try setting setRowHeight(119); instead of setRowHeight(50);. Not sure if it helps, since it's not a usual application/usage of ListField in the posted code.