Android實現(xiàn)網(wǎng)易新聞客戶端首頁效果
關(guān)于實現(xiàn)網(wǎng)易新聞客戶端的界面,以前寫過很多博客,請參考:
Android實現(xiàn)網(wǎng)易新聞客戶端效果
Android實現(xiàn)網(wǎng)易新聞客戶端側(cè)滑菜單(一)
Android實現(xiàn)網(wǎng)易新聞客戶端側(cè)滑菜單(二)
今天用ViewPager + FragmentAdapter + ViewPagerIndicator來實現(xiàn)。
ViewPagerIndicator是一款分頁指標(biāo)小部件兼容ViewPager,封裝上做得非常不錯,目前已為眾多知名應(yīng)用所使用。具體API的使用,大家可以下載官方demo示例研究研究就知道啦!
下載地址:https://github.com/JakeWharton/ViewPagerIndicator
sample是提供給我們的例子,library是庫工程,我們需要將其作為我們自己項目的依賴庫,我們新建一個Android工程,將library導(dǎo)入工程我就不介紹了。
注:
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的布局,具體內(nèi)容可以自己定義。
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然后設(shè)置ViewPager與之關(guān)聯(lián) 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[] { "頭條", "娛樂", "熱點", "體育", "房產(chǎn)" }; 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是系統(tǒng)默認(rèn)的,不太好看,所以還需要在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>
注意:開發(fā)中過程中跟Fragment相關(guān)的類,導(dǎo)入包時會提示兩個包android.app 和 android.support.v4.app,切記,要保證所有類都導(dǎo)入同一個包下的,否則會編譯報錯。
效果圖如下:
附上源碼地址:https://github.com/shineflower/NeteaseNews.git
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Android項目實戰(zhàn)之仿網(wǎng)易新聞的頁面(RecyclerView )
- Android實現(xiàn)仿網(wǎng)易新聞的頂部導(dǎo)航指示器
- Android實現(xiàn)仿網(wǎng)易新聞主界面設(shè)計
- Android實現(xiàn)類似網(wǎng)易新聞選項卡動態(tài)滑動效果
- Android 仿網(wǎng)易新聞客戶端分類排序功能
- Android模擬實現(xiàn)網(wǎng)易新聞客戶端
- Android實現(xiàn)網(wǎng)易新聞客戶端側(cè)滑菜單(1)
- Android組件DrawerLayout仿網(wǎng)易新聞v4.4側(cè)滑菜單
- Android實現(xiàn)網(wǎng)易新聞客戶端側(cè)滑菜單(2)
- Android仿網(wǎng)易新聞圖片詳情下滑隱藏效果示例代碼
相關(guān)文章
五分了解Android?Progress?Bar進(jìn)度條加載
這篇文章主要為大家介紹了Android?Progress?Bar進(jìn)度條加載的實現(xiàn)及屬性示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-02-02Android viewpager在最后一頁滑動之后跳轉(zhuǎn)到主頁面的實例代碼
這篇文章主要介紹了Android viewpager在最后一頁滑動之后跳轉(zhuǎn)到主頁面的實例代碼的相關(guān)資料,需要的朋友可以參考下2016-08-08Activity與Service之間交互并播放歌曲的實現(xiàn)代碼
以下是對Activity與Service之間交互并播放歌曲的實現(xiàn)代碼進(jìn)行了詳細(xì)的分析介紹,需要的朋友可以過來參考下2013-07-07Android的HTTP擴(kuò)展包OkHttp中的緩存功能使用方法解析
OkHttp(GitHub主頁https://github.com/square/okhttp)是一款高人氣的第三方Android網(wǎng)絡(luò)編程包,這里我們來看一下Android的HTTP擴(kuò)展包OkHttp中的緩存功能使用方法解析:2016-07-07Kotlin實現(xiàn)半圓形進(jìn)度條的方法示例
這篇文章主要給大家介紹了關(guān)于Kotlin實現(xiàn)半圓形進(jìn)度條的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧。2018-03-03詳解Android開發(fā)技巧之PagerAdapter實現(xiàn)類的封裝
這篇文章主要介紹了詳解Android開發(fā)技巧之PagerAdapter實現(xiàn)類的封裝,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-11-11