Android学习--Fragment,Android实习面试经验汇总

import android.view.LayoutInflater
import android.view.View
import android.view.ViewGroup
import androidx.fragment.app.Fragment

class AntherRightFrogment :Fragment() {
override fun onCreateView(
inflater: LayoutInflater,
container: ViewGroup?,
savedInstanceState: Bundle?
): View? {
return inflater.inflate(R.layout.anther_right_fragement,container,false)
}
}

然后修改man.xml代码,引入FrameLayout布局,把右边的Fragment布局替换

<?xml version="1.0" encoding="utf-8"?>


最后我们修改ManActivity的代码,为button设置监听器,达到点击BUTTON按钮,更换Fragment

class MainActivity : AppCompatActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
val button:Button=findViewById(R.id.button)
button.setOnClickListener{
repalce(AntherRightFrogment())
}
repalce(RightFragment())
}
private fun repalce(fragment:Fragment){
//就是获取所在fragment的父容器的管理器,
val fragementManager=supportFragmentManager
//开启一个事务
val transaction=fragementManager.beginTransaction()
//添加和替换Fragment
transaction.replace(R.id.rightFragment,fragment)
//返回栈
transaction.addToBackStack(null)
//提交事务
transaction.commit()

}

在Fragment中实现返回栈

按下back建返回上一个Fragment

//返回栈
transaction.addToBackStack(null)

Fragment生命周期

onAttach():Fragment和Activity相关联时调用

onCreate():系统创建Fragment时调用

onCreateView():创建Fragment的布局(视图)调用

onActivityCreated():确保与Fragment相关联的Activity调用完时调用

首先我们修改RightFragment代码来看效果

package com.example.fragmenttest

import android.content.Context
import android.os.Bundle
import android.util.Log
import android.view.LayoutInflater
import android.view.View
import android.view.ViewGroup
import androidx.fragment.app.Fragment

class RightFragment :Fragment(){
companion object{
const val TAG=“RightFragment”
}
//当Fragment和Activity建立关联时调用
override fun onAttach(context: Context) {
super.onAttach(context)
Log.d(TAG,“onAttach”)
}

override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
Log.d(TAG,“onCteate”)
}
//为Fragment创建视图获加载布局时调用
override fun onCreateView(
inflater: LayoutInflater,
container: ViewGroup?,
savedInstanceState: Bundle?
): View? {
Log.d(TAG,“onCreateView”)
return inflater.inflate(R.layout.right_fragment,container,false)
}
//确保和Fragment相关联的Activity已经创建完毕时候调用
override fun onActivityCreated(savedInstanceState: Bundle?) {
super.onActivityCreated(savedInstanceState)

Log.d(TAG,“onActivityCreated”)
}

override fun onStart() {
super.onStart()
Log.d(TAG,“onStart”)
}

override fun onResume() {
super.onResume()
Log.d(TAG,“onResume”)
}

override fun onPause() {
super.onPause()
Log.d(TAG,“onPause”)
}

override fun onStop() {
super.onStop()
Log.d(TAG,“onStop”)
}
//当与Fragment先关联的视图移除时候调用
override fun onDestroyView() {
super.onDestroyView()
Log.d(TAG,“onDestroyView”)
}

override fun onDestroy() {
super.onDestroy()
Log.d(TAG,“onDestroy”)
}
//当Fragment与Activity解除关联时候调用
override fun onDetach() {
super.onDetach()
Log.d(TAG,“onDetach”)
}

}

首次加载RightFragment

Android学习--Fragment,Android实习面试经验汇总

按下Button按钮

Android学习--Fragment,Android实习面试经验汇总

按下Back键返回

Android学习--Fragment,Android实习面试经验汇总

再次按下Back键

Android学习--Fragment,Android实习面试经验汇总

使用限定符

这个作用比较大例如一般平板使用双页符,因为屏幕比较大任性,但是我们手机就不同了屏幕空间小,

只能显示一页,那么怎么才能让运行程序的程序自动判断到底用那页了,这时候就使用我们的限定符(qualifier)实现。

首先我们修改activity.main.xml代码,只留下我们左边的Fragment,就是带一个button按钮的,把它就用做我们手机的单页显示。

​ 修改 android:layout_width="match_parent让它宽度和父布局一样占满空间

<?xml version="1.0" encoding="utf-8"?>


接着在res目录下新建一个layout-large文件夹,然后在这个文件夹下添加一个新的activity_main.xml布局,代码就是前面双页布局,这里只修改屏幕占比,这里large就是一个限定符,认为是large的设备就加载这个个layout-large文件夹布局。

<?xml version="1.0" encoding="utf-8"?>


最后运行代码在平板上
Android学习--Fragment,Android实习面试经验汇总
在手机上
Android学习--Fragment,Android实习面试经验汇总
enttest.RightFragment"
android:layout_width=“0dp”
android:layout_height=“match_parent”
android:layout_weight=“3”/>

最后运行代码在平板上
[外链图片转存中…(img-O5rUODHV-1643352659130)]
在手机上
[外链图片转存中…(img-02HT6r1h-1643352659130)]

上一篇:ViewPager2+Fragment+TabLayout


下一篇:Android 中高级面试题:Activity是如何实现LifecycleOwner的?