android kotlin - Fragment example






MainActivity.kt



package com.cfsuman.kotlinexamples

import android.support.v7.app.AppCompatActivity
import android.os.Bundle
import kotlinx.android.synthetic.main.activity_main.*


class MainActivity : AppCompatActivity() {

override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)

// Set a click listener for first button widget
button1.setOnClickListener {
// Get the text fragment instance
val textFragment = TextFragment()

// Get the support fragment manager instance
val manager = supportFragmentManager

// Begin the fragment transition using support fragment manager
val transaction = manager.beginTransaction()

// Replace the fragment on container
transaction.replace(R.id.fragment_container,textFragment)
transaction.addToBackStack(null)

// Finishing the transition
transaction.commit()
}


// Set a click listener for second button widget
button2.setOnClickListener {
// Get the text fragment instance
val imageFragment = ImageFragment()

// Get the support fragment manager instance
val manager = supportFragmentManager

// Begin the fragment transition using support fragment manager
val transaction = manager.beginTransaction()

// Replace the fragment on container
transaction.replace(R.id.fragment_container,imageFragment)
transaction.addToBackStack(null)

// Finishing the transition
transaction.commit()
}
}
}




activity_main.xml



<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/root_layout"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
android:padding="16dp"
android:background="#f8fdf8"
>
<Button
android:id="@+id/button1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Load Text Fragment"
android:textAllCaps="false"
/>
<Button
android:id="@+id/button2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Load Image Fragment"
android:textAllCaps="false"
/>
<LinearLayout
android:id="@+id/fragment_container"
android:layout_width="match_parent"
android:layout_height="0dp"
android:layout_weight="1"
android:orientation="vertical"
android:background="#c1cfba"
/>
</LinearLayout>





TextFragment.kt



package com.cfsuman.kotlinexamples


import android.content.Context
import android.graphics.Color
import android.os.Bundle
import android.support.v4.app.Fragment
import android.view.LayoutInflater
import android.view.View
import android.view.ViewGroup
import android.widget.TextView
import android.widget.Toast


class TextFragment : Fragment(){
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
}

override fun onCreateView(inflater: LayoutInflater?, container: ViewGroup?, savedInstanceState: Bundle?): View? {
// Get the custom view for this fragment layout
val view = inflater!!.inflate(R.layout.layout_text_fragment,container,false)

// Get the text view widget reference from custom layout
val tv = view.findViewById<TextView>(R.id.text_view)

// Set a click listener for text view object
tv.setOnClickListener{
// Change the text color
tv.setTextColor(Color.RED)

// Show click confirmation
Toast.makeText(view.context,"TextView clicked.",Toast.LENGTH_SHORT).show()
}

// Return the fragment view/layout
return view
}

override fun onPause() {
super.onPause()
}

override fun onAttach(context: Context?) {
super.onAttach(context)
}

override fun onDestroy() {
super.onDestroy()
}

override fun onDetach() {
super.onDetach()
}

override fun onStart() {
super.onStart()
}

override fun onStop() {
super.onStop()
}
}




layout_text_fragment.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="vertical"
android:padding="16dp"
>
<TextView
android:id="@+id/text_view"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="This is a sample text from Text Fragment"
android:textSize="50sp"
/>
</LinearLayout>





ImageFragment.kt



package com.cfsuman.kotlinexamples


import android.content.Context
import android.os.Bundle
import android.support.v4.app.Fragment
import android.view.LayoutInflater
import android.view.View
import android.view.ViewGroup


class ImageFragment : Fragment(){
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
}

override fun onCreateView(inflater: LayoutInflater?, container: ViewGroup?, savedInstanceState: Bundle?): View? {
// Return the fragment view/layout
return inflater!!.inflate(R.layout.layout_image_fragment,container,false)
}

override fun onPause() {
super.onPause()
}

override fun onAttach(context: Context?) {
super.onAttach(context)
}

override fun onDestroy() {
super.onDestroy()
}

override fun onDetach() {
super.onDetach()
}

override fun onStart() {
super.onStart()
}

override fun onStop() {
super.onStop()
}
}




layout_image_fragment.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="vertical"
android:padding="16dp"
>
<ImageView
android:id="@+id/image_view"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/flower"
/>
</LinearLayout>