仿京东快报效果

先来看看效果吧
这里写图片描述
(截图效果不是很好,但是差不多出来了)

代码:

package com.test.scrolltransptoolbar;

import android.content.Context;
import android.graphics.Color;
import android.os.Handler;
import android.text.TextUtils;
import android.util.AttributeSet;
import android.util.TypedValue;
import android.view.GestureDetector;
import android.view.Gravity;
import android.view.MotionEvent;
import android.view.View;
import android.view.ViewGroup;
import android.view.animation.AnimationUtils;
import android.widget.TextView;
import android.widget.ViewFlipper;

import java.util.List;

/**
 * Created by Administrator on 2017/8/31.
 */

public class JinDongKuaiBaoView extends ViewFlipper implements View.OnClickListener, View.OnTouchListener {
    private Context context;
    private List<String> mNotices;
    public final static int SCROLL_TYPE_VERTICAL = 0;
    public final static int SCROLL_TYPE_HORIZONTAL = 1;
    private GestureDetector mGestureDetector;
    public static final int FLING_MIN_DISTANCE = 80;
    public static final int FLING_MIN_VELOCITY = 120;
    private boolean  isFling=false;


    public JinDongKuaiBaoView(Context context) {
        super(context);
    }

    Handler  handler=new Handler();
    public JinDongKuaiBaoView(Context context, AttributeSet attrs) {
        super(context, attrs);
        init(context);
    }

    private void init(Context context) {
       // mGestureDetector = new GestureDetector(new simpleGestureListener());
        this.context = context;
        // 轮播间隔时间为3s
        setFlipInterval(3000);
        // 内边距5dp
        setPadding(dp2px(5f), dp2px(5f), dp2px(5f), dp2px(5f));

          setScrollType(SCROLL_TYPE_VERTICAL);

       // setOnTouchListener(this);
    }


    private int dp2px(float dpValue) {
        return (int) TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_DIP,
                dpValue,
                context.getResources().getDisplayMetrics());
    }

    public void setScrollType(int type) {
        clearAnimation();
        switch (type) {
            case SCROLL_TYPE_VERTICAL://垂直滚动动画设置
                // 设置enter和leave动画
                setInAnimation(AnimationUtils.loadAnimation(context, R.anim.notify_in));
                setOutAnimation(AnimationUtils.loadAnimation(context, R.anim.notify_out));
                break;
            case SCROLL_TYPE_HORIZONTAL://水平滚动动画设置
                setInAnimation(AnimationUtils.loadAnimation(context, R.anim.horizontal_notify_in));
                setOutAnimation(AnimationUtils.loadAnimation(context, R.anim.horizontal_notify_out));

                break;
            default:
                break;
        }
    }


    /**
     * 添加需要轮播展示的公告
     *
     * @param notices
     */
    public void addNotice(List<String> notices) {

        this.mNotices = notices;
        removeAllViews();
        for (int i = 0; i < mNotices.size(); i++) {
            // 根据公告内容构建一个TextView
            String notice = notices.get(i);
            TextView textView = new TextView(context);
            textView.setSingleLine();
            textView.setText(notice);
            textView.setTextSize(13f);
            textView.setEllipsize(TextUtils.TruncateAt.END);
            textView.setTextColor(Color.parseColor("#666666"));
            textView.setGravity(Gravity.CENTER_VERTICAL);
            // 将公告的位置设置为textView的tag方便点击是回调给用户
            textView.setTag(i);
             textView.setOnClickListener(this);
            // 添加到ViewFlipper
            JinDongKuaiBaoView.this.addView(textView, new ViewGroup.LayoutParams(ViewGroup.LayoutParams.FILL_PARENT, ViewGroup.LayoutParams.FILL_PARENT));
        }
    }

    @Override
    public void onClick(View v) {
        int position = (int) v.getTag();
        String notice = (String) mNotices.get(position);
        if (mOnNoticeClickListener != null) {
            mOnNoticeClickListener.onNotieClick(position, notice);
        }
    }


//    private void ToRightAnimation() {
//        clearAnimation();
//        setInAnimation(AnimationUtils.loadAnimation(context, R.anim.right_notify_in));
//        setOutAnimation(AnimationUtils.loadAnimation(context, R.anim.right_notify_out));
//    }
//
//    private void ToLeftAnimation() {
//        clearAnimation();
//        setInAnimation(AnimationUtils.loadAnimation(context, R.anim.horizontal_notify_in));
//        setOutAnimation(AnimationUtils.loadAnimation(context, R.anim.horizontal_notify_out));
//    }

    @Override
    public boolean onTouch(View v, MotionEvent event) {
        mGestureDetector.onTouchEvent(event);
        return true ;
    }

    /**
     * 通知点击监听接口
     */
    public interface OnNoticeClickListener {
        void onNotieClick(int position, String notice);
    }

    private OnNoticeClickListener mOnNoticeClickListener;

    /**
     * 设置通知点击监听器
     *
     * @param onNoticeClickListener 通知点击监听器
     */
    public void setOnNoticeClickListener(OnNoticeClickListener onNoticeClickListener) {
        mOnNoticeClickListener = onNoticeClickListener;
    }


//    private class simpleGestureListener extends GestureDetector.SimpleOnGestureListener {
//        @Override
//        public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY) {
//            isFling=true;
//            if (e1.getX() - e2.getX() > FLING_MIN_DISTANCE
//                    && Math.abs(velocityX) > FLING_MIN_VELOCITY) {
//                // 当像左侧滑动的时候
//                //设置View进入屏幕时候使用的动画
//                //设置View退出屏幕时候使用的动画
//                 ToLeftAnimation();
//                showNext();
//            } else if (e2.getX() - e1.getX() > FLING_MIN_DISTANCE
//                    && Math.abs(velocityX) > FLING_MIN_VELOCITY) {
//                // 当像右侧滑动的时候
//                ToRightAnimation();
//                showPrevious();
//            }
//            handler.postDelayed(new Runnable() {
//                @Override
//                public void run() {
//                    startFlipping();
//                }
//            },0);
//
//            return true;
//        }
//    }
}

注释掉的内容可以不用管,那是我做其他调试用的


使用方式

package com.test.scrolltransptoolbar;

import android.app.Activity;
import android.os.Bundle;
import android.view.GestureDetector;
import android.view.MotionEvent;
import android.view.View;
import android.widget.Toast;

import java.util.ArrayList;
import java.util.List;

/**
 * Created by Administrator on 2017/8/31.
 */
public class ViewFlipperActivity  extends Activity implements JinDongKuaiBaoView.OnNoticeClickListener {

    private JinDongKuaiBaoView jinDongKuaiBaoView;
    private GestureDetector gestureDetector;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_viewflipper);
        jinDongKuaiBaoView = (JinDongKuaiBaoView) findViewById(R.id.jindongkuaibaoview);
        List<String> notices = new ArrayList<>();
        notices.add("大促销下单拆福袋,亿万新年红包随便拿");
        notices.add("家电五折团,抢十亿无门槛现金红包");
        notices.add("星球大战剃须刀首发送200元代金券");
        jinDongKuaiBaoView.setScrollType(JinDongKuaiBaoView.SCROLL_TYPE_HORIZONTAL);
        jinDongKuaiBaoView.addNotice(notices);
        jinDongKuaiBaoView.startFlipping();
        jinDongKuaiBaoView.setOnNoticeClickListener(this);


    }


    @Override
    public void onNotieClick(int position, String notice) {

        Toast.makeText(ViewFlipperActivity.this,"position"+position,Toast.LENGTH_LONG).show();
    }


}
   //设置从左开始滚动还是,水平向上开始滚动
 jinDongKuaiBaoView.setScrollType(JinDongKuaiBaoView.SCROLL_TYPE_HORIZONTAL);
  //开始滚动的方法
  jinDongKuaiBaoView.startFlipping();
  // 轮播间隔时间为3s
  setFlipInterval(3000);
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值