Android 導(dǎo)航欄如何輕松搞定

    APP市場中大多數(shù)新聞App都有導(dǎo)航菜單徘层,導(dǎo)航菜單是一組標(biāo)簽的集合,在新聞客戶端中,每個標(biāo)簽標(biāo)示一個新聞類別肋乍,對應(yīng)下面ViewPager控件的一個分頁面,今日頭條, 網(wǎng)易新聞等。

    話不多說直接先上原型圖擒悬,如圖1,圖2稻艰,圖3懂牧。
image
image
image

首先是新聞Fragment:


import java.io.File;

import java.nio.channels.Channel;

import java.util.ArrayList;

import java.util.Calendar;

import java.util.Date;

import java.util.HashMap;

import java.util.List;

import java.util.Map;

import org.json.JSONException;

import org.json.JSONObject;

import com.android.volley.Request;

import com.android.volley.RequestQueue;

import com.android.volley.Response;

import com.android.volley.VolleyError;

import com.android.volley.toolbox.ClearCacheRequest;

import com.android.volley.toolbox.DiskBasedCache;

import com.android.volley.toolbox.StringRequest;

import com.android.volley.toolbox.Volley;

import com.google.gson.Gson;

import com.google.gson.reflect.TypeToken;

import com.juronggvo.R;

import com.juronggvo.adapter.ExerciseAdapter;

import com.juronggvo.adapter.NewsAdapter;

import com.juronggvo.adapter.PageFragmentAdapter;

import com.juronggvo.bean.NewsBean;

import com.juronggvo.data.Config;

import com.juronggvo.data.Contants;

import com.juronggvo.data.GlobalData;

import com.juronggvo.ui.inform.InformActivity;

import com.juronggvo.ui.news.NewsActivity;

import com.juronggvo.utils.Utils;

import com.juronggvo.widget.MyListView;

import com.juronggvo.widget.NewsTitleTextView;

import com.juronggvo.widget.NewsViewPagerAdapter;

import com.juronggvo.widget.PullToRefreshView;

import com.juronggvo.widget.PullToRefreshView.OnFooterRefreshListener;

import com.juronggvo.widget.PullToRefreshView.OnHeaderRefreshListener;

import android.R.bool;

import android.annotation.SuppressLint;

import android.content.Intent;

import android.graphics.Color;

import android.os.Bundle;

import android.os.Handler;

import android.provider.Settings.Global;

import android.support.v4.app.Fragment;

import android.support.v4.view.ViewPager;

import android.support.v4.view.ViewPager.LayoutParams;

import android.support.v4.view.ViewPager.OnPageChangeListener;

import android.util.DisplayMetrics;

import android.view.Gravity;

import android.view.LayoutInflater;

import android.view.View;

import android.view.View.OnClickListener;

import android.view.ViewGroup;

import android.widget.AdapterView;

import android.widget.AdapterView.OnItemClickListener;

import android.widget.FrameLayout;

import android.widget.HorizontalScrollView;

import android.widget.LinearLayout;

import android.widget.RadioButton;

import android.widget.RadioGroup;

import android.widget.RelativeLayout;

import android.widget.TextView;

import android.widget.Toast;

/**

* 新聞資訊

* @description

* @data 2016年12月13日

* @author yang.yang

*/

public class NewsFragment extends Fragment implements OnPageChangeListener {

private RadioGroup rgChannel;

private View view;

private ViewPager viewPager;

private HorizontalScrollView hvChannel;

private PageFragmentAdapter adapter=null; 

private int page = 1 ;

private Object newsLists; 

 private ListfragmentList=new ArrayList();

private RequestQueue requestQueue =null;

private ExerciseAdapter newsAdapter;

private Handler handler = new Handler() ;

@Override

public View onCreateView(LayoutInflater inflater, ViewGroup container,

Bundle savedInstanceState) {

view = inflater.inflate(R.layout.fragment_new, container, false);

return view ;

}

@Override

public void onActivityCreated(Bundle savedInstanceState) {

super.onActivityCreated(savedInstanceState);

init() ;

setTab(Config.newsPosition,true);

}

private void init(){

requestQueue = Volley.newRequestQueue(getActivity());

rgChannel=(RadioGroup)view.findViewById(R.id.rgChannel);

viewPager=(ViewPager)view.findViewById(R.id.vpNewsList);

hvChannel=(HorizontalScrollView)view.findViewById(R.id.hvChannel);

rgChannel.setOnCheckedChangeListener(

new RadioGroup.OnCheckedChangeListener() {

@Override

public void onCheckedChanged(RadioGroup group,

int checkedId) {

viewPager.setCurrentItem(checkedId);

}

});

viewPager.setOnPageChangeListener(this);

initTab();//動態(tài)產(chǎn)生RadioButton

initViewPager();

}

private void initTab(){ 

ListchannelList=ChannelDb.getSelectedChannel();

for(int i=0;i<channelList.size();i++){

RadioButton rb=(RadioButton)LayoutInflater.from(getActivity()).

inflate(R.layout.tab_rb, null);

rb.setId(i);

rb.setText(channelList.get(i));

RadioGroup.LayoutParams params=new

RadioGroup.LayoutParams(RadioGroup.LayoutParams.WRAP_CONTENT,

RadioGroup.LayoutParams.WRAP_CONTENT);

rgChannel.addView(rb,params);

}

}

private void initViewPager(){

adapter=new PageFragmentAdapter(super.getFragmentManager());

viewPager.setAdapter(adapter);

viewPager.setOffscreenPageLimit(0);

}

/**

* 滑動ViewPager時調(diào)整ScroollView的位置以便顯示按鈕

* @param idx

*/

private void setTab(final int idx,boolean flag){

RadioButton rb=(RadioButton)rgChannel.getChildAt(idx);

rb.setChecked(true);

int left=rb.getLeft();

int width=rb.getMeasuredWidth();

DisplayMetrics metrics=new DisplayMetrics();

super.getActivity().getWindowManager().getDefaultDisplay().getMetrics(metrics);

int screenWidth=metrics.widthPixels;

final int len=left+width/2-screenWidth/2;

hvChannel.smoothScrollTo(len, 0);//滑動ScroollView

System.out.println("len====="+len);

}

@Override

public void onPageScrollStateChanged(int arg0) {

// TODO Auto-generated method stub

}

@Override

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

// TODO Auto-generated method stub

}

@Override

public void onPageSelected(int position) {

// TODO Auto-generated method stub

setTab(position,false);

}

}

其中要用的fragment_new.xml

image
image

ChannelDb 類


import java.nio.channels.Channel;

import java.util.ArrayList;

import java.util.List;

public class ChannelDb {

private static ListselectedChannel=new ArrayList();

static{

selectedChannel.add("熱點(diǎn)資訊");

selectedChannel.add("開發(fā)區(qū)概括");

selectedChannel.add("最新動態(tài)");

selectedChannel.add("文化生活");

selectedChannel.add("旅游景點(diǎn)");

selectedChannel.add("句容資訊");

selectedChannel.add("黨建園地");

selectedChannel.add("重點(diǎn)工程");

}

public static  ListgetSelectedChannel(){

return selectedChannel;

}

}

tab_rb.xml

image

PageFragmentAdapter 類


import java.util.List;

import android.support.v4.app.Fragment;

import android.support.v4.app.FragmentManager;

import android.support.v4.app.FragmentPagerAdapter;

public class PageFragmentAdapter  extends FragmentPagerAdapter{

private String[] tabs  = { "熱點(diǎn)資訊", "開發(fā)區(qū)概括","最新動態(tài)","文化生活","旅游景點(diǎn)","句容資訊","黨建園地","重點(diǎn)工程" };

private FragmentManager fm;

public PageFragmentAdapter(FragmentManager fm ){

super(fm);

this.fm=fm;

}

/**

* 返回每頁對應(yīng)的fragment的對象

*/

@Override

public Fragment getItem(int position) {

return NewsFragmentFactory.create(position);

}

@Override

public int getCount() {

return tabs.length;

}

@Override

public int getItemPosition(Object object) {

return POSITION_NONE;  //沒有找到child要求重新加載

}

}

NewsFragmentFactory類

import com.juronggvo.ui.fragment.ApplyCarFragment;

import com.juronggvo.ui.fragment.ApplyMeetingFragment;

import com.juronggvo.ui.fragment.CulLifeFragment;

import com.juronggvo.ui.fragment.DevoAreFragment;

import com.juronggvo.ui.fragment.HotpointFragment;

import com.juronggvo.ui.fragment.ImportantProFragment;

import com.juronggvo.ui.fragment.JuRongFragment;

import com.juronggvo.ui.fragment.NewRecentFragment;

import com.juronggvo.ui.fragment.PartyBuildFragment;

import com.juronggvo.ui.fragment.TravelFragment;

import android.support.v4.app.Fragment;

public class NewsFragmentFactory {

/**

* 根據(jù)不同的position生產(chǎn)對應(yīng)的fragment對象

* @param position

* @return

*/

public static Fragment create(int position){

Fragment fragment = null;

switch (position) {

case 0:

fragment = new HotpointFragment();

break;

case 1:

fragment = new DevoAreFragment();

break;

case 2:

fragment = new NewRecentFragment();

break;

case 3:

fragment = new CulLifeFragment();

break;

case 4:

fragment = new TravelFragment();

break;

case 5:

fragment = new JuRongFragment();

break;

case 6:

fragment = new PartyBuildFragment();

break;

case 7:

fragment = new ImportantProFragment();

break;

}

return fragment;

}

}

然后在每個pager頁面寫你自己要的數(shù)據(jù) 就可以了。

偉大的哲學(xué)家我自己曾經(jīng)說過尊勿,有夢想就要大聲說出來 僧凤,萬丈高樓平地起用狱,能不能行靠自己!

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末拼弃,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子摇展,更是在濱河造成了極大的恐慌吻氧,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,755評論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件咏连,死亡現(xiàn)場離奇詭異盯孙,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)祟滴,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,305評論 3 395
  • 文/潘曉璐 我一進(jìn)店門振惰,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人垄懂,你說我怎么就攤上這事骑晶。” “怎么了草慧?”我有些...
    開封第一講書人閱讀 165,138評論 0 355
  • 文/不壞的土叔 我叫張陵桶蛔,是天一觀的道長。 經(jīng)常有香客問我漫谷,道長仔雷,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,791評論 1 295
  • 正文 為了忘掉前任舔示,我火速辦了婚禮碟婆,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘惕稻。我一直安慰自己竖共,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,794評論 6 392
  • 文/花漫 我一把揭開白布缩宜。 她就那樣靜靜地躺著肘迎,像睡著了一般。 火紅的嫁衣襯著肌膚如雪锻煌。 梳的紋絲不亂的頭發(fā)上妓布,一...
    開封第一講書人閱讀 51,631評論 1 305
  • 那天,我揣著相機(jī)與錄音宋梧,去河邊找鬼匣沼。 笑死,一個胖子當(dāng)著我的面吹牛捂龄,可吹牛的內(nèi)容都是我干的释涛。 我是一名探鬼主播加叁,決...
    沈念sama閱讀 40,362評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼唇撬!你這毒婦竟也來了它匕?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,264評論 0 276
  • 序言:老撾萬榮一對情侶失蹤窖认,失蹤者是張志新(化名)和其女友劉穎豫柬,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體扑浸,經(jīng)...
    沈念sama閱讀 45,724評論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡烧给,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,900評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了喝噪。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片础嫡。...
    茶點(diǎn)故事閱讀 40,040評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖酝惧,靈堂內(nèi)的尸體忽然破棺而出榴鼎,到底是詐尸還是另有隱情,我是刑警寧澤系奉,帶...
    沈念sama閱讀 35,742評論 5 346
  • 正文 年R本政府宣布檬贰,位于F島的核電站,受9級特大地震影響缺亮,放射性物質(zhì)發(fā)生泄漏翁涤。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,364評論 3 330
  • 文/蒙蒙 一萌踱、第九天 我趴在偏房一處隱蔽的房頂上張望葵礼。 院中可真熱鬧,春花似錦并鸵、人聲如沸鸳粉。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,944評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽届谈。三九已至,卻和暖如春弯汰,著一層夾襖步出監(jiān)牢的瞬間艰山,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,060評論 1 270
  • 我被黑心中介騙來泰國打工咏闪, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留曙搬,地道東北人。 一個月前我還...
    沈念sama閱讀 48,247評論 3 371
  • 正文 我出身青樓,卻偏偏與公主長得像纵装,于是被迫代替她去往敵國和親征讲。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,979評論 2 355

推薦閱讀更多精彩內(nèi)容