亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Android仿微信主界面的實現(xiàn)方法

 更新時間:2018年04月14日 14:00:48   作者:OliverBuddy  
這篇文章主要為大家詳細介紹了Android仿微信主界面的實現(xiàn)方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了Android模仿微信主界面展示的具體代碼,供大家參考,具體內(nèi)容如下

先看一下效果圖

這里寫圖片描述

實現(xiàn)的原理:

ViewPager+FragmentPagerAdapter

主界面可分為三部分:

  • top標題欄就是一個TextView
  • 中間的ViewPager作為顯示的容器,填充Fragment
  • bottom是一個RadioGroup

這里為了布局的優(yōu)化,將top和bottom抽取出來 ,然后用include將其導入主布局,如下

<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=".MainActivity" >

  <include layout="@layout/top" />

  <android.support.v4.view.ViewPager
    android:id="@+id/vp_content"
    android:layout_width="match_parent"
    android:layout_height="0dp"
    android:layout_weight="1" >
  </android.support.v4.view.ViewPager>

  <include layout="@layout/bottom" />
</LinearLayout>

bottom_tab的布局,為了方便管理將它們的共性抽取出來一個style
tab有兩種狀態(tài),選中和非選中,因此將其背景做成一個選擇器selector

<?xml version="1.0" encoding="utf-8"?>
<RadioGroup xmlns:android="http://schemas.android.com/apk/res/android"
  android:id="@+id/rg_tab_container"
  android:layout_width="match_parent"
  android:layout_height="@dimen/bar_height"
  android:background="@drawable/bottom_bar"
  android:gravity="center"
  android:orientation="horizontal" >

  <RadioButton
    android:id="@+id/rb_tab_weixin"
    style="@style/TabStyle"
    android:checked="true"
    android:drawableTop="@drawable/tab_weixin_selector"
    android:text="@string/tab_weixin" />

  <RadioButton
    android:id="@+id/rb_tab_friend"
    style="@style/TabStyle"
    android:drawableTop="@drawable/tab_friend_selector"
    android:text="@string/tab_friend" />

  <RadioButton
    android:id="@+id/rb_tab_contact"
    style="@style/TabStyle"
    android:drawableTop="@drawable/tab_contact_selector"
    android:text="@string/tab_contact" />

  <RadioButton
    android:id="@+id/rb_tab_setting"
    style="@style/TabStyle"
    android:drawableTop="@drawable/tab_setting_selector"
    android:text="@string/tab_setting" />

</RadioGroup>

最后看一下作為Controller的Activity

  1. 先將需要的控件引入
  2. ViewPager內(nèi)容的填充,主要是FragmentPagerAdapter適配器
  3. 將Fragment的初始化,將主界面顯示的內(nèi)容分別用Fragment管理,方便代碼的管理。
  4. bottom_tab和ViewPager的關聯(lián),通過監(jiān)聽ViewPager頁面的改變來改變tab的選中狀態(tài),然后再通過RadioGroup的事件來改變ViewPager的頁面。

/**
 * 主界面 模仿微信界面
 * 
 * @author admin
 * 
 */
public class MainActivity extends FragmentActivity {

  /** tab */
  private RadioGroup mRadioGroup;

  private RadioButton weixinRadioButton;
  private RadioButton friendRadioButton;
  private RadioButton contactRadioButton;
  private RadioButton settingRadioButton;

  /** 顯示內(nèi)容容器 */
  private ViewPager mViewPager;

  private List<Fragment> fragments;

  private Fragment mWeiXinFragment;
  private Fragment mFriendFragment;
  private Fragment mContactFragment;
  private Fragment mSettingFragment;

  private FragmentPagerAdapter mFragmentPagerAdapter;

  private final static int TAB_WEIXIN = 0;
  private final static int TAB_FRIEND = 1;
  private final static int TAB_CONTACT = 2;
  private final static int TAB_SETTING = 3;

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

    initView();

    initEvent();
  }

  private void initEvent() {

    mRadioGroup.setOnCheckedChangeListener(myCheckedChangeListener);
    mViewPager.setOnPageChangeListener(myOnPageChangeListener);
  }

  private void initView() {
    mRadioGroup = (RadioGroup) findViewById(R.id.rg_tab_container);

    weixinRadioButton = (RadioButton) findViewById(R.id.rb_tab_weixin);
    friendRadioButton = (RadioButton) findViewById(R.id.rb_tab_friend);
    contactRadioButton = (RadioButton) findViewById(R.id.rb_tab_contact);
    settingRadioButton = (RadioButton) findViewById(R.id.rb_tab_setting);

    mViewPager = (ViewPager) findViewById(R.id.vp_content);

    fragments = new ArrayList<Fragment>();

    mWeiXinFragment = new WeiXinFragment();
    mFriendFragment = new FriendFragment();
    mContactFragment = new ContactFragment();
    mSettingFragment = new SettingFragment();

    fragments.add(mWeiXinFragment);
    fragments.add(mFriendFragment);
    fragments.add(mContactFragment);
    fragments.add(mSettingFragment);
//這里需要繼承FragmentActivity
    mFragmentPagerAdapter = new FragmentAdapter(getSupportFragmentManager());
    mViewPager.setAdapter(mFragmentPagerAdapter);

  }

  /**
   * 當頁面切換時,tab也跟著切換
   */
  private OnPageChangeListener myOnPageChangeListener = new OnPageChangeListener() {

    @Override
    public void onPageSelected(int arg0) {
      switch (arg0) {
      case TAB_WEIXIN:

        if (!weixinRadioButton.isChecked()) {
          weixinRadioButton.setChecked(true);
        }
        break;
      case TAB_FRIEND:
        friendRadioButton.setChecked(true);

        break;
      case TAB_CONTACT:
        contactRadioButton.setChecked(true);

        break;
      case TAB_SETTING:
        settingRadioButton.setChecked(true);

        break;

      }
    }

    @Override
    public void onPageScrolled(int arg0, float arg1, int arg2) {

    }

    @Override
    public void onPageScrollStateChanged(int arg0) {

    }
  };

  /**
   * 點擊tab,切換到相應的頁面
   */
  private OnCheckedChangeListener myCheckedChangeListener = new OnCheckedChangeListener() {

    @Override
    public void onCheckedChanged(RadioGroup group, int checkedId) {

      switch (checkedId) {
      case R.id.rb_tab_weixin:

        mViewPager.setCurrentItem(TAB_WEIXIN);
        break;
      case R.id.rb_tab_friend:

        mViewPager.setCurrentItem(TAB_FRIEND);
        break;
      case R.id.rb_tab_contact:

        mViewPager.setCurrentItem(TAB_CONTACT);
        break;
      case R.id.rb_tab_setting:
        mViewPager.setCurrentItem(TAB_SETTING);

        break;

      }
    }
  };

  private class FragmentAdapter extends FragmentPagerAdapter {

    public FragmentAdapter(FragmentManager fm) {
      super(fm);
    }

    @Override
    public Fragment getItem(int arg0) {
      return fragments.get(arg0);
    }

    @Override
    public int getCount() {
      return fragments.size();
    }

  }

}

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • android實現(xiàn)倒計時動態(tài)圈

    android實現(xiàn)倒計時動態(tài)圈

    這篇文章主要為大家詳細介紹了android實現(xiàn)倒計時動態(tài)圈,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-01-01
  • Android 實例開發(fā)一個學生管理系統(tǒng)流程詳解

    Android 實例開發(fā)一個學生管理系統(tǒng)流程詳解

    讀萬卷書不如行萬里路,只學書上的理論是遠遠不夠的,只有在實戰(zhàn)中才能獲得能力的提升,本篇文章手把手帶你用Java實現(xiàn)一個學生管理系統(tǒng),大家可以在過程中查缺補漏,提升水平
    2021-11-11
  • Android開發(fā)之電話撥號器實例詳解

    Android開發(fā)之電話撥號器實例詳解

    這篇文章主要介紹了Android開發(fā)之電話撥號器,結合實例形式詳細分析了Android電話撥號器的實現(xiàn)步驟與具體代碼,并附帶了一個Android開放電話撥號器的學習筆記,需要的朋友可以參考下
    2015-12-12
  • Android利用zxing生成二維碼的過程記錄

    Android利用zxing生成二維碼的過程記錄

    Android中二維碼生成的最常用庫就是zxing了,正好目前項目有了生成二維碼的需求,所以下面這篇文章主要給大家介紹了關于Android利用zxing生成二維碼的相關資料,需要的朋友可以參考下
    2021-07-07
  • Android實現(xiàn)圖文垂直跑馬燈效果

    Android實現(xiàn)圖文垂直跑馬燈效果

    這篇文章主要為大家詳細介紹了Android實現(xiàn)圖文垂直跑馬燈效果,圖文結合的跑馬燈效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-08-08
  • Android實現(xiàn)IM多人員組合的群組頭像

    Android實現(xiàn)IM多人員組合的群組頭像

    這篇文章主要為大家詳細介紹了Android實現(xiàn)IM多人員組合的群組頭像,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-10-10
  • Android實現(xiàn)可以展開的TextView

    Android實現(xiàn)可以展開的TextView

    這篇文章主要為大家詳細介紹了Android實現(xiàn)可以展開的TextView,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-11-11
  • android 自定義TabActivity的實例方法

    android 自定義TabActivity的實例方法

    系統(tǒng)自帶的TabActivity的效果不甚理想。開發(fā)中對TabActivity自定義可能有兩種:第一種:改變TAB行的位置,如放到頁面下方。第二種:對TabHost圖片的自定義
    2013-11-11
  • A07_TimePicker & DatePicker & AnalogClock & DigitalClock 的設置小結

    A07_TimePicker & DatePicker & AnalogClock & Digi

    本文將帶領大家一起學習時間日期和時鐘的設置。A07_TimePicker & DatePicker & AnalogClock & DigitalClock 的設置,感興趣的朋友可以參考下哈
    2013-06-06
  • 基于界面適配華為手機的虛擬按鍵的解決方法

    基于界面適配華為手機的虛擬按鍵的解決方法

    下面小編就為大家分享一篇基于界面適配華為手機的虛擬按鍵的解決方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-01-01

最新評論