笔记与Android选项卡一周

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了笔记与Android选项卡一周相关的知识,希望对你有一定的参考价值。

果然,还是项目驱动的学习方式比较有趣呢。

这周的学习全部围绕着选项卡,也就是tab。

用到了好多知识点,都不知道从哪里开始啦(≧o≦*)。


    选项卡的制作有很多方法。选项菜单可以用普通的TextView,也可以直接上button。我选择的是TextView,可能更接近网页的思路吧。

先列个清单出来:

  1. selector

  2. Fragment

  3. ViewPager

布局嘛,网上有一堆,就不提了。


1.selector

    选项卡的功能,就是按不同的按钮就能切换到不同页面。作为反馈,按钮总得有点变化,比如换个颜色。实现思路很简单,点击之后换个图标就好了嘛。嗯~o(* ̄▽ ̄*)o,然而在onClick上折腾半天之后,我打开了百度,很快发现了selector这个标签。

Σヽ(Д ; )居然还有这种操作!

     selector用起来很简单,写在drawable目录下:

for_tab1.xml:

<selector xmlns:android="http://schemas.android.com/apk/res/android">
   <item android:drawable="@drawable/ic_news_act" android:state_selected="true" />
   <item android:drawable="@drawable/ic_news" />
</selector>

    ic_news和ic_news_act是通过new->Image Asset导入的图标,自动生成各种规格,免去了手动处理图片大小的麻烦。和.9图应该是一样的效果吧(.9图?我没做,我不懂)。


    接着在主界面的TextView写上这句话:

    android:drawableTop="@drawable/for_tab1"

    完工!

    改变item标签内的属性名(比如color),就可以改变其他效果。



2.Fragment

    接着就是内容匹配。每个选项卡对应一个内容,一个内容就是一个Fragment。

    android中一个页面可以看作一个Activity,而Fragment只是”碎片“,生命周期不会长于所存在的Activity。查看配置文件AndroidManifest.xml可以发现,Fragment是没有注册的。

     最简单的Fragment,就是重写onCreatView:

View onCreateView(LayoutInflater inflater, ViewGroup container,
                         Bundle savedInstanceState) {
    View view =  inflater.inflate(R.layout., container, );
    view;

}

这时冒出了个inflater!你是谁?inflater说我只是个控制器,连接视图和模型。啊~虽然没有明白,但我暂时放过你,小心点inflater,我会盯着你的!

    


3.ViewPager

    铛~铛~铛~

    ViewPager来了!快让开!

    诶,Fragment好像没讲完啊?没办法呀,Fragment没人(activity)权啊,只能靠主子(activity)接济过活╮(╯3╰)╭。ViewPager就是从Activity派来的走狗,啊呸,使者!

   1 ViewPager可说是这个选项卡的核心。每个Fragment是选项卡显示的内容,ViewPager像是内容的容器,同时担任调度的工作。

    布局里的ViewPager看起来就是个普通的标签,但是人家上头有人!

    ViewPager需要一个FragmentAdapter才能工作。

    这是个超简单的实现:

tabFragmentAdapter FragmentPagerAdapter {
    ArrayList<Fragment>  ;
    =;
    tabFragmentAdapter(FragmentManager fm, ArrayList<Fragment> list){
        (fm);
        .= list;
    }
    Fragment getItem(position) {
        .get(position);
    }

    getCount() {
        ;
    }
}

    入口在主界面的Java类中:

 fa = (getSupportFragmentManager(), );
.setAdapter(fa);

fg是填入了所有Fragment的ArrayList。

getSupperFragmentManager()取到了主界面的FragmentManager。

vp是用id获取的布局中的ViewPager。


在tab所在的主界面的Java类的onCreate()中运行,就绑定好了这些Fragment。



2Listener人呢?给tab们绑定好事件就该你上场了

tabListener View.OnClickListener {
    = ;

    tabListener(index) {
        .= index;
    }

    onClick(View v) {
        .setCurrentItem();
        clearSelect();
        .get().setSelected();
    }
}

index是区分tab的编号;

clearSelect是将tab卡片选择状态重置(用setSelected(false));

tabList里装的是作为tab按钮的TextView;

绑定事件应该会,,,吧?

(i = ; i < .size(); i++) {
    .get(i).setOnClickListener(tabListener(i));
}

似乎很简单,但是我不会告诉你,有一半时间花在了调空指针的BUG!


以上是关于笔记与Android选项卡一周的主要内容,如果未能解决你的问题,请参考以下文章

20179223《Linux内核原理与分析》第十一周学习笔记

笔记与Android酱的第一周

带有片段的 Android Up 按钮未显示完整片段

选项卡执行android中下一个片段中存在的代码

操作栏标签片段中的片段?

Android:使用Tab检测单个片段viewpager