fragment實現(xiàn)隱藏及界面切換效果
在前文中的效果中(Android如何創(chuàng)建自定義ActionBar),點擊屏幕下方的 TextView 以此來實現(xiàn) 5 種 fragment 界面的切換。
由于網(wǎng)絡(luò)數(shù)據(jù)的加載存在于不同的界面之中,當快速的切換界面時,就會出現(xiàn)程序的出錯。因為快速的切換時,當前界面的數(shù)據(jù)還在讀取,就切換到下一個界面,下一個界面也開始加載數(shù)據(jù),每次界面的切換都會加載數(shù)據(jù)。這樣就會出錯(在本文中,fragment 是使用 replace() 方法來加載界面的,)。所以可以使每個 fragment 只加載一次來減少數(shù)據(jù)的加載次數(shù)。當然可以使用緩存技術(shù)來解決問題。
本文中只使用 fragment 的隱藏或者加載來實現(xiàn)每個界面只加載一次。這時需要多定義一個 Fragment 變量,以充當中間的變量,來實現(xiàn) fragment 的隱藏。
上文中界面切換的效果,其實很簡單,即:點擊當前 TextView 使其顏色改變,其他的 TextView 的顏色都變?yōu)橄嗤伾纯伞_@時可以把這些變化封裝為一個方法。減少代碼量。
MainActivity.java :
package com.crazy.gemi; import android.app.SearchManager; import android.content.Intent; import android.graphics.Color; import android.provider.SearchRecentSuggestions; import android.support.v4.app.Fragment; import android.support.v4.app.FragmentActivity; import android.os.Bundle; import android.support.v4.app.FragmentTransaction; import android.view.View; import android.widget.TextView; import com.crazy.gemi.ui.cheaper.CheaperFragment; import com.crazy.gemi.ui.cheaper.SearchSuggestionSampleProvider; import com.crazy.gemi.ui.favor.FavorFragment; import com.crazy.gemi.ui.more.MoreFragment; import com.crazy.gemi.ui.near.NearFragment; import com.crazy.gemi.ui.pocket.PocketFragment; public class MainActivity extends FragmentActivity implements View.OnClickListener, CheaperFragment.SearchResult{ private TextView[] textView = new TextView[5]; private View[] views = new View[5]; // 其中的 firstFragment 相當于是個中間變量 private Fragment firstFragment, nearFragment, cheaperFragment, favorFragment, pocketFragmnet, moreFragment; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); init(); initFragment(); } private void init() { textView[0] = (TextView)findViewById(R.id.near); textView[1] = (TextView)findViewById(R.id.search_cheaper); textView[2] = (TextView)findViewById(R.id.favor); textView[3] = (TextView)findViewById(R.id.pocket); textView[4] = (TextView)findViewById(R.id.more); views[0] = findViewById(R.id.near_top_line); views[1] = findViewById(R.id.cheaper_top_line); views[2] = findViewById(R.id.favor_top_line); views[3] = findViewById(R.id.pocket_top_line); views[4] = findViewById(R.id.more_top_line); textView[0].setOnClickListener(this); textView[1].setOnClickListener(this); textView[2].setOnClickListener(this); textView[3].setOnClickListener(this); textView[4].setOnClickListener(this); } private void initFragment() { firstFragment = FavorFragment.newInstance(); favorFragment = firstFragment; // 最先加載的 fragment getSupportFragmentManager().beginTransaction(). add(R.id.frame_layout, favorFragment).commit(); textView[2].setTextColor(Color.BLACK); views[2].setBackgroundColor(Color.parseColor("#FF6600")); } @Override public void onClick(View v) { switch (v.getId()) { case R.id.near: // getSupportFragmentManager().beginTransaction(). // replace(R.id.frame_layout, NearFragment.newInstance()).commit(); if(nearFragment==null){ nearFragment= NearFragment.newInstance(); } switchContent(firstFragment, nearFragment, getSupportFragmentManager().beginTransaction()); firstFragment = nearFragment; selectStringAndBackgroundColor(0); break; case R.id.search_cheaper: if(cheaperFragment==null){ cheaperFragment= CheaperFragment.newInstance(); } switchContent(firstFragment, cheaperFragment, getSupportFragmentManager().beginTransaction()); firstFragment = cheaperFragment; selectStringAndBackgroundColor(1); break; case R.id.favor: if(favorFragment==null){ favorFragment= FavorFragment.newInstance(); } switchContent(firstFragment, favorFragment, getSupportFragmentManager().beginTransaction()); firstFragment = favorFragment; selectStringAndBackgroundColor(2); break; case R.id.pocket: if(pocketFragmnet==null){ pocketFragmnet= PocketFragment.newInstance(); } switchContent(firstFragment, pocketFragmnet, getSupportFragmentManager().beginTransaction()); firstFragment = pocketFragmnet; selectStringAndBackgroundColor(3); break; case R.id.more: if(moreFragment==null){ moreFragment= MoreFragment.newInstance(); } switchContent(firstFragment, moreFragment, getSupportFragmentManager().beginTransaction()); firstFragment = moreFragment; selectStringAndBackgroundColor(4); break; } } /** * 通過 position 的位置改變文字和 View 的顏色 * @param position */ private void selectStringAndBackgroundColor(int position){ int sum = textView.length; for (int i = 0; i < sum; i++) { if (position == i) { textView[i].setTextColor(Color.BLACK); views[i].setBackgroundColor(Color.parseColor("#FF6600")); } else { textView[i].setTextColor(Color.GRAY); views[i].setBackgroundColor(Color.parseColor("#f0f0f0")); } } } /** * 判斷是否添加了界面,以保存當前狀態(tài) */ public void switchContent(Fragment from, Fragment to, FragmentTransaction transaction) { if (!to.isAdded()) { // 先判斷是否被add過 transaction.hide(from).add(R.id.frame_layout, to) .commit(); // 隱藏當前的fragment,add下一個到Activity中 } else { transaction.hide(from).show(to).commit(); // 隱藏當前的fragment,顯示下一個 } } }
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Android基礎(chǔ)之使用Fragment控制切換多個頁面
- Android App中使用ViewPager+Fragment實現(xiàn)滑動切換效果
- Android使用Fragment打造萬能頁面切換框架
- Android Fragment中使用SurfaceView切換時閃一下黑屏的解決辦法
- 一個Activity中多個Fragment的切換
- Android中Fragment相互切換間不被回收的實現(xiàn)方法
- Android fragment實現(xiàn)多個頁面切換效果
- Android中使用TabHost 與 Fragment 制作頁面切換效果
- Android使用TabLayou+fragment+viewpager實現(xiàn)滑動切換頁面效果
- Android開發(fā)使用Activity嵌套多個Fragment實現(xiàn)橫豎屏切換功能的方法
相關(guān)文章
Android TabLayout實現(xiàn)京東詳情效果
這篇文章主要為大家詳細介紹了android TabLayout實現(xiàn)京東詳情效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-09-09Android 中通過ViewDragHelper實現(xiàn)ListView的Item的側(cè)拉劃出效果
這篇文章主要介紹了 Android 中通過ViewDragHelper實現(xiàn)ListView的Item的側(cè)拉劃出效果,需要的朋友可以參考下2017-08-08Android應(yīng)用內(nèi)懸浮窗Activity的簡單實現(xiàn)
懸浮窗相信大家應(yīng)該都不陌生,下面這篇文章主要給大家介紹了關(guān)于Android應(yīng)用內(nèi)懸浮窗Activity簡單實現(xiàn)的相關(guān)資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下2022-01-01Android中使用GridView和ImageViewSwitcher實現(xiàn)電子相冊簡單功能實例
本篇文章主要介紹了Android中使用GridView和ImageViewSwitcher實現(xiàn)電子相冊簡單功能實例,具有一定的參考價值,有需要的可以了解一下。2016-12-12android開發(fā)中常用的Eclipse快捷鍵詳細整理
android開發(fā)中常用的Eclipse快捷鍵詳細整理方便查找,需要的朋友可以了解下2012-12-12