Android 时间轴实现(RecycleView更高效)

之前实现时间轴的方式,总体来说就是通过ListView的方式。看到网友评论说到RecycleView,就尝试了一下,结果发现用RecycleView实现时间更加高效,尤其是在实现横向时间轴的时候。

RecycleView 是什么?

RecyclerView 是Android L版本中新添加的一个用来取代ListView的SDK,它的灵活性与可替代性比listview更好。

在百度上一搜RecycleView,很多介绍都是以这样的开头。RecycleView的确比ListView灵活了许多,通过设置它提供的不同LayoutManager,ItemDecoration , ItemAnimator可以实现很拉风的视图效果和用户操作体验。(下面你马上就可以体验到)

纵向时间轴

纵向时间轴的实现,类似于使用ListView实现,只是起Adapter和ListView的Adapter有所不同,但整体思路是一样的。

  • Adapter 实现
public class MyRecyclerAdapter extends
        RecyclerView.Adapter<MyRecyclerAdapter.MyViewHolder> {

    List<ItemBean> lists;
    Context mContext;

    public MyRecyclerAdapter(List<ItemBean> lists, Context mContext) {
        super();
        this.lists = lists;
        this.mContext = mContext;
    }

    /*
     * 覆盖方法
     */
    @Override
    public int getItemCount() {
        // TODO 自动生成的方法存根
        return lists.size();
    }

    /*
     * 覆盖方法
     */
    @Override
    public MyViewHolder onCreateViewHolder(ViewGroup arg0, int arg1) {
        // TODO 自动生成的方法存根
        LayoutInflater inflater = LayoutInflater.from(mContext);
        View view = inflater.inflate(R.layout.item_view, arg0, false);
        MyViewHolder holder = new MyViewHolder(view);
        return holder;
    }

    class MyViewHolder extends ViewHolder {
        TextView title,time;
        View line;

        /**
         * @param itemView
         */
        public MyViewHolder(View itemView) {
            super(itemView);
            // TODO 自动生成的构造函数存根
            title = (TextView) itemView.findViewById(R.id.show_title);
            time= (TextView) itemView.findViewById(R.id.show_time);
            line = itemView.findViewById(R.id.line_normal);
        }

    }

    /*
     * 覆盖方法
     */
    @Override
    public void onBindViewHolder(MyViewHolder arg0, int arg1) {
        // TODO 自动生成的方法存根
        arg0.title.setText(lists.get(arg1).getTitle());
        arg0.time.setText(lists.get(arg1).getTime());

        //最后一项时,竖线不再显示
        if (arg1 == lists.size() - 1) {
            arg0.line.setVisibility(View.GONE);
        }
    }

}

这里需要注意的是,布局文件view_item.xml 最外层的View必须是高度必须是wrap_content.

  • 效果如图

    时间轴1

横向时间轴

在实现横向的时间轴时,就体现出了RecycleView的优势来。

在之前的文章中提到,此时需要自定义实现横向的ListView。但是对RecycleView来说,变成横向布局,简直太容易了。代码如下:

  • 设置RecycleView为横向
        recycview=(RecyclerView) findViewById(R.id.recyclerview);
        adapter=new MyRecyclerAdapter2(datas,mContext);
        //设置布局管理器
        LinearLayoutManager linearLayoutManager = new LinearLayoutManager(this);
        linearLayoutManager.setOrientation(LinearLayoutManager.HORIZONTAL);
        recycview.setLayoutManager(linearLayoutManager);
        recycview.setAdapter(adapter);

RecycleView就是这么任性,只需要在设置布局管理器时制定方向为HORIZONTAL,那么整个View就会在水平方向做延伸,很容易的就实现了一个横向的列表。

  • Adapter
public class MyRecyclerAdapter2 extends
        RecyclerView.Adapter<MyRecyclerAdapter2.MyViewHolder> {

    List<ItemBean> lists;
    Context mContext;

    public MyRecyclerAdapter2(List<ItemBean> lists, Context mContext) {
        super();
        this.lists = lists;
        this.mContext = mContext;
    }

    /*
     * 覆盖方法
     */
    @Override
    public int getItemCount() {
        // TODO 自动生成的方法存根
        return lists.size();
    }

    /*
     * 覆盖方法
     */
    @Override
    public MyViewHolder onCreateViewHolder(ViewGroup arg0, int arg1) {
        // TODO 自动生成的方法存根
        LayoutInflater inflater = LayoutInflater.from(mContext);
        View view = inflater.inflate(R.layout.item_view2, arg0, false);
        MyViewHolder holder = new MyViewHolder(view);
        return holder;
    }

    class MyViewHolder extends ViewHolder {
        TextView title,time;
        View lineNorma, lineHiLight;
        ImageView image;

        /**
         * @param itemView
         */
        public MyViewHolder(View itemView) {
            super(itemView);
            // TODO 自动生成的构造函数存根
            title = (TextView) itemView.findViewById(R.id.show_title);
            time= (TextView) itemView.findViewById(R.id.show_time);
            lineNorma = itemView.findViewById(R.id.line_normal);
            lineHiLight = itemView.findViewById(R.id.line_highlight);
            image = (ImageView) itemView.findViewById(R.id.image);
        }

    }

    /*
     * 覆盖方法
     */
    @Override
    public void onBindViewHolder(MyViewHolder item, int position) {
        // TODO 自动生成的方法存根
        item.title.setText(lists.get(position).getTitle());
        item.time.setText(lists.get(position).getTime());

        //最后一项时,竖线不再显示
        if (position == 0) {
            item.lineNorma.setVisibility(View.INVISIBLE);
            item.lineHiLight.setVisibility(View.INVISIBLE);
            item.time.setVisibility(View.VISIBLE);
        }else {
            if (lists.get(position).getStatu() == 1) {
                item.lineHiLight.setVisibility(View.VISIBLE);
                item.image.setImageResource(R.drawable.point1);
                item.time.setVisibility(View.VISIBLE);
            }
        }


    }

}

这里同样需要注意,item_view2布局文件最外层的View的宽度需设置为wrap_content。

  • 效果图

    时间轴2

好了,这就是用RecycleView实现横竖时间轴的两种方式。

可以看到RecycleView的确很灵活。当然了,这里提到的只是冰山一角,Google官方提出用其替代ListView及GridView,在性能方面必然也有它的优势,所以以后开发需罗列大量数据时可以考虑使用RecycleView。


1. 首先,在布局文件中定义BottomSheet和RecycleView: ``` <androidx.coordinatorlayout.widget.CoordinatorLayout android:layout_width="match_parent" android:layout_height="match_parent"> <com.google.android.material.bottomsheet.BottomSheetBehavior android:id="@+id/bottom_sheet" android:layout_width="match_parent" android:layout_height="wrap_content" app:behavior_hideable="true" app:behavior_peekHeight="0dp" app:layout_behavior="@string/bottom_sheet_behavior"> <LinearLayout android:id="@+id/bottom_sheet_content" android:layout_width="match_parent" android:layout_height="match_parent" android:background="@android:color/white" android:orientation="vertical"> <androidx.recyclerview.widget.RecyclerView android:id="@+id/recycler_view" android:layout_width="match_parent" android:layout_height="match_parent" /> </LinearLayout> </com.google.android.material.bottomsheet.BottomSheetBehavior> </androidx.coordinatorlayout.widget.CoordinatorLayout> ``` 2. 在Activity中,初始化BottomSheetBehavior和RecycleView: ``` private BottomSheetBehavior bottomSheetBehavior; private RecyclerView recyclerView; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); recyclerView = findViewById(R.id.recycler_view); recyclerView.setLayoutManager(new LinearLayoutManager(this)); recyclerView.setAdapter(new MyAdapter()); bottomSheetBehavior = BottomSheetBehavior.from(findViewById(R.id.bottom_sheet)); bottomSheetBehavior.setState(BottomSheetBehavior.STATE_HIDDEN); // 设置地图的触摸事件监听器,用于处理拖拽事件 AMap aMap = ((SupportMapFragment) getSupportFragmentManager().findFragmentById(R.id.map)).getMap(); aMap.setOnMapTouchListener(new AMap.OnMapTouchListener() { @Override public void onTouch(MotionEvent motionEvent) { if (motionEvent.getAction() == MotionEvent.ACTION_MOVE) { if (bottomSheetBehavior.getState() == BottomSheetBehavior.STATE_HIDDEN) { bottomSheetBehavior.setState(BottomSheetBehavior.STATE_COLLAPSED); } } } }); } ``` 3. 在MyAdapter中,实现RecyclerView的内容: ``` public class MyAdapter extends RecyclerView.Adapter<MyViewHolder> { private List<String> data = new ArrayList<>(); public MyAdapter() { for (int i = 0; i < 20; i++) { data.add("Item " + i); } } @NonNull @Override public MyViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) { View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.item_layout, parent, false); return new MyViewHolder(view); } @Override public void onBindViewHolder(@NonNull MyViewHolder holder, int position) { holder.textView.setText(data.get(position)); } @Override public int getItemCount() { return data.size(); } } public class MyViewHolder extends RecyclerView.ViewHolder { public TextView textView; public MyViewHolder(@NonNull View itemView) { super(itemView); textView = itemView.findViewById(R.id.text_view); } } ``` 4. 在布局文件中定义item_layout.xml: ``` <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="?attr/listPreferredItemHeight" android:orientation="vertical" android:padding="16dp"> <TextView android:id="@+id/text_view" android:layout_width="match_parent" android:layout_height="wrap_content" android:text="Item" android:textSize="16sp" android:textStyle="bold" /> </LinearLayout> ``` 5. 运行程序,拖动地图时,BottomSheet会自动展开,显示RecyclerView的内容。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

阎楠

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值