继承ViewFlipper实现左右滑动展示以及下面华丽的点点点
来源:互联网 发布:淘宝商城童鞋 编辑:程序博客网 时间:2024/05/17 08:12
忙活了一周,今天终于闲下来了。闲来无事,把这周的一些心得拿来与大家分享。
废话不多话,直接进入主题。量表述不便,直接上图:
下面上代码:
package cn.trto1987.android.util;import java.util.List;import java.util.Timer;import java.util.TimerTask;import android.annotation.SuppressLint;import android.content.Context;import android.graphics.drawable.Drawable;import android.os.Handler;import android.os.Message;import android.util.AttributeSet;import android.util.Log;import android.view.GestureDetector;import android.view.GestureDetector.OnGestureListener;import android.view.MotionEvent;import android.view.View;import android.view.animation.AnimationUtils;import android.widget.ViewFlipper;import cn.trto1987.android.test.R;/** * public class<br/> * <b>ImageFlipper</b><br/> * extends {@link ViewFlipper}<br/> * <b>简单左右滑动图片展示,支持自动播放。</b><br/> * 相关的资源:<br/> * <blockquote> * res/anim/image_left_in.xml, * res/anim/image_left_out.xml, * res/anim/image_right_in.xml, * res/anim/image_right_out.xml * </blockquote> * @author trto1987 */public class ImageFlipper extends ViewFlipper{private List<Drawable> res;//要展示的图片资源private GestureDetector gesture;//手势private Context context;private ImageCounter imageCounter;//图片序号指示器,与本类配合使用private ImageHandler handler;//处理左右滑动的Handlerprivate boolean isBreak = false;//判断自动播放是否点击事件打断private TimerTask autoPlayTask;//定时任务,用来定时滑动public ImageFlipper(Context context) {super(context);this.context = context;this.gesture = new GestureDetector(this.context, new ImageOnGestureListener());//手势监听this.setLongClickable(true);this.setOnTouchListener(new OnTouchListener() {@Overridepublic boolean onTouch(View v, MotionEvent event) {return gesture.onTouchEvent(event);}});}public ImageFlipper(Context context, AttributeSet attrs){super(context, attrs);this.context = context;this.gesture = new GestureDetector(this.context, new ImageOnGestureListener());this.setLongClickable(true);this.setOnTouchListener(new OnTouchListener() {@Overridepublic boolean onTouch(View v, MotionEvent event) {return gesture.onTouchEvent(event);}});}/** * 设置图片资源 * @param res List<Drawable> 图片资源 */@SuppressWarnings("deprecation")public void setResources(List<Drawable> res){this.res = res;for( Drawable d : this.res ){View v = new View(context);v.setBackgroundDrawable(d);this.addView(v);}}public int size(){return res.size();}public int getIndex(){return this.getDisplayedChild();}/** * 设置序号指示器 * @param imageCounter 见{@link ImageCounter} */public void setCounter( ImageCounter imageCounter ){this.imageCounter = imageCounter;imageCounter.setCount(size());}/** * 启用自动播放 * @param breakTime 播放间隔 */public void startAutoPlay( int breakTime ){handler = new ImageHandler();Timer timer = new Timer();autoPlayTask = new TimerTask(){@Overridepublic void run() {if(!isBreak){//如果被电击事件打断,则跳过本次播放handler.sendEmptyMessage(0);} else {isBreak = false;}}};timer.schedule(autoPlayTask, breakTime, breakTime);}/** * 停止自动播放 */public void stopAutoPlay(){autoPlayTask.cancel();}@Overridepublic boolean onTouchEvent(MotionEvent event) {isBreak = true;return super.onTouchEvent(event);}@SuppressLint("HandlerLeak")class ImageHandler extends Handler{@Overridepublic void handleMessage(Message msg) {ImageFlipper.this.setInAnimation(AnimationUtils.loadAnimation(ImageFlipper.this.context, R.anim.image_left_in));//滑动动画ImageFlipper.this.setOutAnimation(AnimationUtils.loadAnimation(ImageFlipper.this.context, R.anim.image_left_out));ImageFlipper.this.showNext();//展示下一张if( ImageFlipper.this.imageCounter != null ){ImageFlipper.this.imageCounter.showNext(ImageFlipper.this.getIndex());//配置了图片序号指示器,相应的变化}super.handleMessage(msg);}}class ImageOnGestureListener implements OnGestureListener{@Overridepublic boolean onDown(MotionEvent e) { return false; }@Overridepublic boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX,float velocityY) {Log.e("flipper", "fling");if( e1.getX()-e2.getX() > 120 ){ImageFlipper.this.setInAnimation(AnimationUtils.loadAnimation(ImageFlipper.this.context, R.anim.image_left_in));ImageFlipper.this.setOutAnimation(AnimationUtils.loadAnimation(ImageFlipper.this.context, R.anim.image_left_out));ImageFlipper.this.showNext();if( ImageFlipper.this.imageCounter != null ){ImageFlipper.this.imageCounter.showNext(ImageFlipper.this.getIndex());}return true;} else if( e1.getX()-e2.getX() < -120 ){ImageFlipper.this.setInAnimation(AnimationUtils.loadAnimation(ImageFlipper.this.context, R.anim.image_right_in));ImageFlipper.this.setOutAnimation(AnimationUtils.loadAnimation(ImageFlipper.this.context, R.anim.image_right_out));ImageFlipper.this.showPrevious();if( ImageFlipper.this.imageCounter != null ){ImageFlipper.this.imageCounter.showNext(ImageFlipper.this.getIndex());}return true;}return false;}@Overridepublic void onLongPress(MotionEvent e) {}@Overridepublic boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX, float distanceY) { return false; }@Overridepublic void onShowPress(MotionEvent e) {}@Overridepublic boolean onSingleTapUp(MotionEvent e) { return false; }}}
package cn.trto1987.android.util;import java.util.ArrayList;import android.content.Context;import android.util.AttributeSet;import android.widget.ImageView;import android.widget.LinearLayout;import cn.trto1987.android.test.R;/** * public class<br/> * <b>ImageCounter</b><br/> * extends {@link LinearLayout}<br/> * <b>本类配合ImageFlipper使用,指示出显示图片的序号</b><br/> * 相关的资源:<br/> * <blockquote> * res/drawable/counter_checked.png, * res/drawable/counter_unchecked.png * </blockquote> * @author trto1987 */public class ImageCounter extends LinearLayout{private int size;//图片的数目private ArrayList<ImageView> list;//指示器的所有指示点private ImageView checked;//正在展示的点private Context context;private LayoutParams viewLayoutParams;//指示点的布局public ImageCounter(Context context) {super(context);this.context = context;list = new ArrayList<ImageView>();viewLayoutParams = new LinearLayout.LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT);viewLayoutParams.setMargins(10, 10, 10, 10);}public ImageCounter(Context context, AttributeSet attrs){super(context,attrs);this.context = context;list = new ArrayList<ImageView>();viewLayoutParams = new LinearLayout.LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT);viewLayoutParams.setMargins(10, 10, 10, 10);}/** * 绑定到{@link ImageFlipper} * @param size 图片数目 */public void setCount(int size) {this.size = size;for( int i = 0; i < this.size; i ++ ){ImageView v = new ImageView(context);v.setLayoutParams(this.viewLayoutParams);if(i==0){v.setBackgroundResource(R.drawable.counter_checked);checked = v;} else {v.setBackgroundResource(R.drawable.counter_unchecked);}this.addView(v);list.add(v);}}/** * 指示下一个,在{@link ImageFlipper}中调用 * @param index 图片序号 */public void showNext(int index){if(checked!=null){checked.setBackgroundResource(R.drawable.counter_unchecked);}checked = list.get(index);checked.setBackgroundResource(R.drawable.counter_checked);}}下面是实现上图的代码:
res/layout/main.xml
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" android:background="#e0e0e0" tools:context=".MainActivity" > <cn.trto1987.android.util.ImageFlipper android:id="@+id/imgs" android:layout_width="200dp" android:layout_height="150dp" android:layout_centerHorizontal="true" android:layout_marginTop="50dp"/> <cn.trto1987.android.util.ImageCounter android:id="@+id/imgsCounter" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_centerHorizontal="true" android:layout_below="@+id/imgs" android:layout_marginTop="10dp"/> </RelativeLayout>src/cn.trto1987.android.test/MainActivity.java
package cn.trto1987.android.test;import java.util.ArrayList;import android.app.Activity;import android.graphics.drawable.Drawable;import android.os.Bundle;import android.view.Window;import cn.trto1987.android.util.ImageCounter;import cn.trto1987.android.util.ImageFlipper;public class MainActivity extends Activity {private ImageFlipper imageFlipper;private ImageCounter imageCounter;private ArrayList<Drawable> imgList;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);requestWindowFeature(Window.FEATURE_NO_TITLE);setContentView(R.layout.main);initView();}private void initView() {imgList = new ArrayList<Drawable>();imgList.add(getResources().getDrawable(R.drawable.a));imgList.add(getResources().getDrawable(R.drawable.b));imgList.add(getResources().getDrawable(R.drawable.c));imageFlipper = (ImageFlipper) findViewById(R.id.imgs);imageCounter = (ImageCounter) findViewById(R.id.imgsCounter);imageFlipper.setResources(imgList);imageFlipper.setCounter(imageCounter);imageFlipper.startAutoPlay(3000);}}
其他的一些关联的东东:
res/anim/image_left_in.xml
<?xml version="1.0" encoding="utf-8"?><set xmlns:android="http://schemas.android.com/apk/res/android" > <translate android:duration="500" android:fromXDelta="100%p" android:toXDelta="0" /> <alpha android:duration="500" android:fromAlpha="0.1" android:toAlpha="1.0" /></set>
res/anim/image_left_out.xml
<?xml version="1.0" encoding="utf-8"?><set xmlns:android="http://schemas.android.com/apk/res/android" > <translate android:duration="500" android:fromXDelta="0" android:toXDelta="-100%p" /> <alpha android:duration="500" android:fromAlpha="1.0" android:toAlpha="0.1" /></set>res/anim/image_right_in.xml
<?xml version="1.0" encoding="utf-8"?><set xmlns:android="http://schemas.android.com/apk/res/android" > <translate android:duration="500" android:fromXDelta="-100%p" android:toXDelta="0" /> <alpha android:duration="500" android:fromAlpha="0.1" android:toAlpha="1.0" /></set>res/anim/image_right_out.xml
<?xml version="1.0" encoding="utf-8"?><set xmlns:android="http://schemas.android.com/apk/res/android" > <translate android:duration="500" android:fromXDelta="0" android:toXDelta="100%p" /> <alpha android:duration="500" android:fromAlpha="1.0" android:toAlpha="0.1" /></set>
暂时就这些了,欢迎一起讨论!
- 继承ViewFlipper实现左右滑动展示以及下面华丽的点点点
- 左右滑动---viewflipper实现
- 豆瓣学习 - 实现左右滑动的ViewFlipper
- ViewPager与ViewFlipper实现图片导航的左右滑动
- 使用ViewFlipper实现图片左右滑动效果
- android ViewPager,ViewFlipper,ViewFlow实现左右滑动
- android ViewPager,ViewFlipper,ViewFlow实现左右滑动
- android ViewPager,ViewFlipper,ViewFlow实现左右滑动
- android ViewPager,ViewFlipper,ViewFlow实现左右滑动
- android ViewPager,ViewFlipper,ViewFlow实现左右滑动
- android ViewPager,ViewFlipper,ViewFlow实现左右滑动
- android ViewPager,ViewFlipper,ViewFlow实现左右滑动
- android ViewPager,ViewFlipper,ViewFlow实现左右滑动
- android通过ViewFlipper实现左右滑动效果
- android ViewPager,ViewFlipper,ViewFlow实现左右滑动
- Android 实现ViewFlipper左右滑动效果
- ViewFlipper 左右滑动效果
- ViewFlipper 左右滑动效果
- 电子产品
- cocos2d-x 使用Jin调用java层代码的问题
- Web Service依赖的jar包介绍
- 论数据库访问组件的选择
- NHibernate主键生成方式 Key Generator
- 继承ViewFlipper实现左右滑动展示以及下面华丽的点点点
- 大话设计模式之工厂方法模式
- 求两个单链表的和
- 程序员不得不知道20个位运算
- hdu3336
- KMP 模版
- “MVC+Nhibernate+Jquery
- 黑马程序员 自学日记(七)集合框架
- Nhibernate下操作SQLite报错