首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

在listview和gridview之间切换视图类型,并将数据保存在Android中

在Android中,在listview和gridview之间切换视图类型,并将数据保存,可以通过以下步骤实现:

  1. 创建一个包含数据的列表或数组,用于存储要显示的数据。
  2. 创建一个布局文件,包含一个ListView和一个GridView,用于显示数据。
  3. 创建一个适配器类,继承自BaseAdapter,并重写相关方法,用于将数据绑定到ListView或GridView上。
  4. 在适配器类中,根据当前视图类型(列表或网格),选择不同的布局文件进行加载和显示。
  5. 在Activity中,初始化适配器并将其设置给ListView或GridView。
  6. 为切换视图类型的按钮添加点击事件监听器。
  7. 在点击事件监听器中,根据当前视图类型,切换为另一种视图类型,并更新适配器。
  8. 在切换视图类型时,将当前数据保存到SharedPreferences或数据库中,以便下次打开应用时恢复。

以下是一个示例代码:

代码语言:java
复制
// MainActivity.java

public class MainActivity extends AppCompatActivity {
    private ListView listView;
    private GridView gridView;
    private Button switchButton;
    private boolean isListView = true;
    private List<DataItem> dataItems;
    private DataAdapter adapter;

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

        listView = findViewById(R.id.listView);
        gridView = findViewById(R.id.gridView);
        switchButton = findViewById(R.id.switchButton);

        // 初始化数据
        dataItems = initData();

        // 初始化适配器
        adapter = new DataAdapter(dataItems, isListView);

        // 设置适配器给ListView或GridView
        if (isListView) {
            listView.setAdapter(adapter);
            listView.setVisibility(View.VISIBLE);
            gridView.setVisibility(View.GONE);
        } else {
            gridView.setAdapter(adapter);
            gridView.setVisibility(View.VISIBLE);
            listView.setVisibility(View.GONE);
        }

        // 切换视图类型按钮点击事件
        switchButton.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                isListView = !isListView;

                // 切换视图类型并更新适配器
                if (isListView) {
                    listView.setAdapter(adapter);
                    listView.setVisibility(View.VISIBLE);
                    gridView.setVisibility(View.GONE);
                } else {
                    gridView.setAdapter(adapter);
                    gridView.setVisibility(View.VISIBLE);
                    listView.setVisibility(View.GONE);
                }
            }
        });
    }

    // 初始化数据
    private List<DataItem> initData() {
        List<DataItem> dataItems = new ArrayList<>();
        // 添加数据项
        // ...

        return dataItems;
    }
}
代码语言:java
复制
// DataAdapter.java

public class DataAdapter extends BaseAdapter {
    private List<DataItem> dataItems;
    private boolean isListView;

    public DataAdapter(List<DataItem> dataItems, boolean isListView) {
        this.dataItems = dataItems;
        this.isListView = isListView;
    }

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

    @Override
    public Object getItem(int position) {
        return dataItems.get(position);
    }

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

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

        if (convertView == null) {
            LayoutInflater inflater = LayoutInflater.from(parent.getContext());

            if (isListView) {
                convertView = inflater.inflate(R.layout.list_item, parent, false);
            } else {
                convertView = inflater.inflate(R.layout.grid_item, parent, false);
            }

            viewHolder = new ViewHolder();
            viewHolder.textView = convertView.findViewById(R.id.textView);
            // 其他视图组件的初始化
            // ...

            convertView.setTag(viewHolder);
        } else {
            viewHolder = (ViewHolder) convertView.getTag();
        }

        DataItem dataItem = dataItems.get(position);

        viewHolder.textView.setText(dataItem.getText());
        // 其他视图组件的数据绑定
        // ...

        return convertView;
    }

    private static class ViewHolder {
        TextView textView;
        // 其他视图组件的引用
        // ...
    }
}

在上述示例中,我们通过一个isListView变量来记录当前视图类型(列表或网格),并在切换视图类型时更新适配器。同时,我们使用了ViewHolder模式来优化ListView和GridView的性能。

请注意,上述示例中的布局文件(list_item.xml和grid_item.xml)需要根据实际需求进行创建和定义。另外,数据的保存和恢复可以使用SharedPreferences或数据库等方式进行实现。

以上是关于在Android中在listview和gridview之间切换视图类型,并将数据保存的一个示例。希望对你有帮助!

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

Android开发笔记(三十八)列表类视图

AdapterView顾名思义是适配器视图,Spinner、ListView和GridView都间接继承自AdapterView,这三个视图都存在多个元素并排展示的情况,所以需要引入适配器模式。 适配器视图的特点有: 1、定义了适配器的设置方法setAdapter,以及获取方法getAdapter。适配器用于传入视图展示需要的相关数据。 2、定义了一个数据观察者AdapterDataSetObserver,用于在列表数据发生变化时,可以通过notifyDataSetChanged方法来更新视图。 3、定义了单个元素的点击、长按、选中事件。其中点击方法为setOnItemClickListener,点击监听器为OnItemClickListener;长按方法为setOnItemLongClickListener,长按监听器为OnItemLongClickListener;选中方法为setOnItemSelectedListener,选中监听器为OnItemSelectedListener。

02
  • Android开发笔记(一百二十二)循环器视图RecyclerView

    RecyclerView是Android在support-v7库中新推出控件,中文别名为循环器视图,它的功能非常强大,可分别实现ListView、GridView,以及瀑布流网格的显示效果。 RecyclerView相关工程在sdk中的路径为sdk\extras\android\support\v7\recyclerview,不过幸好用它不像用Toolbar那样麻烦,要想使用Toolbar得先导入并引用v7-appcompat工程(具体步骤参见《Android开发笔记(一百一十九)工具栏Toolbar》),而使用RecyclerView只需像其他第三方jar一样往libs目录添加android-support-v7-recyclerview.jar就好了。 但是若在Eclipse/ADT中调用RecyclerView,可能app运行时会报错“Caused by: java.lang.NoClassDefFoundError: android.support.v7.recyclerview.R$styleable”,这时就不能使用sdk\extras\android\support\v7\recyclerview下面的jar包,而要到extras/android/m2repository/com/android/support/recyclerview-v7目录下,在版本号21.0.0的子目录中找到recyclerview-v7-21.0.0.aar,该aar文件其实是个压缩文件,解压该文件可得到classes.jar,将该jar包更名并加入到你的工程,上面的运行错误应该就没有了。  下面看看强悍的RecyclerView都提供了哪些常用方法: setAdapter : 设置列表项的适配器。有关适配器的详细说明见下一标题。 setLayoutManager : 设置列表项的布局管理器。目前有三种,分别是:线性布局管理器LinearLayoutManager、网格布局管理器GridLayoutManager、瀑布流网格布局管理器StaggeredGridLayoutManager。有关布局管理器的详细说明见本文的后半部分。 addItemDecoration : 添加列表项的分割线。 removeItemDecoration : 移除列表项的分割线。 setItemAnimator : 设置列表项的增删动画。 addOnItemTouchListener : 添加列表项的触摸监听器。因为RecyclerView没有实现列表项的点击接口,所以开发者可通过这里的触摸监听器来监控用户手势。 removeOnItemTouchListener : 移除列表项的触摸监听器。

    02

    Android开发笔记(二十二)瀑布流网格WaterfallGridView

    Android中展示门类信息一般使用列表视图ListView或者网格视图GridView,特别是电商类APP的首页,除了顶部导航、底部标签、上方横幅外,主要页面都是展示各种商品和活动的网格视图。一般情况下GridView就够用了,不过GridView中规中矩,每个网格的大小都是一样的,有时显得有些死板。比如不同商品的外观尺寸很不一样,冰箱是高高的在纵向上长,空调则是在横向上长,所以若用一样规格的网格来展示,必然有的商品图片被压缩得很小。再比如像新闻摘要,每篇摘要的字数都不一样,为了把文字显示完全,也需要对每个网格自适应高度,字数多的网格分配较小的高度,字数较多的网格分配较大的高度。可惜GridView不支持自适配网格高度,所以我们得自己写个瀑布流网格控件来实现这样的效果了。 先来理下瀑布流控件的思路,因为GridView每个网格的宽和高都是一样的,所以无法基于GridView进行改造。如果是ListView,每行高度一样,一行内每个元素的长度是可以自定义的,但每列元素的长度必须一样,所以改造ListView的效果也很有限。改造GridView也不行,改造ListView也不行,看来得换个思路了,把复杂问题简单化试试。例如这个页面上只有四个视图:左上区块0、右上区块1、左下区块2、右下区块3,直接用布局文件xml编写的话也不难,可能大家多半会想到采用相对布局RelativeLayout来处理。

    06
    领券