Android实现购物车详情简单效果

本文介绍了一种在Android应用中实现购物车详情效果的方法。通过使用TabLayout和ListView组件,并结合自定义适配器,实现了随滚动切换标签页的功能。文章提供了MainActivity的代码示例及对应的XML布局。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

效果图

 

1.MainActivity

package com.example.sj.bigtracing;

import android.os.Bundle;
import android.support.design.widget.TabItem;
import android.support.design.widget.TabLayout;
import android.support.v7.app.AppCompatActivity;
import android.view.View;
import android.widget.AbsListView;
import android.widget.ListView;

import java.lang.reflect.Field;
import java.util.ArrayList;
import java.util.List;

//实现购物车详情效果
public class MainActivity extends AppCompatActivity {

    private TabItem name1;
    private TabItem name2;
    private TabItem name3;
    private ListView lv;
    private TabLayout tab;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        initView();
        initData();
    }

    int noyong;
    private int position;

    private void initData() {
        List<String> list = new ArrayList<>();
        for (int i = 0; i < 40; i++) {
            list.add("天王盖地虎,拉祜。。。" + i);
        }
        MyAdapter adapter = new MyAdapter(this, list);
        lv.setAdapter(adapter);


        lv.setOnScrollListener(new AbsListView.OnScrollListener() {
            @Override
            public void onScrollStateChanged(AbsListView view, int scrollState) {
                switch (noyong) {
                    case 0:
                        TabLayout.Tab tabAt1 = tab.getTabAt(0);
                        tabAt1.select();
                        break;
                    case 10:
                        TabLayout.Tab tabAt2 = tab.getTabAt(1);
                        tabAt2.select();
                        break;
                    case 20:
                        TabLayout.Tab tabAt3 = tab.getTabAt(2);
                        tabAt3.select();
                        break;
                }
            }




            @Override
            public void onScroll(AbsListView view, int firstVisibleItem, int visibleItemCount, int totalItemCount) {
                switch (firstVisibleItem) {
                    case 0:
                        noyong = 0;

                        break;
                    case 10:
                        noyong = 10;

                        break;
                    case 20:
                        noyong = 20;

                        break;
                    case 9:
                        noyong = 0;

                        break;

                    case 19:
                        noyong = 10;

                        break;


                }
            }
        });


        for (int i = 0; i < tab.getTabCount(); i++) {
            TabLayout.Tab tabAt = tab.getTabAt(i);
            if (tabAt == null) {
                Class c = tabAt.getClass();

                try {
                    Field field = c.getDeclaredField("mView");
                    field.setAccessible(true);
                    final View view = (View) field.get(tabAt);
                    if (view == null) {
                        return;
                    }
                    view.setTag(i);
                    view.setOnClickListener(new View.OnClickListener() {
                        @Override
                        public void onClick(View v) {
                            position = (int) view.getTag();
                            switch (position) {
                                case 0:
                                    lv.setSelection(20);
                                    break;
                                case 1:
                                    lv.setSelection(10);
                                    break;
                                case 2:
                                    lv.setSelection(0);
                                    break;


                            }

                        }
                    });


                } catch (NoSuchFieldException e) {
                    e.printStackTrace();
                } catch (IllegalAccessException e) {
                    e.printStackTrace();
                }
            }
        }


    }

    private void initView() {
        name1 = (TabItem) findViewById(R.id.name1);
        name2 = (TabItem) findViewById(R.id.name2);
        name3 = (TabItem) findViewById(R.id.name3);
        lv = (ListView) findViewById(R.id.lv);
        tab = (TabLayout) findViewById(R.id.tab);
    }
}

MainActivity的xml布局

<?xml version="1.0" encoding="utf-8"?>
<android.support.design.widget.CoordinatorLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity">

    <android.support.design.widget.AppBarLayout
        android:id="@+id/appbar"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:fitsSystemWindows="true">

        <android.support.v7.widget.Toolbar
            android:id="@+id/toolbar"
            android:layout_width="match_parent"
            android:layout_height="250dp"
            android:background="@drawable/q"
            app:layout_scrollFlags="scroll|enterAlways|snap">

        </android.support.v7.widget.Toolbar>

        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:orientation="horizontal">

            <android.support.design.widget.TabLayout
                android:id="@+id/tab"
                android:layout_width="0dp"
                android:layout_height="wrap_content"
                android:layout_toLeftOf="@+id/img"
                android:layout_toStartOf="@+id/img"
                android:layout_weight="9"
                android:background="#ffffff"
                app:tabMode="scrollable">
                <android.support.design.widget.TabItem
                    android:id="@+id/name1"
                    android:layout_width="wrap_content"
                    android:layout_height="match_parent"
                    android:text="嘻嘻" />

                <android.support.design.widget.TabItem
                    android:id="@+id/name2"
                    android:layout_width="wrap_content"
                    android:layout_height="match_parent"
                    android:text="哈哈" />

                <android.support.design.widget.TabItem
                    android:id="@+id/name3"
                    android:layout_width="wrap_content"
                    android:layout_height="match_parent"
                    android:text="呵呵" />

            </android.support.design.widget.TabLayout>

        </LinearLayout>
    </android.support.design.widget.AppBarLayout>

    <ListView
        android:id="@+id/lv"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        app:layout_behavior="@string/appbar_scrolling_view_behavior">

    </ListView>


</android.support.design.widget.CoordinatorLayout>

2.MyAdapter 适配器

package com.example.sj.bigtracing;

import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.TextView;

import java.util.List;

public class MyAdapter extends BaseAdapter {
    private Context context;

    public MyAdapter(Context context, List<String> list) {
        this.context = context;
        this.list = list;
    }

    private List<String> list;

    @Override
    public int getCount() {
        return list.size();
    }

    @Override
    public Object getItem(int position) {
        return null;
    }

    @Override
    public long getItemId(int position) {
        return 0;
    }

    @Override
    public View getView(int position, View convertView, ViewGroup parent) {

        ViewHolder viewHolder = null;
        if (convertView == null) {
            convertView = LayoutInflater.from(context).inflate(R.layout.item, null);
            viewHolder = new ViewHolder(convertView);
            convertView.setTag(viewHolder);
        } else {
            viewHolder = (ViewHolder) convertView.getTag();
        }
        viewHolder.item_tv.setText(list.get(position));
        return convertView;
    }

    public static class ViewHolder {
        public View rootView;
        public TextView item_tv;

        public ViewHolder(View rootView) {
            this.rootView = rootView;
            this.item_tv = (TextView) rootView.findViewById(R.id.item_tv);
        }

    }
}

适配器xml布局

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <RelativeLayout
        android:layout_width="match_parent"
        android:layout_height="60dp">

        <TextView
            android:id="@+id/item_tv"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_centerVertical="true"
            android:text="嘻嘻嘻哈哈" />
    </RelativeLayout>

</RelativeLayout>

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值