Blackberry VerticalFieldManager с фиксированным размером: проблема с прокруткой - PullRequest
3 голосов
/ 02 ноября 2009

Я пытаюсь иметь полноэкранный интерфейс с заголовком исправления (менеджер с некоторыми полями) и прокручиваемым содержимым (список настраиваемых полей). Идея состоит в том, чтобы эмулировать некий прокручиваемый список.

Для этого я создал собственный VerticalFieldManager, который принимает maxHeight (высота экрана - высота заголовка).

У меня возникли следующие проблемы:

  • Стрелки прокрутки не отображаются (никогда)
  • В OS 4.7 (Storm) я могу прокрутить ниже, чем последний элемент, пока на моем экране не останется ничего, кроме заголовка.

Мой код нужно скомпилировать с JDE 4.2.1 и 4.7 и запустить на Pearl и Storm. (в худшем случае у меня может быть две версии этого класса)

Я подозреваю, что эти две проблемы связаны. Я, наверное, что-то не так делаю. Я посмотрел несколько примеров / форум и всегда находил подобное решение / код. Ребята, вы можете сказать мне, что я сделал не так?

/**
 *  custom class, so we can set a max height (to keep the header visible)
 */
class myVerticalFieldManager extends VerticalFieldManager{
private int maxHeight = 0;

myVerticalFieldManager(int _maxHeight){
  super(
   //this provoc an "empty scrollable zone" on Storm
   // but if you don't put it, on other OS, the vertical manager does not scroll at all.
   Manager.VERTICAL_SCROLL 

   | Manager.VERTICAL_SCROLLBAR
   ); 
  maxHeight = _maxHeight;
}


protected void sublayout(int width, int height){
        super.sublayout(width, getPreferredHeight());
        setExtent(width, getPreferredHeight());
}

public int getPreferredWidth() {
    return Graphics.getScreenWidth();
}

/**
 * allow the manager to use all the given height. (vs auto Height)
 */
public boolean forceMaxHeight = false;
public int getPreferredHeight() {
  if (forceMaxHeight) return maxHeight;
  int m = super.getPreferredHeight();
  if (m > maxHeight) m = maxHeight;
  return m;   
}    

////////////////////////////////////////////////////////////////////////////

protected boolean isUpArrowShown(){
  //TODO: does not seem to work (4.2.1 emulator & 4.5 device). (called with good return value but the arrows are not painted)
  int i = getFieldWithFocusIndex();
  //Trace("isUpArrowShown " + i);
  return i > 0;
  // note: algo not correct, cause the up arrow will be visible event when no field are hidden.
  //       but not so bad, so the user "know" that he can go up.
}

protected boolean isDownArrowShown(){
  int i = getFieldWithFocusIndex();
  return i < getFieldCount();
}

////////////////////////////////////////////////////////////////////////////
// note : since 4.6 you can use
// http://www.blackberry.com/developers/docs/4.6.0api/net/rim/device/api/ui/decor/Background.html

public int myBackgroundColor = 0xffffff;
protected void paint(Graphics g){
    g.setBackgroundColor(myBackgroundColor);
    // Clears the entire graphic area to the current background
    g.clear();
    super.paint(g);
}


} 

любая помощь приветствуется.

Ответы [ 3 ]

4 голосов
/ 02 ноября 2009

так

Я пришел с этим решением для проблемы «пустой прокручиваемой зоны» в STORM это уродливо и не позволяет использовать собственный ScrollChangeListener, но работает на Pearl & Storm

implements ScrollChangeListener

 //in constructor:

  setScrollListener(null);
  setScrollListener(this);


private boolean MY_CHANGING_SCROLL = false;
public void scrollChanged(Manager manager, int newHorizontalScroll, int newVerticalScroll){
  if (!MY_CHANGING_SCROLL){
    MY_CHANGING_SCROLL = true;
    myCheckVerticalScroll();
    MY_CHANGING_SCROLL = false;
  }      
}  


protected int myMaxVerticalScrollPosition(){
  int vh = getVirtualHeight();
  int h = getHeight();
  if (vh < h ) return 0; // no scroll
  return vh - h; // don't scroll lower than limit.
}

protected void invCheckVerticalScroll() {
    int i = getVerticalScroll();
    int m = myMaxVerticalScrollPosition();
    if ( i > m){
        i = m;
        setVerticalScroll(i);
    }
}

Я все еще ищу решение проблемы со стрелками прокрутки ... Если у кого-нибудь есть идея ...

2 голосов
/ 04 ноября 2009

Вы можете использовать метод setBanner() вместо добавления для вашего заголовка. Затем вы можете добавить по умолчанию VerticalFieldManager на экран, и он будет прокручиваться нормально, но не будет скрывать заголовок. Обратите внимание, что диспетчер делегатов MainScreen является VerticalScrollManager, поэтому вам может не потребоваться второй vfm.

HorizontalFieldManager hfm = new HorizontalFieldManager();
setBanner(hfm)

add(new ButtonField("Hello 1");
add(new ButtonField("Hello 2");

...

0 голосов
/ 25 февраля 2010

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

header_img = Bitmap.getBitmapResource("header.png");
             title = new LabelField("Welcome",LabelField.FIELD_RIGHT);
             header_manager =  new HorizontalFieldManager()
             {
                 protected void paint(net.rim.device.api.ui.Graphics graphics)
                    {
                         int y = this.getVerticalScroll();                                      
                         graphics.drawBitmap( 0, y, header_img.getWidth(), header_img.getHeight(), header_img, 0, 0 );
                         graphics.setColor(Color.LEMONCHIFFON);
                         super.paint( graphics );
                    }

                     protected void sublayout(int maxWidth, int maxHeight) 
                     {                      
                        super.sublayout(Display.getWidth(), 240);

                        Field field = title;
                        layoutChild(field, title.getWidth(), title.getHeight());
                        setPositionChild(field, (Display.getWidth()/2) -10, 13);
                        setExtent(Display.getWidth(),55);

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