黑莓 - 如何创建类似于滑动抽屉Android的布局

3
有人知道如何在黑莓中创建布局组件,使其行为类似于Android的滑动抽屉吗?
谢谢。
3个回答

0
请查看下面的源代码,其中我创建了一个管理器类。只需将您想要滑动的内容添加到该管理器中并使用它即可。根据您的需求进行更改。
package mypackage;

import net.rim.device.api.ui.Graphics;
import net.rim.device.api.ui.Manager;
import net.rim.device.api.ui.TouchEvent;
import net.rim.device.api.ui.component.Dialog;
import net.rim.device.api.ui.component.LabelField;

public class SlidingDrawer extends Manager {
    final static int STATE_VIEW = 1;
    final static int STATE_HIDE = STATE_VIEW+1;
    final static int STATE_SLIDE_DOWN = STATE_HIDE+1;
    final static int STATE_SLIDE_UP = STATE_SLIDE_DOWN+1;
    final static int MAX_NO_OF_STATES = STATE_SLIDE_UP+1;
    static int CURRENT_STATE = STATE_VIEW;
    int i = 0;
    LabelField _lbl_hero;

    public SlidingDrawer(long arg0) {
    super(arg0);
        // TODO Auto-generated constructor stub
        init();
    }

    private void init()
    {
        _lbl_hero = new LabelField("Hero testing Every thign....");
        this.add(_lbl_hero);
    }

    protected void paint(Graphics graphics) {
        // TODO Auto-generated method stub
        switch(CURRENT_STATE)
        {
            case STATE_VIEW:
                super.paint(graphics);
                break;
            case STATE_HIDE:

                break;
            case STATE_SLIDE_DOWN:
                super.paint(graphics);
                if(i<this.getHeight())
                {
                    this.getField(0).setPadding(i++, 0, 0, 0);
                    invalidate();
                }
                else
                {
                    CURRENT_STATE = STATE_HIDE;
                }
                break;
            case STATE_SLIDE_UP:
                super.paint(graphics);
                if( i > 0 )
                {
                    this.getField(0).setPadding(i--, 0, 0, 0);
                    invalidate();
                }
                else
                {
                    CURRENT_STATE = STATE_VIEW;
                }
                break;
        }
    }
    public void setState(int state)
    {
        if(state < MAX_NO_OF_STATES)
        {
            CURRENT_STATE = state;
        }
        else
            Dialog.alert("Invalid State....");
    }
    protected boolean touchEvent(TouchEvent message) {
        // TODO Auto-generated method stub
        if(CURRENT_STATE == STATE_VIEW)
        {
            i=0;
            CURRENT_STATE = STATE_SLIDE_DOWN;
            invalidate();
        }
        else if(CURRENT_STATE == STATE_HIDE)
        {
//          i = this.getField(0).getContentRect().y;
            CURRENT_STATE = STATE_SLIDE_UP;
            invalidate();
        }
        return super.touchEvent(message);
    }
    protected void sublayout(int maxWidth, int maxHeight) {
        // TODO Auto-generated method stub
        setExtent(360, 100);//Width and Height of the Childs
    }
}

请根据您的需求更改此代码并使用它。

0

我实际上还没有做过。但我认为这里最大的困难是滑动动画部分和可见性。你应该先处理滑动效果的动画,然后再处理管理器本身。

触摸设备带来了另一个困难...你必须编写滑块触摸事件,以便它遵循手势。


0

嘿,为黑莓设计这样的布局真是个绝妙的想法。这确实是一个具有挑战性的任务。我们需要使用自定义布局来完成它。 首先需要了解管理器的自定义知识。我相信我们也可以使用弹出屏幕来滑动它。在弹出屏幕上方放置管理器。 其次,使用Gusture API进行侧向滚动。 祝你好运伙计。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接