Android自定义竖向滚动新闻条

这篇博客介绍了如何在Android中实现一个仿京东快报的竖向滚动新闻条。作者探讨了使用ViewPager竖向滚动的不便,并提出通过动画和自定义Adapter来简化实现。通过两个LinearLayout的淡入淡出动画效果,结合AdapterView和OnItemClickListener,创建了一个便捷的自定义控件。文章最后提到了博主对长时间未更新博客的尴尬感。
摘要由CSDN通过智能技术生成

控件:Android自定义竖向滚动新闻条,不知道怎样描述,就起个这个名字吧

功能:仿照京东快报那样类似的上下滚动新闻条。

前言:最开始在网上寻找类似的demo,找到过一些类似的,有一部分是搭配ViewPager使用,设置竖向滚动的。但是写起来终究觉得有一些麻烦,于是开始思考有没有更便捷的实现方式。考虑思路,当前一条上滑淡出,下一条从下面淡入,可以考虑使用两个View的动画来搭配实现。后来又考虑可能要自定义内部的视图,因此借鉴了AdapterView的方式,为这个控件设置Adapter搭配使用,同时实现OnItemClickListener方法设置点击监听,目前就使用来说,还是非常便捷的。

上代码吧

/**
 * Created by rxj on 2018/4/2.
 * <p>
 * 思路:
 * 1.两个View互相替换
 * 2.在第一个View加载时,填充下一个View数据
 * 3.动画过程中无法点击
 * 4.动画完成后设置点击事件
 * 5.定时器自动执行
 */

public class VerticalScrollBar2 extends RelativeLayout {
    private Context mContext;

    private LinearLayout lin1;
    private LinearLayout lin2;

    private ListAdapter adapter;

    private int currentItemPosition = 0;
    private int nextItemPosition = 1;

    private Animation topOut;
    private Animation bottomIn;
    private boolean isAnimationing = false;

    private AdapterView.OnItemClickListener listener;

    private Handler handler = new Handler() {
        @Override
        public void handleMessage(Message msg) {
            super.handleMessage(msg);
            goNext();
            handler.sendEmptyMessageDelayed(0, 2000);
        }
    };

    public VerticalScrollBar2(Context context) {
        this(context, null);
    }

    public VerticalScrollBar2(Context context, @Nullable AttributeSet attrs) {
        this(context, attrs, 0);
    }

    public VerticalScrollBar2(Context context, @Nullable AttributeSet attrs, int defStyleAttr) {
        super(context, attrs, defStyleAttr);
        mContext = context;
        View view = LayoutInflater.from(context).inflate(R.layout.view_vertical_scroll_bar, this);
        lin1 = view.findViewById(R.id.lin_1);
        lin2 = view.findViewById(R.id.lin_2);
        topOut = AnimationUtils.loadAnimation
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值