最近在学习TabLayout的时候,发现个问题,刚进入的时候,第一个tab并没有变成我们想要的选中状态。
设置选中的状态如下:

tabLayout.addOnTabSelectedListener(new TabLayout.OnTabSelectedListener() {
            @Override
            public void onTabSelected(TabLayout.Tab tab) {
                View customView = tab.getCustomView();
                TextView tabItem = customView.findViewById(R.id.tv_tab_item);
                tabItem.setBackgroundColor(Color.parseColor("#ff5500"));
                pager.setCurrentItem(tab.getPosition());
            @Override
            public void onTabUnselected(TabLayout.Tab tab) {
                View customView = tab.getCustomView();
                TextView tabItem = customView.findViewById(R.id.tv_tab_item);
                tabItem.setBackgroundColor(Color.parseColor("#ffffff"));
            @Override
            public void onTabReselected(TabLayout.Tab tab) {               
        });
        tabLayout.getTabAt(0).select();

在这里插入图片描述
就是这种情形,只是将textview的背景色设为橙色,但是如果上面代码设置的话,刚进入的时候是都没有选中的。虽然设置了tabLayout.getTabAt(0).select();,但是会发现是没有效果的,后面跟进源码发现

public void select() {
            if (this.parent == null) {
                throw new IllegalArgumentException("Tab not attached to a TabLayout");
            } else {
                this.parent.selectTab(this);

进入到父布局的设置选中

    void selectTab(TabLayout.Tab tab) {
        this.selectTab(tab, true);
    void selectTab(TabLayout.Tab tab, boolean updateIndicator) {
        TabLayout.Tab currentTab = this.selectedTab;
        if (currentTab == tab) {
            if (currentTab != null) {
                this.dispatchTabReselected(tab);
                this.animateToTab(tab.getPosition());
        } else {
            int newPosition = tab != null ? tab.getPosition() : -1;
            if (updateIndicator) {
                if ((currentTab == null || currentTab.getPosition() == -1) && newPosition != -1) {
                    this.setScrollPosition(newPosition, 0.0F, true);
                } else {
                    this.animateToTab(newPosition);
                if (newPosition != -1) {
                    this.setSelectedTabView(newPosition);
            this.selectedTab = tab;
            if (currentTab != null) {
                this.dispatchTabUnselected(currentTab);
            if (tab != null) {
                this.dispatchTabSelected(tab);

会发现如果当前选中的布局和设置选中的布局是同一个的时候,就会调用dispatchTabReselected(tab);

private void dispatchTabReselected(@NonNull TabLayout.Tab tab) {
        for(int i = this.selectedListeners.size() - 1; i >= 0; --i) {
            ((TabLayout.BaseOnTabSelectedListener)this.selectedListeners.get(i)).onTabReselected(tab);

就会回调new TabLayout.OnTabSelectedListener() 中的onTabReselected方法,但是我们没有在这个方法内部进行选中设置,所以才会导致刚进入时候三个选项卡都没有选中,这里只要把onTabReselected中设置选中状态即可
完整的代码如下:

tabLayout.addOnTabSelectedListener(new TabLayout.OnTabSelectedListener() {
            @Override
            public void onTabSelected(TabLayout.Tab tab) {
                View customView = tab.getCustomView();
                TextView tabItem = customView.findViewById(R.id.tv_tab_item);
                tabItem.setBackgroundColor(Color.parseColor("#ff5500"));
                pager.setCurrentItem(tab.getPosition());
            @Override
            public void onTabUnselected(TabLayout.Tab tab) {
                View customView = tab.getCustomView();
                TextView tabItem = customView.findViewById(R.id.tv_tab_item);
                tabItem.setBackgroundColor(Color.parseColor("#ffffff"));
            @Override
            public void onTabReselected(TabLayout.Tab tab) {
                View customView = tab.getCustomView();
                TextView tabItem = customView.findViewById(R.id.tv_tab_item);
                tabItem.setBackgroundColor(Color.parseColor("#ff5500"));
                pager.setCurrentItem(tab.getPosition());
        });
        tabLayout.getTabAt(0).select();

这样就没有问题了。

重点:通过view的layout方法 只是修改view1显示区域,没有实际修改view中LayoutParams的值 。所以,虽然view1(可见)显示区域变小了,但LayoutParams的值没有改变。因此,改变View的大小,建议使用view1.setLayoutParams(params)。 这也是作者“实验二”中,下面的view无法自动上移的原因。因为view1的LayoutParam... -------- >题目:小科去了一家新的公司做前端主管,发现里面的前端代码有一部分是 C/C++ 程序员写的,他们喜欢用下划线命名,例如: is_good。小科决定写个脚本来全部替换掉这些变量名。 完成 toCamelCaseVar 函数,它可以接受一个字符串作为参数,可以把类似于 is_good 这样的变量名替换成 isGood。变量名首尾的下划线不需要做处理,中间的下划线全部删除并且处理成驼峰。 ## 题解一 ```javascript 我使用TabLayout与ViewPager相结合,我为我的选项卡设置了自定义视图。如果选中和取消选中选项卡(自定义视图根据选定/选定选项卡进行更改),一切都按预期工作。问题是在第一次启动时,onTabSelected方法从不被调用。这里是我的活动:Android - onTabSelected第一次没有使用自定义视图调用setupViewPager(viewPager);tabLayout.s... 写一个demo时发现,其中TabLayout作为底部导航栏,默认选中竟然无法回调onTabSelected,而选择其他Position时,可以正常回调回来 原因是因为我们是先addTab这个时候还没有绑定回调方法,所以应该是先是设置回调,而后add mTabLayout = findViewById(R.id.tab_layout); mTabLayout.addOnTabSelectedListener(new TabLayout.OnTabSelectedListen 在android studio上新建一个空项目,项目可以在android5.0的系统上正常运行,在android4.0的系统上一打开就奔溃。 在网上搜索答案,在这个链接里看到信息: http://bbs.csdn.net/topics/391910446 以下是解决问题的答案的截图: 什么是标签的显示模式?标签以什么方式进行显示,比如div自己占一行,比如span一行可以放很多个作用我们网页的标签非常多,再不同地方会用到不同类型的标签,以便更好的完成我们的网页。标签的类型(分类)HTML标签一般分为块标签和行内标签两种类型,它们也称块元素和行内元素。元素模式元素排列设置样式默认宽度包含块级元素一行只能放一个块级元素可以设置宽度高度容器的100%容器级可以包含任何标签行内元素一行可以放多个行内元素不可以直接设置宽度高度它本身内容的宽度属性。......   曾经几次有朋友问,如何使用托管代码简单地精确获取一个对象在堆或栈中所占内存的大小。我想说,这基本上很难,呵呵。想要做到通用又精确,则必然涉及到 CLR 对载入类型自动的内存布局 (Layout) 控制逻辑,而这部分的逻辑,又是 CLR 在设计时就刻意隐藏的。    CLR 的架构设计师 Chris Brumme 在去年的一篇 blog 中曾经简要地讨论了这个问题,Size of a manag error: ‘make_unique’ is not a member of ‘std’ 问题解释: 在编译使用了std::make_unique语句的代码时,如果出现上述的错误,说明该编译器不支持C++14标准,因为std::make_unique是在C++14以后新加入的函数,用来创建std::unique_ptr智能指针对象。 解决方法: 1、尝试升级编译器版本支持C++14标准; 2、在代码中自己定义这个函数: #include <memory> namespace std {