Gallery自动循环滚动以及手动滚动的平滑切换

@Gallery配合dot使用时,如果放在RelativeLayout中,则手动滑动有反弹现象,其他layout没问题,现在还没弄清原因。
首先继承Gallery重写OnFling函数,去除gallery的滚动惯性

public class MyGallery extends Gallery {

    public MyGallery(Context context, AttributeSet attrs) {

        super(context, attrs);

    }

 

    private boolean isScrollingLeft(MotionEvent e1, MotionEvent e2) {

        return e2.getX() > e1.getX();

    }  

    @Override

    public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX,

            float velocityY) {

        int keyCode;

        //这样能够实现每次滑动只滚动一张图片的效果

        if (isScrollingLeft(e1, e2)) {

            keyCode = KeyEvent.KEYCODE_DPAD_LEFT;

        } else {

            keyCode = KeyEvent.KEYCODE_DPAD_RIGHT;

        }

        onKeyDown(keyCode, null);

        return true;

    }

}

@注 OnFling直接返回false也能实现类似效果,但那样需要滑动很大距离,图片才会切换,用户体验不好

 

第二步,构造adapter

要想平滑的实现循环滚动,可以让getCount返回一个很大的值,这样gallery就认为是有多个item,item之间的切换动画是平滑的

public class GalleryAdapter extends BaseAdapter {

 

    private LayoutInflater mInflater;

    private Context mContext;

    private int width;

    private int count;

    private int[] mImageIds;

 

    public GalleryAdapter(Context context, int[] ids) {

        mContext = context;

        mImageIds = ids;

        mInflater = LayoutInflater.from(mContext);

        DisplayMetrics dm = mContext.getApplicationContext().getResources()

                .getDisplayMetrics();

        width = dm.widthPixels;

        count = mImageIds.length;

    }

 

    @Override

    public int getCount() {

        return Integer.MAX_VALUE;//用于循环滚动

    }

 

    @Override

    public Object getItem(int position) {

        return position;

    }

 

    @Override

    public long getItemId(int position) {

        return position;

    }

 

    @Override

    public View getView(int position, View convertView, ViewGroup parent) {

        position = position % count;

        if (convertView == null) {

            convertView = mInflater.inflate(R.layout.gallery_itemnull);

        }

        ImageView v = (ImageView) convertView.findViewById(R.id.img);

        v.setLayoutParams(new Gallery.LayoutParams(width, 200));

        v.setScaleType(ImageView.ScaleType.FIT_XY);

        v.setBackgroundResource(mImageIds[position]);

        return v;

    }

第三,实现自动滚动

由于我们还要手动滚动,所以自动滚动用单独一个进程来实现

private void startAutoScroll() {

        new Thread() {

            @Override

            public void run() {

                int count = 0; 

                while (mAutoScroll) {

                    count = 0;

                    //这段逻辑用于用户手动滑动时,停止自动滚动

                    while (count < 30) {

                        count++;

                        try {

                            Thread.sleep(100);

                        } catch (InterruptedException e) {

                            e.printStackTrace();

                        }

                        if (mOnTouch) {// 用戶手动滑动时,停止自动滚动

                            count = 0;

                        }

                    }  

                    mPosition++;

                    Message msg = mHandler.obtainMessage(SCROLLmPosition, 0);

                    mHandler.sendMessage(msg);

                }

            }

 

        }.start();

    }

 

private Handler mHandler = new Handler() {

 

        @Override

        public void handleMessage(Message msg) {

            switch (msg.what) {

            case SCROLL:

                mGallery.setSelection(msg.arg1);//进行图片切换

                break;

            }

        }

 

    };

第四 实现手动滚动

手动滚动时,要停止自动滚动,监听gallery的onTouch事件,DOWN时mOnTouch置为true,UPmOnTouch置为false即可

mGallery.setOnTouchListener(new OnTouchListener() {

 

            @Override

            public boolean onTouch(View v, MotionEvent event) {

                int action = event.getAction();

                if (action == MotionEvent.ACTION_DOWN) {

                    mOnTouch = true;

                } else if (action == MotionEvent.ACTION_UP) {

                    mOnTouch = false;

                }

                return false;

            }

 

        });

到现在我们已经可以自动滚动,手动滚动时自动滚动也会停止。

我们也许还需要加上dot提示图片滚动的位置

LinearLayout layout = (LinearLayout) findViewById(R.id.dot);

        if (mDots == null) {

            mDots = new ImageView[ids.length];

            for (int i = 0; i < ids.length; i++) {

                if (mDots[i] == null)

                    mDots[i] = new ImageView(this); 

                mDots[i].setBackgroundResource(R.drawable.banner_tab_unselected);

                layout.addView(mDots[i], new LinearLayout.LayoutParams(mWidth

                        / ids.length + 1, LayoutParams.WRAP_CONTENT));

            }

            mDots[0].setBackgroundResource(R.drawable.banner_tab_selected);

        }

//gallery图片切换时切换dot

mGallery.setOnItemSelectedListener(new OnItemSelectedListener() {

            @Override

            public void onItemSelected(AdapterView<?> arg0, View view,

                    int position, long arg3) {

                mDotPosition = position % ids.length;

                mDots[mDotPosition]

                        .setBackgroundResource(R.drawable.banner_tab_selected);

                if (mDotPosition != mPreDotPosition)

                    mDots[mPreDotPosition]

                            .setBackgroundResource(R.drawable.banner_tab_unselected);

                mPreDotPosition = mDotPosition;

            } 

            @Override

            public void onNothingSelected(AdapterView<?> arg0) {                               

            }           

        });

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值