android 自动滑动图片,android自定义Gallery实现手动和自动循环滚动切换图片

实现类似腾讯视频顶栏的图片切换,网上找了下写的都不全,现在总结下我实现过程中遇到的问题:

第一个问题:Gallery手动滑动翻页

参照网上的方法实现如下:

自定义MyGalleyry继承自Gallery 重写onFling方法

private boolean isScrollingLeft(MotionEvent paramMotionEvent1,

MotionEvent paramMotionEvent2)

{//判断向左还是向右滑动

float f2 = paramMotionEvent2.getX();

float f1 = paramMotionEvent1.getX();

if (f2 > f1)

return true;

return false;

}

public boolean onFling(MotionEvent paramMotionEvent1,

MotionEvent paramMotionEvent2, float paramFloat1, float paramFloat2)

{

int keyCode;

if (isScrollingLeft(paramMotionEvent1, paramMotionEvent2))

{

keyCode = KeyEvent.KEYCODE_DPAD_LEFT;

} else

{

keyCode = KeyEvent.KEYCODE_DPAD_RIGHT;

}

onKeyDown(keyCode, null);

return true;

}

第二个问题:Gallery自动滚动切换图片

通过Timer,TimerTask,Handler的配合使用来实现,需要注意的是gallery的setSelection(int position,boolean anima)可以实现切换但没有滑动的效果。

解决的办法可以通过onKeyDown(KeyEvent.KEYCODE_DPAD_RIGHT,null)向右滑动,和onKeyDown(KeyEvent.KEYCODE_DPAD_LEFT,null)向左滑动实现。

在使用这两个方法时需要注意的是在Gallery的xml属性配置中不能设置spacing否则无法切换,即使spacing设置成0.0dip也不行,当时这个问题困扰了我很久,使用的童鞋要切记切记。

还有在使用以上两个方法时会有点击的声音,这时只要设置Gallery的

android:soundEffectsEnabled="false"就可以了。

下面是具体实现代码:

private static final int timerAnimation = 1;

private final Handler mHandler = new Handler()

{

public void handleMessage(android.os.Message msg)

{

switch (msg.what)

{

case timerAnimation:

int position = getSelectedItemPosition();

if (position >= (getCount() - 1))

{

onKeyDown(KeyEvent.KEYCODE_DPAD_LEFT, null);

} else

{

onKeyDown(KeyEvent.KEYCODE_DPAD_RIGHT, null);

}

break;

default:

break;

}

};

};

private final Timer timer = new Timer();

private final TimerTask task = new TimerTask()

{

public void run()

{

mHandler.sendEmptyMessage(timerAnimation);

}

};

在MyGallery的构造函数里面执行timer.schedule(task, 3000, 3000);,另外在MyGallery里写一个destroy方法取消timer.cancle();在Activity的OnDestroy方法中调用就可以了。

第三个问题:Gallery循环切换问题

重写MyGallery的Adapter的getCount()方法

public int getCount( )

{

return Integer.MAX_VALUE;

}

在给图片赋值时要记得取模

例如:

imageView.setImageDrawable(imgList.get(position%imgList.size()));

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值