自定义ViewFlipper实现手势如ViewPager效果
程序员文章站
2024-03-24 17:45:58
...
用ViewFlipper实现如相册功能一样
第一步:使用ViewFlipper控件
<ViewFlipper
android:layout_width="match_parent"
android:layout_height="match_parent"
android:id="@+id/vf_main_image"
></ViewFlipper>
第二步:因为ViewFlipper不是高级控件,需要直接加值,需要自己加值。下面会有一步步的注释
public class MainActivity extends AppCompatActivity {
private ViewFlipper vf_main_image;
private int images[]={R.drawable.s1,R.drawable.s2,R.drawable.s3};
private GestureDetector gesture;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
vf_main_image = (ViewFlipper) findViewById(R.id.vf_main_image);
//一个一个加控件
for (int i = 0; i < images.length; i++) {
ImageView iv=new ImageView(this);
iv.setImageResource(images[i]);
vf_main_image.addView(iv);
}
//实例化GestureDetector手势检测器类
//第二个参数为手势监听事件
//相册是左右滑动,所以在OnFling事件下实现
gesture = new GestureDetector(this, new GestureDetector.OnGestureListener() {
@Override
public boolean onDown(MotionEvent e) {
Log.i("test","onDown——按下");
return false;
}
@Override
public void onShowPress(MotionEvent e) {
Log.i("test","onShowPress——长按一下会调用");
}
@Override
public boolean onSingleTapUp(MotionEvent e) {
Log.i("test","onSingleTapUp——轻按");
return false;
}
@Override
public boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX, float distanceY) {
Log.i("test","onScroll——滑动");
return false;
}
@Override
public void onLongPress(MotionEvent e) {
Log.i("test","onLongPress——长按");
}
@Override
public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY) {
Log.i("test","onFling——拖动结束");
//右滑代表上一张
// e1,代表向右滑动时,按下的点
// e2代表拖动抬起的点
if(e2.getX()-e1.getX()>100){
vf_main_image.showPrevious();
// vf_main_image.setInAnimation(MainActivity.this,R.anim.left_in);
// vf_main_image.setOutAnimation(MainActivity.this,R.anim.right_out);
}
//左滑代表下一张
// e1,代表向左滑动时,按下的点
// e2代表拖动抬起的点
if(e1.getX()-e2.getX()>100){
vf_main_image.showNext();
// vf_main_image.setInAnimation(MainActivity.this,R.anim.right_in);
// vf_main_image.setOutAnimation(MainActivity.this,R.anim.left_out);
}
return false;
}
});
}
//因为有一个Activity的触摸事件,和拖动事件,那么到底调用哪一个呢
//解决方法:
//调用Activity的触摸事件时调用手势的触摸事件
@Override
public boolean onTouchEvent(MotionEvent event) {
return gesture.onTouchEvent(event);
}
}
上一篇: Homebrew的使用
下一篇: thinkPHP框架使用方法
推荐阅读
-
自定义ViewFlipper实现手势如ViewPager效果
-
Android自定义ViewPager实现个性化的图片切换效果
-
Android自定义ViewPager实现个性化的图片切换效果
-
自定义RadioButton和ViewPager实现TabHost带滑动的页卡效果
-
自定义RadioButton和ViewPager实现TabHost带滑动的页卡效果
-
Android自定义ViewFlipper实现滚动效果
-
自定义ScrollView 实现上拉下拉的回弹效果--并且子控件中有Viewpager的情况
-
自定义ViewPager实现3D画廊效果
-
Android自定义ViewFlipper实现滚动效果
-
自定义ScrollView 实现上拉下拉的回弹效果--并且子控件中有Viewpager的情况