Android使用RecyclerView实现设置界面

本文介绍了如何使用RecyclerView实现Android应用的设置界面。通过BaseSettingItem、布局文件、ViewHolder等组件,结合BasePreferenceFragment和具体Fragment如SettingFragment、ProfileFragment,实现设置界面的统一风格和易于维护。
摘要由CSDN通过智能技术生成

一、目标

在这里插入图片描述

二、下载地址

神马笔记最新版本下载:【神马笔记 版本1.5.0——笔名功能.apk

三、功能设计

随着软件功能的增加,不可避免地会加入越来越多的设置项。如何管理不断增加的设置项?

  • 便于CRUD
  • 界面风格保持统一

首先,必修便于创建,修改,删除,并且只需要改动配置项,而不用对界面进行太大的修改。

其次,子设置界面必须与主设置界面保持风格一致。

四、准备工作

实现设置界面的方式有很多,可以选择任意的容器和控件进行组合,从而实现设置界面。

但是设置界面有其特殊性。

设置界面通常是有多个设置项组成,每一个设置项又由键值对构成。多个设置项可以组合成一个设置组,设置组之间由分割线区分开。其组成方式大概如下结构。

  • 设置界面
    • 设置组
      • 设置项
      • 设置项
      • 设置项
      • ……
    • 设置组
      • 设置项
    • 设置组
    • ……

从以上结构来看,设置界面便是一组设置项的列表。列表界面自然是使用RecyclerView来实现。

五、组合起来

1. BaseSettingItem

定义设置项UI的组成。

public class BaseSettingItem<T> {
   

    public static final int DIVIDER_NONE = 0;
    public static final int DIVIDER_NAME = 1;

    String id; // 唯一ID

    @DrawableRes int iconResId; // 图标资源
    ColorStateList iconTintList; // 图标Tint

    CharSequence name; // 名称
    CharSequence text; // 文本

    boolean chevron; // 是否显示chevron

    Consumer<T> consumer; // 列表项处理点击事件

    T userObject; // 用户数据

    boolean dividerVisible; // 是否显示分割线
    int dividerType; // 分割线的显示方式
}

2. 布局文件

定义基础设置项的布局。基础布局包括图标、名称、箭头3个部分组成。

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
        xmlns:android="http://schemas.android.com/apk/res/android"
        android:orientation="horizontal"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:minHeight="@dimen/settingItemHeight"
        android:background="@color/colorSettingItemBackground"
        android:paddingLeft="?listPreferredItemPaddingLeft"
        android:paddingRight="?listPreferredItemPaddingRight"
        android:gravity="center_vertical"
        android:foreground="?selectableItemBackground">

    <ImageView
            android:id="@+id/iv_icon"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_marginRight="?listPreferredItemPaddingRight"/>

    <TextView
            android:id="@+id/tv_name"
            android:textAppearance="@style/Base.TextAppearance.AppCompat.Menu"
            android:layout_width="0dp"
            android:layout_weight="1"
            android:layout_height="wrap_content"/>

    <ImageView
            android:id="@+id/iv_chevron"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:src="@drawable/ic_chevron_right_white_24dp"
            android:tint="@color/colorChevron"/>

</LinearLayout>

3. BaseSettingViewHolder

RecyclerView的ViewHolder实现。

public class BaseSettingViewHolder<T extends BaseSettingItem> extends BridgeViewHolder<T> implements SectionDividerDecoration.Adapter {
   

    public static final int LAYOUT_RES_ID = R.layout.layout_setting_list_item;

    ImageView iconView;
    TextView nameView;
    TextView textView;
    ImageView chevronView;

    @Keep
    public BaseSettingViewHolder(View itemView) {
   
        super(itemView);
    }

    @Override
    public int getLayoutResourceId() {
   
        return LAYOUT_RES_ID;
    }

    @Override
    public void onViewCreated(@NonNull View view) {
   
        view.setOnClickListener(this::onItemClick);

        this.iconView = view.findViewById(R.id.iv_icon);
        this.nameView = view.findViewById(R.id.tv_name);
        this.textView = view.findViewById(R.id.tv_text);
        this.chevronView = view.findViewById(R.id.iv_chevron);

        if (iconView != null) {
   
            if (iconView.getOutlineProvider() != null) {
   
                iconView.setClipToOutline(true);
            }
        }
    }

    @Override
    public void onBind(T item, int position) {
   

        if (iconView != null) {
   
            if (item.getIcon() > 0) {
   
                iconView.setImageResource(item.getIcon());
                iconView.setVisibility(View.VISIBLE
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值