TabTopAutoTextSizeLayout【自定义文字字号区域(动态选项卡数据且可滑动)】

版权声明:本文为HaiyuKing原创文章,转载请注明出处!

前言

自定义顶部选项卡布局LinearLayout类,实现可滑动效果。【实际情况中建议使用RecyclerView

对《TabTopAutoLayout【自定义顶部选项卡区域(带下划线)(动态选项卡数据且可滑动)】》的实际运用。

效果图

代码分析

简TabTopAutoTextSizeLayout:选项卡布局类——自定义的LinearLayout子类;实现了各个选项卡的布局、状态切换、点击事件的回调。

需要注意:注释掉params.weight = 1;

            //设置要添加的子布局view的参数
            LinearLayout.LayoutParams params = new LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT);
//            params.weight = 1;//在tab_item文件的根节点RelativeLayout中是无法添加的,而这个是必须要写上的,否则只会展现一个view
            params.gravity = Gravity.CENTER;

item的左右边距值需要在代码中设置

//设置内边距【第一个不设置左边距,最后一个不设置右边距】
            int paddingPx = mContext.getResources().getDimensionPixelOffset(R.dimen.tab_top_auto_padding);
            if(index == 0){
                params.setMargins(0,0,paddingPx,0);
            }else if(index == tabTitleList.size() - 1){
                params.setMargins(paddingPx,0,0,0);
            }else{
                params.setMargins(paddingPx,0,paddingPx,0);
            }

可滑动效果是在activity_main布局文件中实现的

    <HorizontalScrollView
        android:id="@+id/tab_hori_layout"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:scrollbars="none"
        android:layout_margin="20dp">

        <com.why.project.tabtopautotextsizelayout.tab.TabTopAutoTextSizeLayout
            android:id="@+id/tab_textsizeLayout"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:gravity="center_vertical"
            android:orientation="horizontal"
            />
    </HorizontalScrollView>

使用步骤

一、项目组织结构图

注意事项:

1、导入类文件后需要change包名以及重新import R文件路径

2、Values目录下的文件(strings.xml、dimens.xml、colors.xml等),如果项目中存在,则复制里面的内容,不要整个覆盖

二、导入步骤

将TabTopAutoTextSizeLayout.java文件复制到项目中

package com.why.project.tabtopautotextsizelayout.tab;

import android.content.Context;
import android.graphics.Typeface;
import android.util.AttributeSet;
import android.view.Gravity;
import android.view.LayoutInflater;
import android.view.View;
import android.widget.LinearLayout;
import android.widget.RelativeLayout;
import android.widget.TextView;

import com.why.project.tabtopautotextsizelayout.R;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;

/**
 * Created by HaiyuKing
 * Used TabTopAutoLayout的变形运用:文字字号横向列表
 */

public class TabTopAutoTextSizeLayout extends LinearLayout {

    private Context mContext;
    //选项卡标题
    //CharSequence与String都能用于定义字符串,但CharSequence的值是可读可写序列,而String的值是只读序列。
    private CharSequence[] toptab_Titles = {"16"};

    //选项卡的各个选项的标题的集合:用于切换时改变文字颜色
    private List<TextView> topTab_titles = new ArrayList<TextView>();

    public TabTopAutoTextSizeLayout(Context context, AttributeSet attrs) {
        super(context, attrs);

        mContext = context;

        List<CharSequence> toptab_titleList = new ArrayList<CharSequence>();
        toptab_titleList = Arrays.asList(toptab_Titles);
        //初始化view:创建多个view对象(引用tab_bottom_item文件),设置图片和文字,然后添加到这个自定义类的布局中
        initAddBottomTabItemView(toptab_titleList);
    }

    //初始化控件
    private void initAddBottomTabItemView(List<CharSequence> tabTitleList){

        int countChild = this.getChildCount();
        if(countChild > 0){
            this.removeAllViewsInLayout();//清空控件
            //将各个选项卡的各个选项的标题添加到集合中
            topTab_titles.clear();
        }

        for(int index=0;index<tabTitleList.size();index++){

            //设置要添加的子布局view的参数
            LinearLayout.LayoutParams params = new LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT);
//            params.weight = 1;//在tab_item文件的根节点RelativeLayout中是无法添加的,而这个是必须要写上的,否则只会展现一个view
            params.gravity = Gravity.CENTER;

            final int finalIndex = index;

            //============引用选项卡的各个选项的布局文件=================
            View toptabitemView = LayoutInflater.from(mContext).inflate(R.layout.tab_top_auto_textsize_item, this, false);

            //===========选项卡的根布局==========
            RelativeLayout toptabLayout = (RelativeLayout) toptabitemView.findViewById(R.id.toptabLayout);

            //===========设置选项卡的文字==========
            final TextView top_title = (TextView) toptabitemView.findViewById(R.id.top_title);
            //设置选项卡的文字
            top_title.setText(tabTitleList.get(index));
            //===========设置选项卡控件的Tag(索引)==========用于后续的切换更改图片和文字
            top_title.setTag("tag"+index);

            //设置内边距【第一个不设置左边距,最后一个不设置右边距】
            int paddingPx = mContext.getResources().getDimensionPixelOffset(R.dimen.tab_top_auto_padding);
            if(index == 0){
                params.setMargins(0,0,paddingPx,0);
            }else if(index == tabTitleList.size() - 1){
                params.setMargins(paddingPx,0,0,0);
            }else{
                params.setMargins(paddingPx,0,paddingPx,0);
            }

            //添加选项卡各个选项的触发事件监听
            toptabLayout.setOnClickListener(new OnClickListener() {
                public void onClick(View v) {
                    //设置当前选项卡状态为选中状态
                    //修改View的背景颜色
                    setTabsDisplay(finalIndex);
                    //添加点击事件
                    if(textSizeItemSelectListener != null){
                        //执行activity主类中的onBottomTabSelected方法
                        textSizeItemSelectListener.onTextSizeItemSelected(finalIndex);
                    }
                }
            });

            //把这个view添加到自定义的布局里面
            this.addView(toptabitemView,params);

            //将各个选项卡的各个选项的标题添加到集合中
            topTab_titles.add(top_title);
        }
    }

    /**
     * 设置底部导航中图片显示状态和字体颜色
     */
    public void setTabsDisplay(int checkedIndex) {

        int size = topTab_titles.size();

        for(int i=0;i<size;i++){
            TextView topTabTitle = topTab_titles.get(i);
            //设置选项卡状态为选中状态
            if(topTabTitle.getTag().equals("tag"+checkedIndex)){
                topTabTitle.setTypeface(Typeface.defaultFromStyle(Typeface.BOLD));
                //修改文字颜色
                topTabTitle.setTextColor(getResources().getColor(R.color.tab_text_selected_color));
            }else{
                topTabTitle.setTypeface(Typeface.defaultFromStyle(Typeface.NORMAL));
                //修改文字颜色
                topTabTitle.setTextColor(getResources().getColor(R.color.tab_text_normal_color));
            }
        }
    }

    public TextView getTabsItem(int checkedIndex){
        TextView topTabTitle = topTab_titles.get(checkedIndex);
        return topTabTitle;
    }

    /**设置显示的选项卡集合*/
    public void setTabList(ArrayList<CharSequence> toptab_titleList){
        initAddBottomTabItemView(toptab_titleList);
    }

    private OnTextSizeItemSelectListener textSizeItemSelectListener;

    //自定义一个内部接口,用于监听选项卡选中的事件,用于获取选中的选项卡的下标值
    public interface OnTextSizeItemSelectListener{
        void onTextSizeItemSelected(int index);
    }

    public void setOnTopTabSelectedListener(OnTextSizeItemSelectListener textSizeItemSelectListener){
        this.textSizeItemSelectListener = textSizeItemSelectListener;
    }
}
TabTopAutoTextSizeLayout.java

将tab_top_auto_textsize_item.xml文件复制到项目中

<?xml version="1.0" encoding="utf-8"?>
<!--  -->
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/toptabLayout"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:gravity="center"
    >
    <!-- 标题 -->
    <TextView
        android:id="@+id/top_title"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:gravity="center"
        android:text=""
        android:textSize="16sp"
        android:textColor="@color/tab_text_normal_color"
        android:layout_centerInParent="true"
        android:paddingLeft="5dp"
        android:paddingRight="5dp"/>

</RelativeLayout>
tab_top_auto_textsize_item.xml

在colors.xml文件中添加以下代码:【后续可根据实际情况更改文字颜色值

<?xml version="1.0" encoding="utf-8"?>
<resources>
    <color name="colorPrimary">#3F51B5</color>
    <color name="colorPrimaryDark">#303F9F</color>
    <color name="colorAccent">#FF4081</color>

    <!-- *********************************选项卡(文字字号横向列表)区域********************************* -->
    <!-- 选项卡文本颜色 -->
    <color name="tab_text_normal_color">#ff777777</color>
    <color name="tab_text_selected_color">#1A78EC</color>
</resources>

在dimens.xml文件中添加以下代码:【后续可根据实际情况更改底部选项卡区域的边距值

<resources>

    <!-- *********************************选项卡(文字字号横向列表)区域********************************* -->
    <!-- 选项卡的内边距 -->
    <dimen name="tab_top_auto_padding">10dp</dimen>
</resources>

至此,TabTopAutoTextSizeLayout类集成到项目中了。

三、使用方法

在Activity布局文件中引用TabTopAutoTextSizeLayout布局类【注意:需要重新引用TabTopAutoTextSizeLayout类的完整路径】

<?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="match_parent"
    android:orientation="vertical"
    >
    <Button
        android:id="@+id/btn_change"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="选中字号24"
        android:layout_margin="20dp"
        android:layout_gravity="center"/>

    <HorizontalScrollView
        android:id="@+id/tab_hori_layout"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:scrollbars="none"
        android:layout_margin="20dp">

        <com.why.project.tabtopautotextsizelayout.tab.TabTopAutoTextSizeLayout
            android:id="@+id/tab_textsizeLayout"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:gravity="center_vertical"
            android:orientation="horizontal"
            />
    </HorizontalScrollView>

    <TextView
        android:id="@+id/text_size_view"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="这显示选中的字号"
        android:textColor="@color/tab_text_selected_color"
        android:layout_margin="20dp"
        android:layout_gravity="center"/>
</LinearLayout>

在Activity中使用如下

package com.why.project.tabtopautotextsizelayout;

import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.view.View;
import android.widget.Button;
import android.widget.TextView;

import com.why.project.tabtopautotextsizelayout.tab.TabTopAutoTextSizeLayout;

import java.util.ArrayList;

public class MainActivity extends AppCompatActivity {

    private Button mChangeBtn;
    private TextView mSelectedTextSizeTV;//选中的文字大小的展现view

    private static String[] fontSizes = {"10","12","14","16","18","20","22","24","26","30","36","42"};
private String fontSizeUnit = "px";
    private TabTopAutoTextSizeLayout mTextSizeLayout;

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

        initViews();
        initDatas();
        initEvents();
    }

    private void initViews() {
        mChangeBtn = (Button) findViewById(R.id.btn_change);
        mSelectedTextSizeTV = (TextView) findViewById(R.id.text_size_view);

        mTextSizeLayout = (TabTopAutoTextSizeLayout) findViewById(R.id.tab_textsizeLayout);
    }

    private void initDatas() {
        ArrayList<CharSequence> textSizeArray = new ArrayList<CharSequence>();//用于展现
        for(int i=0;i<fontSizes.length;i++){
            textSizeArray.add(fontSizes[i]);
        }

        mTextSizeLayout.setTabList(textSizeArray);
    }

    private void initEvents() {
        //模拟更改字体
        mChangeBtn.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                int selectedTextSize = 24;
                mSelectedTextSizeTV.setText(selectedTextSize + fontSizeUnit);
                int selectedIndex = 0;
                for(int i = 0;i<fontSizes.length;i++){
                    if(Integer.parseInt(fontSizes[i]) == selectedTextSize){
                        selectedIndex = i;
                        break;
                    }
                }
                mTextSizeLayout.setTabsDisplay(selectedIndex);
            }
        });
        //字号的点击事件
        mTextSizeLayout.setOnTopTabSelectedListener(new TabTopAutoTextSizeLayout.OnTextSizeItemSelectListener() {
            @Override
            public void onTextSizeItemSelected(int index) {
                mSelectedTextSizeTV.setText(fontSizes[index] + fontSizeUnit);//带单位
            }
        });
    }
}

混淆配置

参考资料

暂时空缺

项目demo下载地址

https://github.com/haiyuKing/TabTopAutoTextSizeLayout

posted @ 2018-07-07 16:27  HaiyuKing  阅读(461)  评论(0编辑  收藏  举报