zoukankan      html  css  js  c++  java
  • Android -- FragmentTabHost实现微信底部切换

    1,在商城类的项目中我们开始一个项目的时候经常出现这样的需求,如下图所示:

    下面使用户可以切换的模块,上面是对应的模块的详细内容,实现这个效果有很多方式,可以使用radiobutton+fragment来实现,也可以用LinearLayout+fragment来实现,但是如何很快速的把我们的ui框架给搭建起来呢,今天就给大家介绍使用Fragment+FragmentTabHost来实现。

    2,说一下FragmentTabHost实现的步骤吧:

     ①、Activity要继承FragmentActivity

     ②、调用FragmentTabHost的setup()方法

     ③、添加TabSpec

    ok,那让我们一起来实现一下吧

    首先,创建布局文件,可以看到,由于我们的fragment要放在FragmentTabHost的上面,所以创建了一个realtabcontent,但是官网给的给的FragmentTabHost的使用方法是必须在这个控件里面放一个fragment,那我们就来放一个假的fragment吧。布局代码如下:

    <?xml version="1.0" encoding="utf-8"?>
    <LinearLayout
        xmlns:android="http://schemas.android.com/apk/res/android"
        xmlns:tools="http://schemas.android.com/tools"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="vertical"
        tools:context="com.wangjitao.myfragmenttabhost.MainActivity">
    
        <FrameLayout
            android:id="@+id/realtabcontent"
            android:layout_width="match_parent"
            android:layout_height="0dp"
            android:layout_weight="1"
            android:background="@color/white"
            />
        <android.support.v4.app.FragmentTabHost
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:id="@+id/tabhost"
            android:background="@color/white"
            >
            <FrameLayout
                android:id="@android:id/tabhost"
                android:layout_width="0dp"
                android:layout_height="0dp"
                android:layout_weight="0"
                />
        </android.support.v4.app.FragmentTabHost>
    
    </LinearLayout>
    

    然后我们要创建一个MainActivity,需要的是继承Fragment ,由于我们的AppCompatActivity是继承Fragment的(不知道的同学可以去看一下源码),所以我们直接去继承一下AppCompatActivity就行,这就实现了我们使用FragmentTabHost使用的第一个要求,然后找到我们的FragmentTabHost,调用其setup()方法 

    mTabHost.setup(this, getSupportFragmentManager(), R.id.realtabcontent);
    

    可以看到,第一个参数是上下文环境,第二个参数是我们的FragmentManager,第三个参数是要与我们FragmentTabHost切换的同步的Fragment,ok这样我们的第二个要求就写完成了。然后是我们的四三个要求,添加TabSpec,代码如下:

    mTabHost.addTab(mTabHost.newTabSpec(getString(mTabs.get(i).getTitle())).setIndicator(view),
                        mTabs.get(i).getFragment(), null);
    

    首先我们要创建一个TabSpec,所以调用TabHost.newTabSpec(我们tab的title).setIndicator(对应的图标和文字的布局)

    来看一下我们view的布局,很简单的,就是一个图标和一个textview

    <?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:layout_gravity="center"
                  android:gravity="center"
                  android:orientation="vertical"
                  android:paddingBottom="3dp"
                  android:paddingTop="3dp"
        >
    
        <ImageView
            android:id="@+id/icon_tab"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            />
    
        <TextView
            android:id="@+id/txt_indicator"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_marginTop="2dp"
            android:textColor="@color/selector_tab_text"
            />
    </LinearLayout>
    

    ok,由于一个Tab对应的有一个title,一个icon,一个对应的fragment,所以我们可以把这个Tab抽出来,创建出来这个对象Tab.java

    package com.wangjitao.myfragmenttabhost.bean;
    
    /**
     * Created by jh on 2016/5/10.
     */
    public class Tab {
        private int title ;
        private int icon ;
        private Class fragment ;
    
        public Tab(int title, int icon, Class fragment) {
            this.title = title;
            this.icon = icon;
            this.fragment = fragment;
        }
    
        public int getTitle() {
            return title;
        }
    
        public void setTitle(int title) {
            this.title = title;
        }
    
        public int getIcon() {
            return icon;
        }
    
        public void setIcon(int icon) {
            this.icon = icon;
        }
    
        public Class getFragment() {
            return fragment;
        }
    
        public void setFragment(Class fragment) {
            this.fragment = fragment;
        }
    }
    

    ok,这样的话加上我们的选择器和对应的fragment,代码基本上就ok了

    就简单的贴一个例子选择器和fragment代码就行了  

    TabHome.java

    package com.wangjitao.myfragmenttabhost.fragment;
    
    import android.os.Bundle;
    import android.support.annotation.Nullable;
    import android.support.v4.app.Fragment;
    import android.view.LayoutInflater;
    import android.view.View;
    import android.view.ViewGroup;
    
    import com.wangjitao.myfragmenttabhost.R;
    
    /**
     * Created by jh on 2016/5/10.
     */
    public class HomeFragment extends Fragment {
        @Nullable
        @Override
        public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
            View view = inflater.inflate(R.layout.tab_home, null);
            return view;
        }
    }  

     对应的图片的selector

    <?xml version="1.0" encoding="utf-8"?>
    <selector xmlns:android="http://schemas.android.com/apk/res/android">
    
        <item android:drawable="@drawable/weixin_pressed" android:state_selected="true"/>
        <item android:drawable="@drawable/weixin_normal"/>
    
    </selector>
    

    再加上对应的文字的selector

    <?xml version="1.0" encoding="utf-8"?>
    <selector xmlns:android="http://schemas.android.com/apk/res/android">
       <item android:color="#0c760c" android:state_selected="true"/>
        <item android:color="#0c760c" android:state_active="true"/>
        <item android:color="#a9b7b7" android:state_selected="false"/>
        <item android:color="#a9b7b7" android:state_active="false"/>
    </selector>
    

    MainActivity.java

    package com.wangjitao.myfragmenttabhost;
    
    import android.content.Context;
    import android.media.Image;
    import android.support.v4.app.FragmentTabHost;
    import android.support.v7.app.AppCompatActivity;
    import android.os.Bundle;
    import android.view.LayoutInflater;
    import android.view.View;
    import android.widget.ImageView;
    import android.widget.LinearLayout;
    import android.widget.TextView;
    
    import com.wangjitao.myfragmenttabhost.bean.Tab;
    import com.wangjitao.myfragmenttabhost.fragment.AddressFragment;
    import com.wangjitao.myfragmenttabhost.fragment.FindFriendFragment;
    import com.wangjitao.myfragmenttabhost.fragment.HomeFragment;
    import com.wangjitao.myfragmenttabhost.fragment.SettingsFragment;
    
    import java.util.ArrayList;
    import java.util.List;
    
    public class MainActivity extends AppCompatActivity {
    
        private Context mContext = MainActivity.this ;
        private FragmentTabHost mTabHost ;
        private LayoutInflater mInflater ;
        private List<Tab> mTabs = new ArrayList<>();
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_main);
    
            //1,activity 继承FragmentActivity  AppCompatActivity本身就是继承的FragmentActivity
    
            //2,调用FragmentTabHost的setup方法
    
    //        View view = mInflater.inflate(R.layout.tab_indicator,null) ;
    //        ImageView img = (ImageView) view.findViewById(R.id.icon_tab);
    //        TextView tex = (TextView) view.findViewById(R.id.txt_indicator);
    //
    //
    //        img.setImageResource(R.mipmap.tab_address_normal);
    //        tex.setText("主页");
    //
    //        mTabHost.addTab(mTabHost.newTabSpec("home").setIndicator(view), HomeFragment.class, null);
    
            initTab();
        }
    
        private void initTab() {
            mInflater = LayoutInflater.from(this);
    
            mTabHost = (FragmentTabHost) findViewById(R.id.tabhost);
            mTabHost.setup(this, getSupportFragmentManager(), R.id.realtabcontent);
    
            Tab tab_nome = new Tab(R.string.home,R.drawable.tab_weixin,HomeFragment.class) ;
            Tab tab_address = new Tab(R.string.address,R.drawable.tab_profile,AddressFragment.class) ;
            Tab tab_find_friend = new Tab(R.string.findfriend,R.drawable.tab_find,FindFriendFragment.class) ;
            Tab tab_setting = new Tab(R.string.setting,R.drawable.tab_contact_list,SettingsFragment.class) ;
    
            mTabs.add(tab_nome);
            mTabs.add(tab_address);
            mTabs.add(tab_find_friend);
            mTabs.add(tab_setting);
    
            for (int i = 0 ; i < mTabs.size() ;i++ ){
                View view = mInflater.inflate(R.layout.tab_indicator,null) ;
                ImageView img = (ImageView) view.findViewById(R.id.icon_tab);
                TextView tex = (TextView) view.findViewById(R.id.txt_indicator);
    
    
                img.setImageResource(mTabs.get(i).getIcon());
                tex.setText(mTabs.get(i).getTitle());
    
                mTabHost.addTab(mTabHost.newTabSpec(getString(mTabs.get(i).getTitle())).setIndicator(view),
                        mTabs.get(i).getFragment(), null);
            }
    
            mTabHost.getTabWidget().setShowDividers(LinearLayout.SHOW_DIVIDER_NONE);
            mTabHost.setCurrentTab(0);
        }
    }
    

     ok ,这样就完全实现了,看一下效果图(丑哭了,找不到好的UI图 流泪):

     

      

      

     

      

     

      

  • 相关阅读:
    nrm安装与配置(nrm管理npm源)
    Mac启动MongoDB报错:exception in initAndListen: NonExistentPath: Data directory /data/db not found., terminating
    基本类型(例如:int)数组和ArrayList之间的转化
    sqlite3--sqlite3_prepare
    fgets
    strdup
    openssl-EVP_md5()
    FIPS--Federal Information Processing Standards
    pthread_mutexattr_gettype、pthread_mutexattr_settype、pthread_mutexattr_destroy、pthread_mutexattr_init!
    gethostname&&getdomainname
  • 原文地址:https://www.cnblogs.com/wjtaigwh/p/5488621.html
Copyright © 2011-2022 走看看