Android 使用Fragment模仿微信界面的實(shí)例代碼
什么是Fragment
自從Android 3.0中引入fragments 的概念,根據(jù)詞海的翻譯可以譯為:碎片、片段。其目的是為了解決不同屏幕分辯率的動(dòng)態(tài)和靈活UI設(shè)計(jì)。大屏幕如平板小屏幕如手機(jī),平板電腦的設(shè)計(jì)使得其有更多的空間來放更多的UI組件,而多出來的空間存放UI使其會產(chǎn)生更多的交互,從而誕生了fragments 。
fragments 的設(shè)計(jì)不需要你來親自管理view hierarchy 的復(fù)雜變化,通過將Activity 的布局分散到frament 中,可以在運(yùn)行時(shí)修改activity 的外觀,并且由activity 管理的back stack 中保存些變化。當(dāng)一個(gè)片段指定了自身的布局時(shí),它能和其他片段配置成不同的組合,在活動(dòng)中為不同的屏幕尺寸修改布局配置(小屏幕可能每次顯示一個(gè)片段,而大屏幕則可以顯示兩個(gè)或更多)。
Fragment必須被寫成可重用的模塊。因?yàn)閒ragment有自己的layout,自己進(jìn)行事件響應(yīng),擁有自己的生命周期和行為,所以你可以在多個(gè)activity中包含同一個(gè)Fragment的不同實(shí)例。這對于讓你的界面在不同的屏幕尺寸下都能給用戶完美的體驗(yàn)尤其重要。
Fragment優(yōu)點(diǎn)
Fragment可以使你能夠?qū)ctivity分離成多個(gè)可重用的組件,每個(gè)都有它自己的生命周期和UI。
Fragment可以輕松得創(chuàng)建動(dòng)態(tài)靈活的UI設(shè)計(jì),可以適應(yīng)于不同的屏幕尺寸。從手機(jī)到平板電腦。
Fragment是一個(gè)獨(dú)立的模塊,緊緊地與activity綁定在一起??梢赃\(yùn)行中動(dòng)態(tài)地移除、加入、交換等。
Fragment提供一個(gè)新的方式讓你在不同的安卓設(shè)備上統(tǒng)一你的UI。
Fragment 解決Activity間的切換不流暢,輕量切換。
Fragment 替代TabActivity做導(dǎo)航,性能更好。
Fragment 在4.2.版本中新增嵌套fragment使用方法,能夠生成更好的界面效果。
Fragment做局部內(nèi)容更新更方便,原來為了到達(dá)這一點(diǎn)要把多個(gè)布局放到一個(gè)activity里面,現(xiàn)在可以用多Fragment來代替,只有在需要的時(shí)候才加載Fragment,提高性能。
可以從startActivityForResult中接收到返回結(jié)果,但是View不能。

圖片中給出了實(shí)例的效果,在點(diǎn)擊下方的按鈕時(shí),上半部分會自動(dòng)切換成對應(yīng)的內(nèi)容。這里使用的技術(shù)是fragment。
想必大家對fragment已經(jīng)有所了解,就算不清楚,百度也有詳細(xì)的介紹。在這里就著重介紹實(shí)現(xiàn)的過程。
首先,拿其中的一個(gè)部分“首頁”來講:
上面一部分是fragment,下面則是相對固定的按鈕區(qū)。也就是說,當(dāng)點(diǎn)擊按鈕時(shí),切換的只是上半部分內(nèi)容。所以,每一個(gè)fragment都有一個(gè)自己的xml布局文件。就想圖中所示的,“首頁”這個(gè)fragment的xml文件就是由一個(gè)textview構(gòu)成。
完成fragment的xml文件后,需要定義一個(gè)對應(yīng)的Java類來找到它,比如:首頁對應(yīng)的類是homeFragment.java。注意,這個(gè)類需要繼承fragment,并且每一個(gè)這樣繼承fragment的類都需要重寫其onCreateView的方法。具體代碼是:
import android.app.Fragment;
import android.os.Bundle;
import android.support.annotation.Nullable;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import com.example.cerian.marcon.R;
/**
* Created by Cerian on 2017/7/9.
*/
public class homeFragment extends Fragment {
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
View view=inflater.inflate(R.layout.fragment_home, null);
//找到按鈕前要加view.
return view;
}
}
完成到這步時(shí),每一個(gè)fragment的內(nèi)容就已經(jīng)完成了。接下來要做的是,將每一個(gè)fragment與一個(gè)頁面綁定并在其上顯示。這里我用了一個(gè)menufunction.xml

代碼是:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
android:id="@+id/rl_layout"
xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical"
android:layout_width="match_parent"
android:layout_height="match_parent">
<LinearLayout
android:id="@+id/ll_layout"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
</LinearLayout>
<LinearLayout
android:showDividers="beginning|end|middle"
android:background="#ffffff"
android:layout_width="match_parent"
android:layout_height="40dp"
android:orientation="horizontal"
android:layout_alignParentBottom="true"
android:layout_alignParentLeft="true"
android:layout_alignParentStart="true">
<ImageView
android:id="@+id/ig_home"
android:clickable="true"
android:layout_weight="1"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:src="@mipmap/homepage1"/>
<ImageView
android:id="@+id/ig_lib"
android:clickable="true"
android:layout_weight="1"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:src="@mipmap/library1"/>
<ImageView
android:id="@+id/ig_my"
android:clickable="true"
android:layout_weight="1"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:src="@mipmap/my1"/>
</LinearLayout>
</RelativeLayout>
在這個(gè)布局中,上面的LinearLayout是用來顯示fragment內(nèi)容的,下面的是按鈕。
然后,在這個(gè)menufunction.xml的對應(yīng)java類中,找到定義好的fragment,并顯示。主要的思想是:①拿到一個(gè)管理者②開啟一個(gè)事務(wù)③替換fragment內(nèi)容④提交,注意,這里的第四步很容易被遺忘。
代碼是:
import android.app.FragmentManager;
import android.app.FragmentTransaction;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.view.View;
import android.widget.ImageView;
import com.example.cerian.marcon.fragment.homeFragment;
import com.example.cerian.marcon.fragment.libFragment;
import com.example.cerian.marcon.fragment.myFragment;
/**
* Created by Cerian on 2017/7/9.
*/
public class home extends AppCompatActivity implements View.OnClickListener {
private ImageView ig_home, ig_lib, ig_my;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.menufunction);
ig_home = (ImageView) findViewById(R.id.ig_home);
ig_lib = (ImageView) findViewById(R.id.ig_lib);
ig_my = (ImageView) findViewById(R.id.ig_my);
ig_home.setOnClickListener(this);
ig_lib.setOnClickListener(this);
ig_my.setOnClickListener(this);
/**
* 第一步:拿到管理者
* 第二步:開啟事務(wù)
* 第三步:替換
* 第四步:提交
*/
FragmentManager fragmentManager = getFragmentManager();
FragmentTransaction beginTransaction = fragmentManager.beginTransaction();
beginTransaction.replace(R.id.ll_layout, new homeFragment());
ig_home.setImageResource(R.mipmap.homepage2);
beginTransaction.commit();
}
@Override
public void onClick(View view) {
FragmentManager fragmentManager = getFragmentManager();
FragmentTransaction beginTransaction = fragmentManager.beginTransaction();
switch (view.getId()) {
case R.id.ig_home: //點(diǎn)擊的是主頁
beginTransaction.replace(R.id.ll_layout, new homeFragment());
ig_home.setImageResource(R.mipmap.homepage2);
ig_my.setImageResource(R.mipmap.my1);
ig_lib.setImageResource(R.mipmap.library1);
break;
case R.id.ig_lib: //點(diǎn)擊的是收藏
beginTransaction.replace(R.id.ll_layout, new libFragment());
ig_home.setImageResource(R.mipmap.homepage1);
ig_my.setImageResource(R.mipmap.my1);
ig_lib.setImageResource(R.mipmap.library2);
break;
case R.id.ig_my: //點(diǎn)擊的是我的
beginTransaction.replace(R.id.ll_layout, new myFragment());
ig_home.setImageResource(R.mipmap.homepage1);
ig_my.setImageResource(R.mipmap.my2);
ig_lib.setImageResource(R.mipmap.library1);
break;
}
beginTransaction.commit();
}
}
其中,因?yàn)樯婕暗降狞c(diǎn)擊事件有點(diǎn)多且相似,我用到了一個(gè)特殊的寫法,也就是setonclicklistener(this),參數(shù)用了this,并重新定義了一個(gè)click方法。注意:這樣寫,必須要繼承一個(gè)clicklistener的接口。
最后,提交就ok。
效果是:

這就是利用fragment來模擬微信界面。
以上所述是小編給大家介紹的Android 使用Fragment模仿微信界面的實(shí)例代碼,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時(shí)回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
- Android中Fragment的基本用法示例總結(jié)
- Android fragment實(shí)現(xiàn)多個(gè)頁面切換效果
- Android 多層嵌套后的 Fragment 懶加載實(shí)現(xiàn)示例
- Android使用TabLayou+fragment+viewpager實(shí)現(xiàn)滑動(dòng)切換頁面效果
- Android的廣播Receiver動(dòng)態(tài)注冊和靜態(tài)注冊示例
- 深入Android中BroadcastReceiver的兩種注冊方式(靜態(tài)和動(dòng)態(tài))詳解
- Android Fragment的靜態(tài)注冊和動(dòng)態(tài)注冊創(chuàng)建步驟
相關(guān)文章
Android實(shí)現(xiàn)圖片預(yù)覽與保存功能
在App開發(fā)中,通常為了省流提高加載速度提升用戶體驗(yàn)我們通常在列表中或新聞中的插圖都是以縮略圖壓縮過的圖片來進(jìn)行展示,當(dāng)用戶點(diǎn)擊圖片時(shí)我們再去加載真正像素的大圖讓用戶預(yù)覽。本文將利用Flutter實(shí)現(xiàn)這一功能,需要的可以參考一下2022-04-04
android 有阻尼下拉刷新列表的實(shí)現(xiàn)方法
下面小編就為大家分享一篇android 有阻尼下拉刷新列表的實(shí)現(xiàn)方法,具有很好的參考價(jià)值,希望對大家有所幫助,一起跟隨小編過來看看吧2018-01-01
Android編程判斷橫屏、豎屏及設(shè)置橫豎屏的方法
這篇文章主要介紹了Android編程判斷橫屏、豎屏及設(shè)置橫豎屏的方法,結(jié)合實(shí)例形式分析了Android針對橫豎屏的判斷、計(jì)算、設(shè)置等相關(guān)操作技巧,需要的朋友可以參考下2018-01-01
Android開發(fā)中實(shí)現(xiàn)應(yīng)用的前后臺切換效果
這篇文章主要介紹了Android開發(fā)中實(shí)現(xiàn)應(yīng)用的前后臺切換效果的方法,文章最后還附帶了監(jiān)聽程序是否進(jìn)入后臺的判斷方法,需要的朋友可以參考下2016-02-02
Android Flutter實(shí)現(xiàn)興趣標(biāo)簽選擇功能
我們在首次使用內(nèi)容類 App 的時(shí)候,不少都會讓我們選擇個(gè)人偏好,通過這些標(biāo)簽選擇可以預(yù)先知道用戶的偏好信息。我們本篇就來看看 Flutter 如何實(shí)現(xiàn)興趣標(biāo)簽的選擇,需要的可以參考一下2022-11-11
Android MediaPlayer音頻播放器封裝示例淺析
Android提供了許多方法來控制播放的音頻/視頻文件和流。其中該方法是通過一類稱為MediaPlayer。Android是提供MediaPlayer類訪問內(nèi)置的媒體播放器的服務(wù),如播放音頻,視頻等為了使用MediaPlayer,我們要調(diào)用這個(gè)類的靜態(tài)create()方法2023-04-04
Android NotificationManager簡單使用詳解
這篇文章主要為大家詳細(xì)介紹了Android NotificationManager的簡單使用,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-11-11
Android實(shí)現(xiàn)直播聊天區(qū)域中頂部的漸變效果
最近在研究直播的彈幕,東西有點(diǎn)多,準(zhǔn)備記錄一下免得自己忘了又要重新研究,下面這篇文章主要給大家介紹了關(guān)于Android如何實(shí)現(xiàn)直播聊天區(qū)域中頂部漸變效果的相關(guān)資料,需要的朋友可以參考借鑒,下面來一起看看吧。2018-04-04
Android編程中Handler原理及用法實(shí)例分析
這篇文章主要介紹了Android編程中Handler用法,結(jié)合實(shí)例形式分析了Handler的功能,原理及使用技巧,需要的朋友可以參考下2016-01-01

