fragment實現(xiàn)隱藏及界面切換效果
在前文中的效果中(Android如何創(chuàng)建自定義ActionBar),點擊屏幕下方的 TextView 以此來實現(xiàn) 5 種 fragment 界面的切換。
由于網(wǎng)絡(luò)數(shù)據(jù)的加載存在于不同的界面之中,當(dāng)快速的切換界面時,就會出現(xiàn)程序的出錯。因為快速的切換時,當(dāng)前界面的數(shù)據(jù)還在讀取,就切換到下一個界面,下一個界面也開始加載數(shù)據(jù),每次界面的切換都會加載數(shù)據(jù)。這樣就會出錯(在本文中,fragment 是使用 replace() 方法來加載界面的,)。所以可以使每個 fragment 只加載一次來減少數(shù)據(jù)的加載次數(shù)。當(dāng)然可以使用緩存技術(shù)來解決問題。
本文中只使用 fragment 的隱藏或者加載來實現(xiàn)每個界面只加載一次。這時需要多定義一個 Fragment 變量,以充當(dāng)中間的變量,來實現(xiàn) fragment 的隱藏。
上文中界面切換的效果,其實很簡單,即:點擊當(dāng)前 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 相當(dāng)于是個中間變量
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"));
}
}
}
/**
* 判斷是否添加了界面,以保存當(dāng)前狀態(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(); // 隱藏當(dāng)前的fragment,add下一個到Activity中
} else {
transaction.hide(from).show(to).commit(); // 隱藏當(dāng)前的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)文章
Kotlin?掛起函數(shù)CPS轉(zhuǎn)換原理解析
這篇文章主要為大家介紹了Kotlin?掛起函數(shù)CPS轉(zhuǎn)換原理解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-12-12
Android?studio實現(xiàn)日期?、時間選擇器與進(jìn)度條
這篇文章主要為大家詳細(xì)介紹了Android?studio實現(xiàn)日期、時間選擇器與進(jìn)度條,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-01-01
Android Mouse實現(xiàn)過程詳細(xì)筆記
鼠標(biāo)的實現(xiàn)有兩個步驟,一個是所有層上面的一個圖標(biāo),還有一個就是事件控制2013-09-09
Android開發(fā)Viewbinding委托實例詳解
這篇文章主要為大家介紹了Android開發(fā)Viewbinding委托實例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-06-06
android源碼探索之定制android關(guān)機界面的方法
這篇文章主要介紹了android源碼探索之定制android關(guān)機界面的方法,較為詳細(xì)的分析了Android關(guān)機界面的相關(guān)原理與代碼實現(xiàn)技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-10-10
Android自定義View實現(xiàn)飄動的葉子效果(三)
這篇文章主要為大家詳細(xì)介紹了Android自定義View實現(xiàn)飄動的葉子效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-03-03
Android 媒體庫數(shù)據(jù)更新方法總結(jié)
這篇文章主要介紹了Android 媒體庫數(shù)據(jù)更新方法總結(jié)的相關(guān)資料,需要的朋友可以參考下2017-04-04
Android BottomSheet實現(xiàn)可拉伸控件
這篇文章主要為大家詳細(xì)介紹了Android BottomSheet實現(xiàn)可拉伸控件,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-11-11

