Blackberry: создание настраиваемого поля для использования с VerticalFieldManager для репликации табличного представления - PullRequest
0 голосов
/ 22 декабря 2011

Я не знаю, выбираю ли я правильный маршрут, но я решил создать настраиваемое поле и использовать его в вертикальном диспетчере полей.

В настраиваемом поле я хочу добавить изображениеслева и текст справа.

Я только что начал, но столкнулся с некоторыми проблемами.

package mypackage;

import net.rim.device.api.ui.DrawStyle;
import net.rim.device.api.ui.Field;
import net.rim.device.api.ui.Graphics;

public class CustomEventField extends Field implements DrawStyle {

    private String title;
    private String by;
    private String date;
    private String desc;


    public CustomEventField(String title, String by, String date, String desc){
        super();
        this.title = title;
        this.by = by;
        this.date = date;
        this.desc = desc;

    }

    protected void layout(int width, int height) {
        setExtent(width,height);

    }

    protected void paint(Graphics graphics) {

        graphics.drawText(this.title, 0, 0);

        graphics.drawText(this.by, 50, 0);


    }

}

Как мне сделать drawText перейти к следующей строке изDrawText до этого?Должен ли я рассчитать высоту шрифта и добавить ее к позиции у?

1 Ответ

2 голосов
/ 22 декабря 2011

В соответствии с приведенным выше кодом это может быть невозможно, поэтому я создал один пользовательский класс, который может отображать изображение, заголовок, дату.когда вы нажимаете на элемент, появится одно диалоговое окно с его индексом, это также полезно для пользовательского представления списка

Примечание: если вы хотите попробовать следующие изображения, доступные здесь, вы просто используете PLeaseздесь

Если здесь есть какие-либо исправления, пожалуйста, дайте мне знать

class CustomListField extends HorizontalFieldManager{

        private Bitmap scale_image;
        private int width=0;
        private int height=0;
        private int background_color=0;
        private BitmapField bitmap_field;
        private boolean flag=false;
        public CustomListField(String title, Bitmap image, String date,int image_width,int image_height,int background_color){
            super(NO_HORIZONTAL_SCROLL|USE_ALL_WIDTH);
            this.background_color=background_color;
            width=image_width;
            height=image_width;
            if(image!=null){
                scale_image=new Bitmap(image_width, image_height);
                image.scaleInto(scale_image, Bitmap.FILTER_LANCZOS);
                bitmap_field=new BitmapField(scale_image);
                flag=false;
                bitmap_field.setMargin(5, 5, 5, 5);
                add(bitmap_field);
            }


            VerticalFieldManager vmanager=new VerticalFieldManager(USE_ALL_WIDTH|Field.FIELD_VCENTER){
                protected void sublayout(int maxWidth, int maxHeight) {
                    super.sublayout(Display.getWidth()-width, height);
                    setExtent(Display.getWidth()-width, height);
                }
            };
            LabelField title_lbl=new LabelField("Title: "+title,Field.NON_FOCUSABLE|DrawStyle.ELLIPSIS);
            vmanager.add(title_lbl);

            LabelField date_lbl=new LabelField("Date: "+date,Field.NON_FOCUSABLE);
            vmanager.add(date_lbl);

            Font fon=title_lbl.getFont();
            int title_height=fon.getHeight();

            Font font=date_lbl.getFont();
            int date_height=font.getHeight();
            int pad=title_height+date_height;
            title_lbl.setPadding((height-pad)/2, 0, 0, 0);
            add(vmanager);
            add(new NullField(FOCUSABLE));
        }

        protected void sublayout(int maxWidth, int maxHeight) {
            super.sublayout(Display.getWidth(), height);
            setExtent(Display.getWidth(), height);
        }
        protected void paint(Graphics graphics) {
            if(flag)
            graphics.setBackgroundColor(background_color);
            graphics.clear();
            super.paint(graphics);
        }
        protected void onFocus(int direction) {
            super.onFocus(direction);
            flag=true;
            invalidate();
        }
        protected void onUnfocus() {
            invalidate();
            flag=false;
        }
        protected boolean navigationClick(int status, int time) {

            if(Touchscreen.isSupported()){
                return false;
            }else{
                fieldChangeNotify(1);
                return true;
            }

        }
        protected boolean touchEvent(TouchEvent message) 
        {
            if (TouchEvent.CLICK == message.getEvent()) 
            {

                FieldChangeListener listener = getChangeListener();
                if (null != listener)
                    this.setFocus();
                    listener.fieldChanged(this, 1);
            }
            return super.touchEvent(message);
        }
    }

, вы можете вызывать этот класс следующим образом, передавая Bitmap, title, image_height и width и фоновый цвет

      class sampleScreen extends MainScreen implements FieldChangeListener
        {
            private CustomListField cu_field[];
            private Bitmap image=null;
            int size=8;
            public sampleScreen() {
                VerticalFieldManager vmanager=new VerticalFieldManager(VERTICAL_SCROLL|VERTICAL_SCROLLBAR){
                    protected void sublayout(int maxWidth, int maxHeight) {

                        super.sublayout(Display.getWidth(),Display.getHeight());
                        setExtent(Display.getWidth(),Display.getHeight());
                    }
                };
                cu_field=new CustomListField[size]; 
                for(int i=0;i<size;i++){
                    image=Bitmap.getBitmapResource("sample_"+i+".jpg");
cu_field[i]=new CustomListField("BlackBerry models that had a built-in mobile phone, were the first models that natively ran Java, and transmitted data over the normal 2G cellular network. RIM began to advertise these devices as email-capable mobile phones rather than as 2-way pagers.",
     image, "jan2011", 100, 100,Color.RED);
                    cu_field[i].setChangeListener(this);
                    vmanager.add(new SeparatorField());
                    vmanager.add(cu_field[i]);
                }
                add(vmanager);
            }

            public void fieldChanged(Field field, int context) {
                // TODO Auto-generated method stub
                for(int i=0;i<size;i++){
                    if(field==cu_field[i]){
                        final int k=i;
                        UiApplication.getUiApplication().invokeLater(new Runnable() {
                            public void run() {
                                Dialog.alert("You click on Item No "+k);
                            }
                        });
                    }
                }
            }
        }

Здесь вы получите вывод в виде следующего изображения

This is out put for above code

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...