編輯:關於Android編程
關於實現網易新聞客戶端的界面,以前寫過很多博客,請參考:
Android實現網易新聞客戶端效果
Android實現網易新聞客戶端側滑菜單(一)
Android實現網易新聞客戶端側滑菜單(二)
今天用ViewPager + FragmentAdapter + ViewPagerIndicator來實現。
ViewPagerIndicator是一款分頁指標小部件兼容ViewPager,封裝上做得非常不錯,目前已為眾多知名應用所使用。具體API的使用,大家可以下載官方demo示例研究研究就知道啦!
下載地址:https://github.com/JakeWharton/ViewPagerIndicator
sample是提供給我們的例子,library是庫工程,我們需要將其作為我們自己項目的依賴庫,我們新建一個Android工程,將library導入工程我就不介紹了。
注:
Eclipse: 如果你新建的項目libs目錄下面有android-support-v4.jar,你要將其刪除,因為ViewPageIndicator裡面有這個庫,我們項目中不允許兩個android-support-v4.jar,不刪除我們的項目不能編譯的。
Android Studio: 直接import module就行。
activity_main.xml
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" > <include layout="@layout/activity_top" /> <com.viewpagerindicator.TabPageIndicator android:id="@+id/indicator" android:layout_width="match_parent" android:layout_height="wrap_content" android:background="@android:color/transparent" > </com.viewpagerindicator.TabPageIndicator> <android.support.v4.view.ViewPager android:id="@+id/viewpager" android:layout_width="match_parent" android:layout_height="match_parent" android:background="#EEF3FA"> </android.support.v4.view.ViewPager> </LinearLayout>
布局很簡單,頂部引入了一個activity_top.xml的布局,具體內容可以自己定義。
MainActivity.java
package com.jackie.neteasenews;
import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentActivity;
import android.support.v4.view.ViewPager;
import com.viewpagerindicator.TabPageIndicator;
import java.util.ArrayList;
import java.util.List;
public class MainActivity extends FragmentActivity {
private TabPageIndicator mTabPageIndicator;
private ViewPager mViewPager;
private ViewPagerIndicatorAdapter mAdapter;
private HeadlineFragment mHeadlineFragment;
private EnjoyFragment mEnjoyFragment;
private HotspotFragment mHotspotFragment;
private SportFragment mSportFragment;
private HouseFragment mHouseFragment;
private List<Fragment> mFragmentList;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
initView();
}
private void initView() {
mTabPageIndicator = (TabPageIndicator) findViewById(R.id.indicator);
mViewPager = (ViewPager) findViewById(R.id.viewpager);
mHeadlineFragment = new HeadlineFragment();
mEnjoyFragment = new EnjoyFragment();
mHotspotFragment = new HotspotFragment();
mSportFragment = new SportFragment();
mHouseFragment = new HouseFragment();
mFragmentList = new ArrayList<>();
mFragmentList.add(mHeadlineFragment);
mFragmentList.add(mEnjoyFragment);
mFragmentList.add(mHotspotFragment);
mFragmentList.add(mSportFragment);
mFragmentList.add(mHouseFragment);
mAdapter = new ViewPagerIndicatorAdapter(getSupportFragmentManager(), mFragmentList);
mViewPager.setAdapter(mAdapter);
//實例化TabPageIndicator然後設置ViewPager與之關聯
mTabPageIndicator.setViewPager(mViewPager, 1);
}
}
ViewPagerIndicatorAdapter.java
package com.jackie.neteasenews;
import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentManager;
import android.support.v4.app.FragmentPagerAdapter;
import java.util.List;
public class ViewPagerIndicatorAdapter extends FragmentPagerAdapter {
private List<Fragment> mFragmentList;
public static String[] TITLES = new String[] { "頭條", "娛樂", "熱點", "體育", "房產" };
public ViewPagerIndicatorAdapter(FragmentManager fm, List<Fragment> fragmentList) {
super(fm);
this.mFragmentList = fragmentList;
}
@Override
public Fragment getItem(int position) {
return mFragmentList.get(position);
}
@Override
public int getCount() {
return mFragmentList.size();
}
@Override
public CharSequence getPageTitle(int position) {
return TITLES[position];
}
}
代碼很簡單,但是有一點,上面的Indicator是系統默認的,不太好看,所以還需要在styles.xml添加下面的樣式:
<style name="StyledTabPageIndicator" parent="@android:style/Theme.Light"> <item name="vpiTabPageIndicatorStyle">@style/CustomTabPageIndicator</item> <item name="android:windowNoTitle">true</item> <item name="android:animationDuration">5000</item> <item name="android:windowContentOverlay">@null</item> </style> <style name="CustomTabPageIndicator" parent="Widget"> <item name="android:gravity">center</item> <item name="android:background">@drawable/tab_indicator</item> <!--<item name="android:background">@drawable/vpi__tab_indicator</item>--> <item name="android:paddingLeft">22dip</item> <item name="android:paddingRight">22dip</item> <item name="android:paddingTop">8dp</item> <item name="android:paddingBottom">8dp</item> <item name="android:textAppearance">@style/CustomTabPageIndicator.Text</item> <item name="android:textSize">16sp</item> <item name="android:maxLines">1</item> </style> <style name="CustomTabPageIndicator.Text" parent="Widget"> <item name="android:textColor">@drawable/tab_text</item> </style>
注意:開發中過程中跟Fragment相關的類,導入包時會提示兩個包android.app 和 android.support.v4.app,切記,要保證所有類都導入同一個包下的,否則會編譯報錯。
效果圖如下:

附上源碼地址:https://github.com/shineflower/NeteaseNews.git
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持本站。
微信發不出去怎麼辦 微信不能發信息怎麼辦
微信可以說是我們當下非常常用的手機軟件,很多人都會選擇它來進行交流。有的時候,我們在使用微信的過程中也會發現很多問題,今天,小編就來講講微信發不出信息怎麼辦
Android自定義控件實戰——仿淘寶商品浏覽界面
用手機淘寶浏覽商品詳情時,商品圖片是放在後面的,在第一個ScrollView滾動到最底下時會有提示,繼續拖動才能浏覽圖片。仿照這個效果寫一個出來並不難,只要
微信讀書APP設置背景顏色的方法
騰訊新出了微信讀書APP,外界很多都在討論他是否兼具了讀書和社交的雙重功能呢?讓我們拭目以待!使用微信讀書時有些同學遇到一些問題,比如不知道微信讀書怎麼設置
談談Android Fragments 詳細使用
Fragments 誕生初衷自從Android 3.0中引入fragments 的概念,根據詞海的翻譯可以譯為:碎片、片段。其上的是為了解決不同屏幕分辯率的動態和靈活UI