參考鏈接:http://www.jianshu.com/p/7bc9a1ff137e
我們提供的服務(wù)有:網(wǎng)站建設(shè)、成都做網(wǎng)站、微信公眾號開發(fā)、網(wǎng)站優(yōu)化、網(wǎng)站認證、紅旗ssl等。為成百上千企事業(yè)單位解決了網(wǎng)站和推廣的問題。提供周到的售前咨詢和貼心的售后服務(wù),是有科學(xué)管理、有技術(shù)的紅旗網(wǎng)站制作公司
http://www.devstore.cn/code/info/245.html
http://www.tuicool.com/articles/FfeiumV
本人參考了三篇文章來寫這個頁面,但是運行這上面給出的源碼,發(fā)現(xiàn)每個fragment的flag并不能實現(xiàn)切換。
要實現(xiàn)的效果如下:
在activity_main.xml中設(shè)置布局。xml內(nèi)容如下:
接下來,增加3個Fragment布局頁 ,分別在里面填充簡單的內(nèi)容
第一個 :
第二個 :
第三個 :
以上3個Fragment的布局文件已創(chuàng)建完畢,每個文件中只顯示簡單的文本內(nèi)容,用做演示。
加載3個Fragment到Activity中。
首先實現(xiàn)3個Fragment對應(yīng)的后臺類
import android.os.Bundle; import android.support.v4.app.Fragment; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import org.ganinfo.interfacepractice.R; public class FragmentHot extends Fragment { @Override public View onCreateView(LayoutInflater inflater, ViewGroup container,Bundle savedInstanceState) { View view = inflater.inflate(R.layout.fragmenthot, container, false); return view; } }
news布局頁對應(yīng)的類:
import android.os.Bundle; import android.support.v4.app.Fragment; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import org.ganinfo.interfacepractice.R; public class FragmentNews extends Fragment { @Override public View onCreateView(LayoutInflater inflater, ViewGroup container,Bundle savedInstanceState) { View view = inflater.inflate(R.layout.fragmentnews, container, false); return view; } }
收藏布局頁對應(yīng)的類:
import android.os.Bundle; import android.support.v4.app.Fragment; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import org.ganinfo.interfacepractice.R; public class FragmentFavorite extends Fragment { @Override public View onCreateView(LayoutInflater inflater, ViewGroup container,Bundle savedInstanceState) { View view = inflater.inflate(R.layout.fragmentfav, container, false); return view; } }
之后再activity中初始化這3個Fragment
注意要點:
MainActivity繼承自FragmentActivity
要實現(xiàn)一個FragmentPagerAdapter,內(nèi)容如下:
import android.support.v4.app.Fragment; import android.support.v4.app.FragmentManager; import android.support.v4.app.FragmentPagerAdapter; import java.util.ArrayList; public class MyFragmentAdapter extends FragmentPagerAdapter { ArrayListlist; public MyFragmentAdapter(FragmentManager fm,ArrayList list){ super(fm); this.list = list; } @Override public Fragment getItem(int arg0) { return list.get(arg0); } @Override public int getCount() { return list.size(); } }
然后在MainActivity中實現(xiàn)切換和動畫效果,代碼如下:
import android.os.Bundle; import android.support.v4.app.Fragment; import android.support.v4.app.FragmentActivity; import android.support.v4.view.ViewPager; import android.view.MenuItem; import android.view.View; import android.widget.TextView; import java.util.ArrayList; import adapter.MyFragmentAdapter; import fragment.FragmentFavorite; import fragment.FragmentHot; import fragment.FragmentNews; public class MainActivity extends FragmentActivity implements View.OnClickListener{ private ViewPager mViewPager; private ArrayList fragments; private TextView view1, view2, view3; private int mCurrentOption = 0; private View flag0, flag1, flag2; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); initViewPager(); initView(); } @Override public boolean onOptionsItemSelected(MenuItem item) { int id = item.getItemId(); if (id == R.id.action_settings) { return true; } return super.onOptionsItemSelected(item); } private void initView(){ view1 = (TextView) findViewById(R.id.tv_hot); view2 = (TextView) findViewById(R.id.tv_news); view3 = (TextView) findViewById(R.id.tv_fav); flag0 = findViewById(R.id.activity_order_flag_all); flag1 = findViewById(R.id.activity_order_flag_uncomplete); flag2 = findViewById(R.id.activity_order_flag_complete); view1.setOnClickListener(this); view2.setOnClickListener(this); view3.setOnClickListener(this); } @Override public void onClick(View v) { switch (v.getId()){ case R.id.tv_hot: if(mCurrentOption == 0) return; mCurrentOption = 0; flag0.setVisibility(View.VISIBLE); flag1.setVisibility(View.INVISIBLE); flag2.setVisibility(View.INVISIBLE); mViewPager.setCurrentItem(mCurrentOption); break; case R.id.tv_news: if(mCurrentOption == 1) return; mCurrentOption = 1; flag0.setVisibility(View.INVISIBLE); flag1.setVisibility(View.VISIBLE); flag2.setVisibility(View.INVISIBLE); mViewPager.setCurrentItem(mCurrentOption); break; case R.id.tv_fav: if(mCurrentOption == 2) return; mCurrentOption = 2; flag0.setVisibility(View.INVISIBLE); flag1.setVisibility(View.INVISIBLE); flag2.setVisibility(View.VISIBLE); mViewPager.setCurrentItem(mCurrentOption); break; default: return; } } private void initViewPager(){ mViewPager = (ViewPager)findViewById(R.id.myViewPager); fragments = new ArrayList(); Fragment fragmentHot = new FragmentHot(); Fragment fragmentNews = new FragmentNews(); Fragment fragmentFav = new FragmentFavorite(); fragments.add(fragmentHot); fragments.add(fragmentNews); fragments.add(fragmentFav); mViewPager.setAdapter(new MyFragmentAdapter(getSupportFragmentManager(), fragments)); mViewPager.setCurrentItem(0); mViewPager.setOnPageChangeListener(new ViewPager.OnPageChangeListener() { @Override public void onPageScrolled(int i, float v, int i2) { } @Override public void onPageSelected(int i) { switch (i){ case 0: flag0.setVisibility(View.VISIBLE); flag1.setVisibility(View.INVISIBLE); flag2.setVisibility(View.INVISIBLE); break; case 1: flag0.setVisibility(View.INVISIBLE); flag1.setVisibility(View.VISIBLE); flag2.setVisibility(View.INVISIBLE); break; case 2: flag0.setVisibility(View.INVISIBLE); flag1.setVisibility(View.INVISIBLE); flag2.setVisibility(View.VISIBLE); break; default: return; } } @Override public void onPageScrollStateChanged(int i) { } }); } }
-------------------------------------------------------------------------------------
package com.ganinfo.collect.activity; import java.util.ArrayList; import com.ganinfo.collect.R; import com.ganinfo.collect.fragment.GzMyFragment; import com.ganinfo.collect.fragment.GzTaskFragment; import com.ganinfo.collect.utils.GzLog; import com.ganinfo.collect.utils.GzNetwork; import com.ganinfo.collect.widget.MyFragmentAdapter; import android.annotation.SuppressLint; import android.app.AlertDialog; import android.os.Bundle; import android.support.v4.view.ViewPager; import android.view.MenuItem; import android.view.View; import android.widget.ImageView; import android.widget.TextView; @SuppressLint("ResourceAsColor") public class GzMainActivity extends GzBaseActivity { private String TAG = "GzMainActivity"; private long lastTime = 0; //再按一次退出的時間標(biāo)志 private ArrayListfragments; private int mCurrentOption = 0; private ViewPager mViewPager; private ImageView mTaskIV,mTaskMyIV; private TextView mTaskTV,mTaskMyTV; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); GzLog.d(TAG, "onCreate"); initview(); initViewPager(); CheckNetwork(); } private void initview() { mTaskIV = (ImageView) findViewById(R.id.main_iv_shop); mTaskMyIV = (ImageView) findViewById(R.id.main_iv_my); mTaskTV = (TextView) findViewById(R.id.main_tv_shop); mTaskMyTV = (TextView) findViewById(R.id.main_tv_my); } @Override public boolean onOptionsItemSelected(MenuItem item) { int id = item.getItemId(); if (id == R.id.action_settings) { return true; } return super.onOptionsItemSelected(item); } private void CheckNetwork() { if(!GzNetwork.isNetworkAvailable()){ new AlertDialog.Builder(this). setMessage(R.string.network_not_avail). setPositiveButton(R.string.ok, null). create().show(); } } private void initViewPager(){ mViewPager = (ViewPager)findViewById(R.id.main_viewpager); fragments = new ArrayList (); GzTaskFragment fragmentTask = new GzTaskFragment(); GzMyFragment fragmentMy = new GzMyFragment(); fragments.add(fragmentTask); fragments.add(fragmentMy); mViewPager.setAdapter(new MyFragmentAdapter(getSupportFragmentManager(), fragments)); mViewPager.setCurrentItem(mCurrentOption); mViewPager.setOnPageChangeListener(new ViewPager.OnPageChangeListener() { @Override public void onPageSelected(int i) { if(mCurrentOption == i){ } } @Override public void onPageScrolled(int arg0, float arg1, int arg2) { } @Override public void onPageScrollStateChanged(int arg0) { } }); } @SuppressLint("ResourceAsColor") public void onClickTab(View view){ switch (view.getId()) { case R.id.main_fg_task: if(mCurrentOption == 0) return; mCurrentOption = 0; mViewPager.setCurrentItem(mCurrentOption); mTaskTV.setTextColor(R.color.app_style_normal); break; case R.id.main_fg_my: if(mCurrentOption == 1) return; mCurrentOption = 1; mViewPager.setCurrentItem(mCurrentOption); mTaskMyTV.setTextColor(R.color.app_style_normal); break; default: return; } } @Override public void onBackPressed() { if(System.currentTimeMillis() - lastTime > 2000){ showToast(R.string.back_hint); lastTime = System.currentTimeMillis(); return; } super.onBackPressed(); } }