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调用完时调用
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
按下Button按钮
按下Back键返回
再次按下Back键
使用限定符
这个作用比较大例如一般平板使用双页符,因为屏幕比较大任性,但是我们手机就不同了屏幕空间小,
只能显示一页,那么怎么才能让运行程序的程序自动判断到底用那页了,这时候就使用我们的限定符(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:layout_width=“0dp”
android:layout_height=“match_parent”
android:layout_weight=“3”/>
最后运行代码在平板上
[外链图片转存中…(img-O5rUODHV-1643352659130)]
在手机上
[外链图片转存中…(img-02HT6r1h-1643352659130)]