0システマティックAndroid--
記事カタログのこのシリーズ:もっとブティック記事のカテゴリ
継続的に更新....この一連の初段コンテンツ参照「最初の行」
ライフサイクルの4.3枚
デブリは、独自のライフサイクルを持ち、生活や活動のサイクルも好きです。
国家4.3.1破片とコールバック
動作状態
断片が表示され、それは活動と関連している動作状態にあるとき、この破片はまた、実行されています。
サスペンド状態
アクティビティが停止状態に入るときに、それに関連付けられた可視デブリはサスペンド状態に入ります。
停止状態
停止状態への活動は、彼に関連付けられた破片は停止状態に、または呼び出すことにより、入力されますとき
FragmentTransaction
にremove()
、またはreplace()
トランザクションのコミット呼び出しの前にいることを提供する、アクティブ方式から破片を取り除くaddToBackStack()
方法を、その破片が入ります停止状態に。// 前提当前的 Activity 处于运行状态。 Fragment A = new Fragment(); FragmentManager fragmentManager = getSupportFragmentManger(); FrgmentTransaction fragmentTransaction = fragmentManger.beginTransaction(); fragmentTransaction.replace(R.id.framelayout,A);// 这个时候 Fragment A应该是处于运行状态的。 fragmentTransaction.addToBackStack(null); fragmentTransaction.commit(); Fragment B = new Fragment(); fragmentTransaction.replace(R.id.framelayout,B);// 这个时候 AFragment 的状态时停止状态的。 fragmentTransaction.addToBackStack(null); fragmentTransaction.commit();
ユーザーに破片のために足踏み状態に完全に見えなくさもたらし、回復システムがあるかもしれません。
国家の破壊
アクティビティは常にデブリ存在すること取り付けられるので、活性が破壊されたときに、デブリが状態の関連破壊に入ります。または呼び出すことによって
FragmentTransaction()
ではreove()
、replace()
Activityから破片を取り除く方法、およびトランザクションのコミット前に呼び出していないaddToBackStatck()
方法を、そして破片の量が破壊された状態に入ることができます。
- 使用のONATTACH()デブリとアクティビティ関連付けます
- onCreateView()呼び出しビューを作成するには(負荷分散)の作品に
- onActivityCreated()は呼び出されたときに破片が活動に関連付けられていることを確認するために作成されている必要があります。
- ビューのデブリの除去に関連するときonDestroyView()が呼び出され
- 破片とアクティビティがコールを解離さonDetach()。
4.3.2経験の破片のライフサイクル
就是在上一个例子的基础上,在每个方法汇总打印一下,观察一下效果就好了。
这里给宿主 FragmentBaseActivity
和 静态添加到 Activity 中的 Fragment 的生命周期方法里面添加打印。效果:
在碎片中,你也是可以通过 onSaveInstanceState() 方法来保存数据,因为进入停止状态的碎片也是有可能被系统在内存不足的情况下收回的。保存下来的数据在 onCreateView()
和 onActivityCreated()
和 onCreate()
中都可以获取到
4.4 动态加载布局的技巧
程序如何能够根据设备的分辨率或屏幕大小在运行时来决定加载哪个布局呢?
4.4.1 使用限定符
经常使用平板电脑我们会发现有些应用都是采用双页模式(程序会在左侧面板上显示一个包含子项的列表,在右侧的面板上显示内容)。这是因为平板电脑屏幕的大的原因,完全可以显示两页的内容。但是手机就不行了,屏幕比较小,只能显示一页的内容。
那么怎么样才能在运行时判断程序应该使用双页模式还是单页模式呢?这就需要限定符(Qualifiers)实现。
在 activity_main.xml
中
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="horizontal">
<fragment
android:layout_width="match_parent"
android:layout_height="match_parent"
android:name="com.example.firstcode.fourth_chapter.LeftFragment"/>
</LinearLayout>
这个时候让它充满了整个页面。
在 res 目录下新建 layout_large
文件夹,在这个文件夹新建一个布局,也叫做 activity_main.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="horizontal">
<fragment
android:layout_width="0dp"
android:layout_height="match_parent"
android:layout_weight="1"
android:name="com.example.firstcode.fourth_chapter.LeftFragment"
android:id="@+id/fg_left"/>
<fragment
android:layout_width="0dp"
android:layout_height="match_parent"
android:layout_weight="1"
android:name="com.example.firstcode.fourth_chapter.RightFragment"
android:id="@+id/fg_right"/>
</LinearLayout>
其中 large
就是一个限定符,那些屏幕被认为是large
的设备就会自动加载 layout-large
文件下的布局,而小屏幕的设备还是会加载 layout
下的布局。
Android 中一些常见的限定符
4.4.2 使用最小宽度限定符
large
到底指多大呢?有时候我们需要更加灵活,不管它们是不是被系统认定为 large
这个时候就可以使用最小宽度限定符(Smallest-width Qualifier)。
最小宽度限定符允许我们指定一个最小的值(以dp为单位),然后如果屏幕大于等于这个最小值则使用这个文件夹内的布局,如果小于则使用默认布局
在 res 目录新建 layout-sw600dp
文件,在这个文件夹创建布局就可以了。
4.5 碎片的实践----简易版新闻应用
首先我们要实现的效果是在普通手机上是单页模式,也就是有一个新闻标题列表,点击后进入下一个页面(新闻详情页面)。
在平板电脑上效果是双页模式:效果如
试想我们是不是可以为手机和平板每个端提供一个应用程序呢?如果这样做的话会浪费很多的人力物力,因为这样意味着要同时维护两份代码。
Fragment 的出现就是为了充分利用屏幕空间的。这里可以使用 Fragment 来很多的处理这个问题。
思路:通过限定符,在手机上面会加载直接标题列表的页面,在平板上会加载列表和内容页面。
其中为了复用,标题列表和内容页面都应该是一个 Fragment。这样就达到了复用的效果。
实现代码:MyGitHub/FirstCode/app/src/main/java/com/example/firstcode/fourth_chapter/news 包下
4.6 总结
Fragment 运用在要求充分利用屏幕资源的情况下
加载方式有静态加载和动态加载。