android自定义Gallery实现手动和自动循环滚动切换图片
2013-05-21 15:05
567 查看
实现类似腾讯视频顶栏的图片切换,网上找了下写的都不全,现在总结下我实现过程中遇到的问题:
第一个问题: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()));
好了基本问题总结完毕~
第一个问题: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()));
好了基本问题总结完毕~
相关文章推荐
- android自定义Gallery实现手动和自动循环滚动切换图片
- UIScrollView+UIPageControl+NSTimer实现图片的自动滑动以及用户可手动切换,UIPageControl可点击
- JS实现div内部的文字或图片自动循环滚动代码
- UIScrollView+UIPageControl+NSTimer实现图片的自动滑动以及用户可手动切换,UIPageControl可点击
- jQuery实现自动与手动切换的滚动新闻特效代码分享
- jquery焦点图片切换(数字标注/手动/自动播放/横向滚动)
- 原生JS—实现图片循环切换及监测鼠标滚动切换图片
- UIScrollView+UIpageControl实现图片的循环滚动切换
- UIScrollView+UIPageControl+NSTimer实现图片的自动滑动以及用户可手动切换,UIPageControl可点击
- JS实现div内部的文字或图片自动循环滚动
- 滚动视图(UIScrollView)无限无缝左右切换图片,自动顺序加逆序循环播放图片
- jQuery代码实现图片墙自动+手动淡入淡出切换效果
- UIScrollView+UIPageControl+NSTimer实现图片的自动滑动以及用户可手动切换,UIPageControl可点击
- Android使用Recyclerview实现图片水平自动循环滚动效果
- Axure之实现图片自动循环切换效果
- IOS UIScroView 实现循环滚动 实现固定相框切换图片
- Android之ViewFlipper实现手动+自动切换图片(附加动画效果)
- 网易新闻首页的实现,可以添加,移除标签,自动滚动图片,无限左右切换图片
- Android 滑动切换(首页展示,图片、新闻自动切换,循环切换,自动和手动)
- UIScrollView+UIpageControl实现图片的循环滚动切换